]> foleosoft.com Git - QAnsel.git/commitdiff
Sun Jan 19 08:12:02 PM EST 2025
authormiha-q <>
Mon, 20 Jan 2025 01:12:02 +0000 (20:12 -0500)
committermiha-q <>
Mon, 20 Jan 2025 01:12:02 +0000 (20:12 -0500)
22 files changed:
src/imports/OrbitControls.js [deleted file]
src/imports/QAnsel.apk [deleted file]
src/imports/bloch-sphere.html [deleted file]
src/imports/chart.js [deleted file]
src/imports/code-input.css [deleted file]
src/imports/code-input.js [deleted file]
src/imports/code.html [deleted file]
src/imports/dom-to-image.js [deleted file]
src/imports/estouls-api.js [deleted file]
src/imports/guide.pdf [deleted file]
src/imports/highlight.js [deleted file]
src/imports/istina-editor.css [deleted file]
src/imports/istina-editor.js [deleted file]
src/imports/jasmal.js [deleted file]
src/imports/math.js.map [deleted file]
src/imports/math.min.js [deleted file]
src/imports/measure.png [deleted file]
src/imports/micromodal.css [deleted file]
src/imports/micromodal.js [deleted file]
src/imports/spinner.gif [deleted file]
src/imports/three.min.js [deleted file]
src/imports/welcome.png [deleted file]

diff --git a/src/imports/OrbitControls.js b/src/imports/OrbitControls.js
deleted file mode 100644 (file)
index 0873097..0000000
+++ /dev/null
@@ -1,1045 +0,0 @@
-( function () {
-
-       // Unlike TrackballControls, it maintains the "up" direction object.up (+Y by default).
-       //
-       //    Orbit - left mouse / touch: one-finger move
-       //    Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish
-       //    Pan - right mouse, or left mouse + ctrl/meta/shiftKey, or arrow keys / touch: two-finger move
-
-       const _changeEvent = {
-               type: 'change'
-       };
-       const _startEvent = {
-               type: 'start'
-       };
-       const _endEvent = {
-               type: 'end'
-       };
-
-       class OrbitControls extends THREE.EventDispatcher {
-
-               constructor( object, domElement ) {
-
-                       super();
-                       if ( domElement === undefined ) console.warn( 'THREE.OrbitControls: The second parameter "domElement" is now mandatory.' );
-                       if ( domElement === document ) console.error( 'THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.' );
-                       this.object = object;
-                       this.domElement = domElement; // Set to false to disable this control
-
-                       this.enabled = true; // "target" sets the location of focus, where the object orbits around
-
-                       this.target = new THREE.Vector3(); // How far you can dolly in and out ( PerspectiveCamera only )
-
-                       this.minDistance = 0;
-                       this.maxDistance = Infinity; // How far you can zoom in and out ( OrthographicCamera only )
-
-                       this.minZoom = 0;
-                       this.maxZoom = Infinity; // How far you can orbit vertically, upper and lower limits.
-                       // Range is 0 to Math.PI radians.
-
-                       this.minPolarAngle = 0; // radians
-
-                       this.maxPolarAngle = Math.PI; // radians
-                       // How far you can orbit horizontally, upper and lower limits.
-                       // If set, the interval [ min, max ] must be a sub-interval of [ - 2 PI, 2 PI ], with ( max - min < 2 PI )
-
-                       this.minAzimuthAngle = - Infinity; // radians
-
-                       this.maxAzimuthAngle = Infinity; // radians
-                       // Set to true to enable damping (inertia)
-                       // If damping is enabled, you must call controls.update() in your animation loop
-
-                       this.enableDamping = false;
-                       this.dampingFactor = 0.05; // This option actually enables dollying in and out; left as "zoom" for backwards compatibility.
-                       // Set to false to disable zooming
-
-                       this.enableZoom = true;
-                       this.zoomSpeed = 1.0; // Set to false to disable rotating
-
-                       this.enableRotate = true;
-                       this.rotateSpeed = 1.0; // Set to false to disable panning
-
-                       this.enablePan = true;
-                       this.panSpeed = 1.0;
-                       this.screenSpacePanning = true; // if false, pan orthogonal to world-space direction camera.up
-
-                       this.keyPanSpeed = 7.0; // pixels moved per arrow key push
-                       // Set to true to automatically rotate around the target
-                       // If auto-rotate is enabled, you must call controls.update() in your animation loop
-
-                       this.autoRotate = false;
-                       this.autoRotateSpeed = 2.0; // 30 seconds per orbit when fps is 60
-                       // The four arrow keys
-
-                       this.keys = {
-                               LEFT: 'ArrowLeft',
-                               UP: 'ArrowUp',
-                               RIGHT: 'ArrowRight',
-                               BOTTOM: 'ArrowDown'
-                       }; // Mouse buttons
-
-                       this.mouseButtons = {
-                               LEFT: THREE.MOUSE.ROTATE,
-                               MIDDLE: THREE.MOUSE.DOLLY,
-                               RIGHT: THREE.MOUSE.PAN
-                       }; // Touch fingers
-
-                       this.touches = {
-                               ONE: THREE.TOUCH.ROTATE,
-                               TWO: THREE.TOUCH.DOLLY_PAN
-                       }; // for reset
-
-                       this.target0 = this.target.clone();
-                       this.position0 = this.object.position.clone();
-                       this.zoom0 = this.object.zoom; // the target DOM element for key events
-
-                       this._domElementKeyEvents = null; //
-                       // public methods
-                       //
-
-                       this.getPolarAngle = function () {
-
-                               return spherical.phi;
-
-                       };
-
-                       this.getAzimuthalAngle = function () {
-
-                               return spherical.theta;
-
-                       };
-
-                       this.listenToKeyEvents = function ( domElement ) {
-
-                               domElement.addEventListener( 'keydown', onKeyDown );
-                               this._domElementKeyEvents = domElement;
-
-                       };
-
-                       this.saveState = function () {
-
-                               scope.target0.copy( scope.target );
-                               scope.position0.copy( scope.object.position );
-                               scope.zoom0 = scope.object.zoom;
-
-                       };
-
-                       this.reset = function () {
-
-                               scope.target.copy( scope.target0 );
-                               scope.object.position.copy( scope.position0 );
-                               scope.object.zoom = scope.zoom0;
-                               scope.object.updateProjectionMatrix();
-                               scope.dispatchEvent( _changeEvent );
-                               scope.update();
-                               state = STATE.NONE;
-
-                       }; // this method is exposed, but perhaps it would be better if we can make it private...
-
-
-                       this.update = function () {
-
-                               const offset = new THREE.Vector3(); // so camera.up is the orbit axis
-
-                               const quat = new THREE.Quaternion().setFromUnitVectors( object.up, new THREE.Vector3( 0, 1, 0 ) );
-                               const quatInverse = quat.clone().invert();
-                               const lastPosition = new THREE.Vector3();
-                               const lastQuaternion = new THREE.Quaternion();
-                               const twoPI = 2 * Math.PI;
-                               return function update() {
-
-                                       const position = scope.object.position;
-                                       offset.copy( position ).sub( scope.target ); // rotate offset to "y-axis-is-up" space
-
-                                       offset.applyQuaternion( quat ); // angle from z-axis around y-axis
-
-                                       spherical.setFromVector3( offset );
-
-                                       if ( scope.autoRotate && state === STATE.NONE ) {
-
-                                               rotateLeft( getAutoRotationAngle() );
-
-                                       }
-
-                                       if ( scope.enableDamping ) {
-
-                                               spherical.theta += sphericalDelta.theta * scope.dampingFactor;
-                                               spherical.phi += sphericalDelta.phi * scope.dampingFactor;
-
-                                       } else {
-
-                                               spherical.theta += sphericalDelta.theta;
-                                               spherical.phi += sphericalDelta.phi;
-
-                                       } // restrict theta to be between desired limits
-
-
-                                       let min = scope.minAzimuthAngle;
-                                       let max = scope.maxAzimuthAngle;
-
-                                       if ( isFinite( min ) && isFinite( max ) ) {
-
-                                               if ( min < - Math.PI ) min += twoPI; else if ( min > Math.PI ) min -= twoPI;
-                                               if ( max < - Math.PI ) max += twoPI; else if ( max > Math.PI ) max -= twoPI;
-
-                                               if ( min <= max ) {
-
-                                                       spherical.theta = Math.max( min, Math.min( max, spherical.theta ) );
-
-                                               } else {
-
-                                                       spherical.theta = spherical.theta > ( min + max ) / 2 ? Math.max( min, spherical.theta ) : Math.min( max, spherical.theta );
-
-                                               }
-
-                                       } // restrict phi to be between desired limits
-
-
-                                       spherical.phi = Math.max( scope.minPolarAngle, Math.min( scope.maxPolarAngle, spherical.phi ) );
-                                       spherical.makeSafe();
-                                       spherical.radius *= scale; // restrict radius to be between desired limits
-
-                                       spherical.radius = Math.max( scope.minDistance, Math.min( scope.maxDistance, spherical.radius ) ); // move target to panned location
-
-                                       if ( scope.enableDamping === true ) {
-
-                                               scope.target.addScaledVector( panOffset, scope.dampingFactor );
-
-                                       } else {
-
-                                               scope.target.add( panOffset );
-
-                                       }
-
-                                       offset.setFromSpherical( spherical ); // rotate offset back to "camera-up-vector-is-up" space
-
-                                       offset.applyQuaternion( quatInverse );
-                                       position.copy( scope.target ).add( offset );
-                                       scope.object.lookAt( scope.target );
-
-                                       if ( scope.enableDamping === true ) {
-
-                                               sphericalDelta.theta *= 1 - scope.dampingFactor;
-                                               sphericalDelta.phi *= 1 - scope.dampingFactor;
-                                               panOffset.multiplyScalar( 1 - scope.dampingFactor );
-
-                                       } else {
-
-                                               sphericalDelta.set( 0, 0, 0 );
-                                               panOffset.set( 0, 0, 0 );
-
-                                       }
-
-                                       scale = 1; // update condition is:
-                                       // min(camera displacement, camera rotation in radians)^2 > EPS
-                                       // using small-angle approximation cos(x/2) = 1 - x^2 / 8
-
-                                       if ( zoomChanged || lastPosition.distanceToSquared( scope.object.position ) > EPS || 8 * ( 1 - lastQuaternion.dot( scope.object.quaternion ) ) > EPS ) {
-
-                                               scope.dispatchEvent( _changeEvent );
-                                               lastPosition.copy( scope.object.position );
-                                               lastQuaternion.copy( scope.object.quaternion );
-                                               zoomChanged = false;
-                                               return true;
-
-                                       }
-
-                                       return false;
-
-                               };
-
-                       }();
-
-                       this.dispose = function () {
-
-                               scope.domElement.removeEventListener( 'contextmenu', onContextMenu );
-                               scope.domElement.removeEventListener( 'pointerdown', onPointerDown );
-                               scope.domElement.removeEventListener( 'wheel', onMouseWheel );
-                               scope.domElement.removeEventListener( 'touchstart', onTouchStart );
-                               scope.domElement.removeEventListener( 'touchend', onTouchEnd );
-                               scope.domElement.removeEventListener( 'touchmove', onTouchMove );
-                               scope.domElement.ownerDocument.removeEventListener( 'pointermove', onPointerMove );
-                               scope.domElement.ownerDocument.removeEventListener( 'pointerup', onPointerUp );
-
-                               if ( scope._domElementKeyEvents !== null ) {
-
-                                       scope._domElementKeyEvents.removeEventListener( 'keydown', onKeyDown );
-
-                               } //scope.dispatchEvent( { type: 'dispose' } ); // should this be added here?
-
-                       }; //
-                       // internals
-                       //
-
-
-                       const scope = this;
-                       const STATE = {
-                               NONE: - 1,
-                               ROTATE: 0,
-                               DOLLY: 1,
-                               PAN: 2,
-                               TOUCH_ROTATE: 3,
-                               TOUCH_PAN: 4,
-                               TOUCH_DOLLY_PAN: 5,
-                               TOUCH_DOLLY_ROTATE: 6
-                       };
-                       let state = STATE.NONE;
-                       const EPS = 0.000001; // current position in spherical coordinates
-
-                       const spherical = new THREE.Spherical();
-                       const sphericalDelta = new THREE.Spherical();
-                       let scale = 1;
-                       const panOffset = new THREE.Vector3();
-                       let zoomChanged = false;
-                       const rotateStart = new THREE.Vector2();
-                       const rotateEnd = new THREE.Vector2();
-                       const rotateDelta = new THREE.Vector2();
-                       const panStart = new THREE.Vector2();
-                       const panEnd = new THREE.Vector2();
-                       const panDelta = new THREE.Vector2();
-                       const dollyStart = new THREE.Vector2();
-                       const dollyEnd = new THREE.Vector2();
-                       const dollyDelta = new THREE.Vector2();
-
-                       function getAutoRotationAngle() {
-
-                               return 2 * Math.PI / 60 / 60 * scope.autoRotateSpeed;
-
-                       }
-
-                       function getZoomScale() {
-
-                               return Math.pow( 0.95, scope.zoomSpeed );
-
-                       }
-
-                       function rotateLeft( angle ) {
-
-                               sphericalDelta.theta -= angle;
-
-                       }
-
-                       function rotateUp( angle ) {
-
-                               sphericalDelta.phi -= angle;
-
-                       }
-
-                       const panLeft = function () {
-
-                               const v = new THREE.Vector3();
-                               return function panLeft( distance, objectMatrix ) {
-
-                                       v.setFromMatrixColumn( objectMatrix, 0 ); // get X column of objectMatrix
-
-                                       v.multiplyScalar( - distance );
-                                       panOffset.add( v );
-
-                               };
-
-                       }();
-
-                       const panUp = function () {
-
-                               const v = new THREE.Vector3();
-                               return function panUp( distance, objectMatrix ) {
-
-                                       if ( scope.screenSpacePanning === true ) {
-
-                                               v.setFromMatrixColumn( objectMatrix, 1 );
-
-                                       } else {
-
-                                               v.setFromMatrixColumn( objectMatrix, 0 );
-                                               v.crossVectors( scope.object.up, v );
-
-                                       }
-
-                                       v.multiplyScalar( distance );
-                                       panOffset.add( v );
-
-                               };
-
-                       }(); // deltaX and deltaY are in pixels; right and down are positive
-
-
-                       const pan = function () {
-
-                               const offset = new THREE.Vector3();
-                               return function pan( deltaX, deltaY ) {
-
-                                       const element = scope.domElement;
-
-                                       if ( scope.object.isPerspectiveCamera ) {
-
-                                               // perspective
-                                               const position = scope.object.position;
-                                               offset.copy( position ).sub( scope.target );
-                                               let targetDistance = offset.length(); // half of the fov is center to top of screen
-
-                                               targetDistance *= Math.tan( scope.object.fov / 2 * Math.PI / 180.0 ); // we use only clientHeight here so aspect ratio does not distort speed
-
-                                               panLeft( 2 * deltaX * targetDistance / element.clientHeight, scope.object.matrix );
-                                               panUp( 2 * deltaY * targetDistance / element.clientHeight, scope.object.matrix );
-
-                                       } else if ( scope.object.isOrthographicCamera ) {
-
-                                               // orthographic
-                                               panLeft( deltaX * ( scope.object.right - scope.object.left ) / scope.object.zoom / element.clientWidth, scope.object.matrix );
-                                               panUp( deltaY * ( scope.object.top - scope.object.bottom ) / scope.object.zoom / element.clientHeight, scope.object.matrix );
-
-                                       } else {
-
-                                               // camera neither orthographic nor perspective
-                                               console.warn( 'WARNING: OrbitControls.js encountered an unknown camera type - pan disabled.' );
-                                               scope.enablePan = false;
-
-                                       }
-
-                               };
-
-                       }();
-
-                       function dollyOut( dollyScale ) {
-
-                               if ( scope.object.isPerspectiveCamera ) {
-
-                                       scale /= dollyScale;
-
-                               } else if ( scope.object.isOrthographicCamera ) {
-
-                                       scope.object.zoom = Math.max( scope.minZoom, Math.min( scope.maxZoom, scope.object.zoom * dollyScale ) );
-                                       scope.object.updateProjectionMatrix();
-                                       zoomChanged = true;
-
-                               } else {
-
-                                       console.warn( 'WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.' );
-                                       scope.enableZoom = false;
-
-                               }
-
-                       }
-
-                       function dollyIn( dollyScale ) {
-
-                               if ( scope.object.isPerspectiveCamera ) {
-
-                                       scale *= dollyScale;
-
-                               } else if ( scope.object.isOrthographicCamera ) {
-
-                                       scope.object.zoom = Math.max( scope.minZoom, Math.min( scope.maxZoom, scope.object.zoom / dollyScale ) );
-                                       scope.object.updateProjectionMatrix();
-                                       zoomChanged = true;
-
-                               } else {
-
-                                       console.warn( 'WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled.' );
-                                       scope.enableZoom = false;
-
-                               }
-
-                       } //
-                       // event callbacks - update the object state
-                       //
-
-
-                       function handleMouseDownRotate( event ) {
-
-                               rotateStart.set( event.clientX, event.clientY );
-
-                       }
-
-                       function handleMouseDownDolly( event ) {
-
-                               dollyStart.set( event.clientX, event.clientY );
-
-                       }
-
-                       function handleMouseDownPan( event ) {
-
-                               panStart.set( event.clientX, event.clientY );
-
-                       }
-
-                       function handleMouseMoveRotate( event ) {
-
-                               rotateEnd.set( event.clientX, event.clientY );
-                               rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( scope.rotateSpeed );
-                               const element = scope.domElement;
-                               rotateLeft( 2 * Math.PI * rotateDelta.x / element.clientHeight ); // yes, height
-
-                               rotateUp( 2 * Math.PI * rotateDelta.y / element.clientHeight );
-                               rotateStart.copy( rotateEnd );
-                               scope.update();
-
-                       }
-
-                       function handleMouseMoveDolly( event ) {
-
-                               dollyEnd.set( event.clientX, event.clientY );
-                               dollyDelta.subVectors( dollyEnd, dollyStart );
-
-                               if ( dollyDelta.y > 0 ) {
-
-                                       dollyOut( getZoomScale() );
-
-                               } else if ( dollyDelta.y < 0 ) {
-
-                                       dollyIn( getZoomScale() );
-
-                               }
-
-                               dollyStart.copy( dollyEnd );
-                               scope.update();
-
-                       }
-
-                       function handleMouseMovePan( event ) {
-
-                               panEnd.set( event.clientX, event.clientY );
-                               panDelta.subVectors( panEnd, panStart ).multiplyScalar( scope.panSpeed );
-                               pan( panDelta.x, panDelta.y );
-                               panStart.copy( panEnd );
-                               scope.update();
-
-                       }
-
-                       function handleMouseUp( ) { // no-op
-                       }
-
-                       function handleMouseWheel( event ) {
-
-                               if ( event.deltaY < 0 ) {
-
-                                       dollyIn( getZoomScale() );
-
-                               } else if ( event.deltaY > 0 ) {
-
-                                       dollyOut( getZoomScale() );
-
-                               }
-
-                               scope.update();
-
-                       }
-
-                       function handleKeyDown( event ) {
-
-                               let needsUpdate = false;
-
-                               switch ( event.code ) {
-
-                                       case scope.keys.UP:
-                                               pan( 0, scope.keyPanSpeed );
-                                               needsUpdate = true;
-                                               break;
-
-                                       case scope.keys.BOTTOM:
-                                               pan( 0, - scope.keyPanSpeed );
-                                               needsUpdate = true;
-                                               break;
-
-                                       case scope.keys.LEFT:
-                                               pan( scope.keyPanSpeed, 0 );
-                                               needsUpdate = true;
-                                               break;
-
-                                       case scope.keys.RIGHT:
-                                               pan( - scope.keyPanSpeed, 0 );
-                                               needsUpdate = true;
-                                               break;
-
-                               }
-
-                               if ( needsUpdate ) {
-
-                                       // prevent the browser from scrolling on cursor keys
-                                       event.preventDefault();
-                                       scope.update();
-
-                               }
-
-                       }
-
-                       function handleTouchStartRotate( event ) {
-
-                               if ( event.touches.length == 1 ) {
-
-                                       rotateStart.set( event.touches[ 0 ].pageX, event.touches[ 0 ].pageY );
-
-                               } else {
-
-                                       const x = 0.5 * ( event.touches[ 0 ].pageX + event.touches[ 1 ].pageX );
-                                       const y = 0.5 * ( event.touches[ 0 ].pageY + event.touches[ 1 ].pageY );
-                                       rotateStart.set( x, y );
-
-                               }
-
-                       }
-
-                       function handleTouchStartPan( event ) {
-
-                               if ( event.touches.length == 1 ) {
-
-                                       panStart.set( event.touches[ 0 ].pageX, event.touches[ 0 ].pageY );
-
-                               } else {
-
-                                       const x = 0.5 * ( event.touches[ 0 ].pageX + event.touches[ 1 ].pageX );
-                                       const y = 0.5 * ( event.touches[ 0 ].pageY + event.touches[ 1 ].pageY );
-                                       panStart.set( x, y );
-
-                               }
-
-                       }
-
-                       function handleTouchStartDolly( event ) {
-
-                               const dx = event.touches[ 0 ].pageX - event.touches[ 1 ].pageX;
-                               const dy = event.touches[ 0 ].pageY - event.touches[ 1 ].pageY;
-                               const distance = Math.sqrt( dx * dx + dy * dy );
-                               dollyStart.set( 0, distance );
-
-                       }
-
-                       function handleTouchStartDollyPan( event ) {
-
-                               if ( scope.enableZoom ) handleTouchStartDolly( event );
-                               if ( scope.enablePan ) handleTouchStartPan( event );
-
-                       }
-
-                       function handleTouchStartDollyRotate( event ) {
-
-                               if ( scope.enableZoom ) handleTouchStartDolly( event );
-                               if ( scope.enableRotate ) handleTouchStartRotate( event );
-
-                       }
-
-                       function handleTouchMoveRotate( event ) {
-
-                               if ( event.touches.length == 1 ) {
-
-                                       rotateEnd.set( event.touches[ 0 ].pageX, event.touches[ 0 ].pageY );
-
-                               } else {
-
-                                       const x = 0.5 * ( event.touches[ 0 ].pageX + event.touches[ 1 ].pageX );
-                                       const y = 0.5 * ( event.touches[ 0 ].pageY + event.touches[ 1 ].pageY );
-                                       rotateEnd.set( x, y );
-
-                               }
-
-                               rotateDelta.subVectors( rotateEnd, rotateStart ).multiplyScalar( scope.rotateSpeed );
-                               const element = scope.domElement;
-                               rotateLeft( 2 * Math.PI * rotateDelta.x / element.clientHeight ); // yes, height
-
-                               rotateUp( 2 * Math.PI * rotateDelta.y / element.clientHeight );
-                               rotateStart.copy( rotateEnd );
-
-                       }
-
-                       function handleTouchMovePan( event ) {
-
-                               if ( event.touches.length == 1 ) {
-
-                                       panEnd.set( event.touches[ 0 ].pageX, event.touches[ 0 ].pageY );
-
-                               } else {
-
-                                       const x = 0.5 * ( event.touches[ 0 ].pageX + event.touches[ 1 ].pageX );
-                                       const y = 0.5 * ( event.touches[ 0 ].pageY + event.touches[ 1 ].pageY );
-                                       panEnd.set( x, y );
-
-                               }
-
-                               panDelta.subVectors( panEnd, panStart ).multiplyScalar( scope.panSpeed );
-                               pan( panDelta.x, panDelta.y );
-                               panStart.copy( panEnd );
-
-                       }
-
-                       function handleTouchMoveDolly( event ) {
-
-                               const dx = event.touches[ 0 ].pageX - event.touches[ 1 ].pageX;
-                               const dy = event.touches[ 0 ].pageY - event.touches[ 1 ].pageY;
-                               const distance = Math.sqrt( dx * dx + dy * dy );
-                               dollyEnd.set( 0, distance );
-                               dollyDelta.set( 0, Math.pow( dollyEnd.y / dollyStart.y, scope.zoomSpeed ) );
-                               dollyOut( dollyDelta.y );
-                               dollyStart.copy( dollyEnd );
-
-                       }
-
-                       function handleTouchMoveDollyPan( event ) {
-
-                               if ( scope.enableZoom ) handleTouchMoveDolly( event );
-                               if ( scope.enablePan ) handleTouchMovePan( event );
-
-                       }
-
-                       function handleTouchMoveDollyRotate( event ) {
-
-                               if ( scope.enableZoom ) handleTouchMoveDolly( event );
-                               if ( scope.enableRotate ) handleTouchMoveRotate( event );
-
-                       }
-
-                       function handleTouchEnd( ) { // no-op
-                       } //
-                       // event handlers - FSM: listen for events and reset state
-                       //
-
-
-                       function onPointerDown( event ) {
-
-                               if ( scope.enabled === false ) return;
-
-                               switch ( event.pointerType ) {
-
-                                       case 'mouse':
-                                       case 'pen':
-                                               onMouseDown( event );
-                                               break;
-        // TODO touch
-
-                               }
-
-                       }
-
-                       function onPointerMove( event ) {
-
-                               if ( scope.enabled === false ) return;
-
-                               switch ( event.pointerType ) {
-
-                                       case 'mouse':
-                                       case 'pen':
-                                               onMouseMove( event );
-                                               break;
-        // TODO touch
-
-                               }
-
-                       }
-
-                       function onPointerUp( event ) {
-
-                               switch ( event.pointerType ) {
-
-                                       case 'mouse':
-                                       case 'pen':
-                                               onMouseUp( event );
-                                               break;
-        // TODO touch
-
-                               }
-
-                       }
-
-                       function onMouseDown( event ) {
-
-                               // Prevent the browser from scrolling.
-                               event.preventDefault(); // Manually set the focus since calling preventDefault above
-                               // prevents the browser from setting it automatically.
-
-                               scope.domElement.focus ? scope.domElement.focus() : window.focus();
-                               let mouseAction;
-
-                               switch ( event.button ) {
-
-                                       case 0:
-                                               mouseAction = scope.mouseButtons.LEFT;
-                                               break;
-
-                                       case 1:
-                                               mouseAction = scope.mouseButtons.MIDDLE;
-                                               break;
-
-                                       case 2:
-                                               mouseAction = scope.mouseButtons.RIGHT;
-                                               break;
-
-                                       default:
-                                               mouseAction = - 1;
-
-                               }
-
-                               switch ( mouseAction ) {
-
-                                       case THREE.MOUSE.DOLLY:
-                                               if ( scope.enableZoom === false ) return;
-                                               handleMouseDownDolly( event );
-                                               state = STATE.DOLLY;
-                                               break;
-
-                                       case THREE.MOUSE.ROTATE:
-                                               if ( event.ctrlKey || event.metaKey || event.shiftKey ) {
-
-                                                       if ( scope.enablePan === false ) return;
-                                                       handleMouseDownPan( event );
-                                                       state = STATE.PAN;
-
-                                               } else {
-
-                                                       if ( scope.enableRotate === false ) return;
-                                                       handleMouseDownRotate( event );
-                                                       state = STATE.ROTATE;
-
-                                               }
-
-                                               break;
-
-                                       case THREE.MOUSE.PAN:
-                                               if ( event.ctrlKey || event.metaKey || event.shiftKey ) {
-
-                                                       if ( scope.enableRotate === false ) return;
-                                                       handleMouseDownRotate( event );
-                                                       state = STATE.ROTATE;
-
-                                               } else {
-
-                                                       if ( scope.enablePan === false ) return;
-                                                       handleMouseDownPan( event );
-                                                       state = STATE.PAN;
-
-                                               }
-
-                                               break;
-
-                                       default:
-                                               state = STATE.NONE;
-
-                               }
-
-                               if ( state !== STATE.NONE ) {
-
-                                       scope.domElement.ownerDocument.addEventListener( 'pointermove', onPointerMove );
-                                       scope.domElement.ownerDocument.addEventListener( 'pointerup', onPointerUp );
-                                       scope.dispatchEvent( _startEvent );
-
-                               }
-
-                       }
-
-                       function onMouseMove( event ) {
-
-                               if ( scope.enabled === false ) return;
-                               event.preventDefault();
-
-                               switch ( state ) {
-
-                                       case STATE.ROTATE:
-                                               if ( scope.enableRotate === false ) return;
-                                               handleMouseMoveRotate( event );
-                                               break;
-
-                                       case STATE.DOLLY:
-                                               if ( scope.enableZoom === false ) return;
-                                               handleMouseMoveDolly( event );
-                                               break;
-
-                                       case STATE.PAN:
-                                               if ( scope.enablePan === false ) return;
-                                               handleMouseMovePan( event );
-                                               break;
-
-                               }
-
-                       }
-
-                       function onMouseUp( event ) {
-
-                               scope.domElement.ownerDocument.removeEventListener( 'pointermove', onPointerMove );
-                               scope.domElement.ownerDocument.removeEventListener( 'pointerup', onPointerUp );
-                               if ( scope.enabled === false ) return;
-                               handleMouseUp( event );
-                               scope.dispatchEvent( _endEvent );
-                               state = STATE.NONE;
-
-                       }
-
-                       function onMouseWheel( event ) {
-
-                               if ( scope.enabled === false || scope.enableZoom === false || state !== STATE.NONE && state !== STATE.ROTATE ) return;
-                               event.preventDefault();
-                               scope.dispatchEvent( _startEvent );
-                               handleMouseWheel( event );
-                               scope.dispatchEvent( _endEvent );
-
-                       }
-
-                       function onKeyDown( event ) {
-
-                               if ( scope.enabled === false || scope.enablePan === false ) return;
-                               handleKeyDown( event );
-
-                       }
-
-                       function onTouchStart( event ) {
-
-                               if ( scope.enabled === false ) return;
-                               event.preventDefault(); // prevent scrolling
-
-                               switch ( event.touches.length ) {
-
-                                       case 1:
-                                               switch ( scope.touches.ONE ) {
-
-                                                       case THREE.TOUCH.ROTATE:
-                                                               if ( scope.enableRotate === false ) return;
-                                                               handleTouchStartRotate( event );
-                                                               state = STATE.TOUCH_ROTATE;
-                                                               break;
-
-                                                       case THREE.TOUCH.PAN:
-                                                               if ( scope.enablePan === false ) return;
-                                                               handleTouchStartPan( event );
-                                                               state = STATE.TOUCH_PAN;
-                                                               break;
-
-                                                       default:
-                                                               state = STATE.NONE;
-
-                                               }
-
-                                               break;
-
-                                       case 2:
-                                               switch ( scope.touches.TWO ) {
-
-                                                       case THREE.TOUCH.DOLLY_PAN:
-                                                               if ( scope.enableZoom === false && scope.enablePan === false ) return;
-                                                               handleTouchStartDollyPan( event );
-                                                               state = STATE.TOUCH_DOLLY_PAN;
-                                                               break;
-
-                                                       case THREE.TOUCH.DOLLY_ROTATE:
-                                                               if ( scope.enableZoom === false && scope.enableRotate === false ) return;
-                                                               handleTouchStartDollyRotate( event );
-                                                               state = STATE.TOUCH_DOLLY_ROTATE;
-                                                               break;
-
-                                                       default:
-                                                               state = STATE.NONE;
-
-                                               }
-
-                                               break;
-
-                                       default:
-                                               state = STATE.NONE;
-
-                               }
-
-                               if ( state !== STATE.NONE ) {
-
-                                       scope.dispatchEvent( _startEvent );
-
-                               }
-
-                       }
-
-                       function onTouchMove( event ) {
-
-                               if ( scope.enabled === false ) return;
-                               event.preventDefault(); // prevent scrolling
-
-                               switch ( state ) {
-
-                                       case STATE.TOUCH_ROTATE:
-                                               if ( scope.enableRotate === false ) return;
-                                               handleTouchMoveRotate( event );
-                                               scope.update();
-                                               break;
-
-                                       case STATE.TOUCH_PAN:
-                                               if ( scope.enablePan === false ) return;
-                                               handleTouchMovePan( event );
-                                               scope.update();
-                                               break;
-
-                                       case STATE.TOUCH_DOLLY_PAN:
-                                               if ( scope.enableZoom === false && scope.enablePan === false ) return;
-                                               handleTouchMoveDollyPan( event );
-                                               scope.update();
-                                               break;
-
-                                       case STATE.TOUCH_DOLLY_ROTATE:
-                                               if ( scope.enableZoom === false && scope.enableRotate === false ) return;
-                                               handleTouchMoveDollyRotate( event );
-                                               scope.update();
-                                               break;
-
-                                       default:
-                                               state = STATE.NONE;
-
-                               }
-
-                       }
-
-                       function onTouchEnd( event ) {
-
-                               if ( scope.enabled === false ) return;
-                               handleTouchEnd( event );
-                               scope.dispatchEvent( _endEvent );
-                               state = STATE.NONE;
-
-                       }
-
-                       function onContextMenu( event ) {
-
-                               if ( scope.enabled === false ) return;
-                               event.preventDefault();
-
-                       } //
-
-
-                       scope.domElement.addEventListener( 'contextmenu', onContextMenu );
-                       scope.domElement.addEventListener( 'pointerdown', onPointerDown );
-                       scope.domElement.addEventListener( 'wheel', onMouseWheel, {
-                               passive: false
-                       } );
-                       scope.domElement.addEventListener( 'touchstart', onTouchStart, {
-                               passive: false
-                       } );
-                       scope.domElement.addEventListener( 'touchend', onTouchEnd );
-                       scope.domElement.addEventListener( 'touchmove', onTouchMove, {
-                               passive: false
-                       } ); // force an update at start
-
-                       this.update();
-
-               }
-
-       } // This set of controls performs orbiting, dollying (zooming), and panning.
-       // Unlike TrackballControls, it maintains the "up" direction object.up (+Y by default).
-       // This is very similar to OrbitControls, another set of touch behavior
-       //
-       //    Orbit - right mouse, or left mouse + ctrl/meta/shiftKey / touch: two-finger rotate
-       //    Zoom - middle mouse, or mousewheel / touch: two-finger spread or squish
-       //    Pan - left mouse, or arrow keys / touch: one-finger move
-
-
-       class MapControls extends OrbitControls {
-
-               constructor( object, domElement ) {
-
-                       super( object, domElement );
-                       this.screenSpacePanning = false; // pan orthogonal to world-space direction camera.up
-
-                       this.mouseButtons.LEFT = THREE.MOUSE.PAN;
-                       this.mouseButtons.RIGHT = THREE.MOUSE.ROTATE;
-                       this.touches.ONE = THREE.TOUCH.PAN;
-                       this.touches.TWO = THREE.TOUCH.DOLLY_ROTATE;
-
-               }
-
-       }
-
-       THREE.MapControls = MapControls;
-       THREE.OrbitControls = OrbitControls;
-
-} )();
diff --git a/src/imports/QAnsel.apk b/src/imports/QAnsel.apk
deleted file mode 100644 (file)
index 0c2917c..0000000
Binary files a/src/imports/QAnsel.apk and /dev/null differ
diff --git a/src/imports/bloch-sphere.html b/src/imports/bloch-sphere.html
deleted file mode 100644 (file)
index 85509a6..0000000
+++ /dev/null
@@ -1,1991 +0,0 @@
-<!DOCTYPE html>
-<html lang="en">
-<head>
-    <meta charset="UTF-8">
-    <meta name="viewport" content="width=device-width, initial-scale=1.0">
-    <style>
-        body { margin: 0; user-select: none; }
-        canvas { display: block; }
-        .overlay
-               {
-            position: absolute;
-            top: 20px;
-            left: 20px;
-            z-index: 1;
-        }
-        .overlay button
-               {
-            margin-bottom: 5px;
-            font-size: 12px;
-                       width: 32px;
-                       height: 32px;
-                       text-align: center;
-                       cursor: pointer;
-        }
-               pre { display: none; }
-    </style>
-</head>
-<body>
-    <div class="overlay">
-               <button>|0⟩</button>
-               <button>🔍</button>
-        <button>X</button>
-        <button>Y</button>
-        <button>Z</button>
-               <br />
-        <button>H</button>
-        <button>S</button>
-        <button>T</button>
-        <button>S<sup>†</sup></button>
-        <button>T<sup>†</sup></button>
-    </div>
-    <script src="three.min.js"></script>
-    <script src="OrbitControls.js"></script>
-    <script>
-               var useColor = true;
-               if (window.location.href.includes("picturemode=true"))
-               {
-                       useColor = false;
-               }
-               var gate = {};
-               gate.i =
-               [
-                       [1, 0], [0, 0],
-                       [0, 0], [1, 0],
-               ];
-               gate.x =
-               [
-                       [0, 0], [1, 0],
-                       [1, 0], [0, 0],
-               ];
-               gate.y =
-               [
-                       [0, 0], [0, -1],
-                       [0, 1], [0,  0],
-               ];
-               gate.z =
-               [
-                       [1, 0], [ 0, 0],
-                       [0, 0], [-1, 0],
-               ];
-               var R = 1/Math.sqrt(2);
-               [
-                       [ 1, 0 ], [ 0, 0 ],
-                       [ 0, 0 ], [ 1, 0 ],
-               ];
-               gate.h = 
-               [
-                       [ R, 0 ], [ R, 0 ],
-                       [ R, 0 ], [-R, 0 ],
-               ];
-               gate.s =
-               [
-                       [1, 0], [0, 0],
-                       [0, 0], [0, 1],
-               ];
-               gate.t =
-               [
-                       [1, 0], [0, 0],
-                       [0, 0], [R, R],
-               ];
-               gate.sdg =
-               [
-                       [1, 0], [0,  0],
-                       [0, 0], [0, -1],
-               ];
-               gate.tdg =
-               [
-                       [1, 0], [0,  0],
-                       [0, 0], [R, -R],
-               ];
-               gate.reset = "reset";
-               gate.measure = "measure";
-               document.body.onload = function()
-               {
-                       gate.xh = precomputedHamiltonian("x");
-                       gate.yh = precomputedHamiltonian("y");
-                       gate.zh = precomputedHamiltonian("z");
-                       gate.hh = precomputedHamiltonian("h");
-                       gate.sh = precomputedHamiltonian("s");
-                       gate.sdgh = precomputedHamiltonian("sdg");
-                       gate.th = precomputedHamiltonian("t");
-                       gate.tdgh = precomputedHamiltonian("tdg");
-               };
-
-               var complex = {};
-               complex.multiply = (a, b) =>
-               {
-                       var r = [ 0, 0 ];
-                       var f = a[0] * b[0];
-                       var o = a[0] * b[1];
-                       var i = a[1] * b[0];
-                       var l = a[1] * b[1];
-                       r[0] = f - l;
-                       r[1] = o + i;
-                       return r;
-               };
-               complex.add = (a, b) =>
-               {
-                       return [ a[0] + b[0], a[1] + b[1] ];
-               };
-               complex.conjugate = (a) =>
-               {
-                       return [ a[0], -a[1] ];
-               };
-               complex.magnitude = (a) =>
-               {
-                       return Math.sqrt( Math.pow(a[0], 2) + Math.pow(a[1], 2) );
-               };
-
-               var qubit = {};
-               qubit.state = [ [1, 0], [0, 0] ];
-               qubit.calcX = () => 2 * complex.multiply(qubit.state[0], complex.conjugate(qubit.state[1]))[0];
-               qubit.calcY = () => 2 * complex.multiply(qubit.state[0], complex.conjugate(qubit.state[1]))[1];
-               qubit.calcZ = () => Math.pow(complex.magnitude(qubit.state[0]), 2) - Math.pow(complex.magnitude(qubit.state[1]), 2);
-               qubit.born = function()
-               {
-                       var prob = Math.pow(this.state[0][0], 2) + Math.pow(this.state[0][1], 2);
-                       if (Math.random() < prob) return 0;
-                       else return 1;
-               };
-               qubit.apply = function (g)
-               {
-                       if (g == "reset" || g == "measure")
-                       {
-                               var v = g == "reset" ? 0 : this.born();
-                               if (v == 0)
-                               {
-                                       this.state[0] = [1, 0];
-                                       this.state[1] = [0, 0];
-                               }
-                               else
-                               {
-                                       this.state[0] = [0, 0];
-                                       this.state[1] = [1, 0];
-                               }
-                               changeMainVec(this.calcX(), this.calcY(), this.calcZ());
-                               return;
-                       }
-                       var s = [];
-                       s[0] = complex.multiply(this.state[0], g[0]);
-                       s[0] = complex.add(s[0], complex.multiply(this.state[1], g[2]));
-                       s[1] = complex.multiply(this.state[0], g[1]);
-                       s[1] = complex.add(s[1], complex.multiply(this.state[1], g[3]));
-                       this.state = s;
-                       changeMainVec(this.calcX(), this.calcY(), this.calcZ());
-               };
-               qubit.smoothapply = function(tg, g)
-               {
-                       var btns = document.getElementsByTagName("button");
-                       for (var i = 0; i < btns.length; i++)
-                       {
-                               btns[i].style.pointerEvents = "none";
-                               btns[i].style.touchAction = "none";
-                       }
-                       var init = this.state;
-                       var idx = 0;
-                       var donext = () =>
-                       {
-                               this.state = init;
-                               if (idx > 30)
-                               {
-                                       this.apply(tg);
-                                       for (var i = 0; i < btns.length; i++)
-                                       {
-                                               btns[i].style.pointerEvents = "";
-                                               btns[i].style.touchAction = "";
-                                       }
-                                       return;
-                               }
-                               this.apply(g[idx]);
-                               idx++;
-                               setTimeout(function() { donext(); }, 1000/60);
-                       };
-                       donext();
-               }
-
-        var scene = new THREE.Scene();
-        var camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
-        var renderer = new THREE.WebGLRenderer({ antialias: true });
-        renderer.setSize(window.innerWidth, window.innerHeight);
-        document.body.appendChild(renderer.domElement);
-
-               if (!useColor) scene.background = new THREE.Color(0xffffff);
-
-               var gridHelper = new THREE.GridHelper(10, 10);
-        scene.add(gridHelper);
-
-        // Create the sphere
-        var sphereGeometry = new THREE.SphereGeometry(1, 32, 32);
-        var sphereMaterial = new THREE.MeshStandardMaterial({ 
-            color: 0xaaaaaa,
-            transparent: true,
-            opacity: 0.75
-        });
-        var sphere = new THREE.Mesh(sphereGeometry, sphereMaterial);
-        scene.add(sphere);
-
-//        var light = new THREE.DirectionalLight(0xffffff, 1);
-//        light.position.set(5, 5, 5).normalize();
-//        scene.add(light);
-               var ambientLight = new THREE.AmbientLight(0xffffff, 1);
-        scene.add(ambientLight);
-
-               var vectors =
-               [
-                       "Z", [0, 1, 0],
-                       "Y", [1, 0, 0],
-                       "X", [0, 0, 1],
-               ];
-               for (var i = 0; i < vectors.length; i += 2)
-               {
-                       var direction = new THREE.Vector3(vectors[i + 1][0], vectors[i + 1][1], vectors[i + 1][2]).normalize();
-                       var arrowHelper = new THREE.ArrowHelper(direction, sphere.position, 2, useColor ? 0xff0000 : 0xBBBBBB);
-                       scene.add(arrowHelper);
-                       var label = createTextLabel(vectors[i]);
-                       label.material.color.set(useColor ? 0xffffff : 0x000000);
-                       label.position.copy(arrowHelper.position).add(direction.multiplyScalar(2.25));
-                       scene.add(label);
-               }
-
-               var mainvec = new THREE.Vector3(0, 1, 0).normalize();
-               var mainvechelper = new THREE.ArrowHelper(mainvec, sphere.position, 2, useColor ? 0x00ff00 : 0x000000);
-               scene.add(mainvechelper);
-
-               function changeMainVec(x, y, z)
-               {
-                       scene.remove(mainvechelper);
-                       mainvec = new THREE.Vector3(y, z, x).normalize();
-                       mainvechelper = new THREE.ArrowHelper(mainvec, sphere.position, 2, useColor ? 0x00ff00 : 0x000000);
-                       scene.add(mainvechelper);
-               }
-
-        // Function to create a text label as a sprite
-        function createTextLabel(text) {
-            var canvas = document.createElement('canvas');
-            var context = canvas.getContext('2d');
-            canvas.width = 256;
-            canvas.height = 128;
-
-            // Draw the text
-            context.fillStyle = useColor ? "#ffffff" : "#000000";
-            //context.font = '24px Arial';
-            context.font = '32px Arial';
-            context.textAlign = 'center';
-            context.textBaseline = 'middle';
-            context.fillText(text, canvas.width / 2, canvas.height / 2);
-
-            // Create texture from canvas
-            var texture = new THREE.CanvasTexture(canvas);
-            var spriteMaterial = new THREE.SpriteMaterial({ map: texture, transparent: true });
-            var sprite = new THREE.Sprite(spriteMaterial);
-
-            // Scale sprite to appropriate size
-            sprite.scale.set(1.5, 0.75, 1);
-            return sprite;
-        }
-
-               function factorial(n)
-               {
-                       if (n === 0 || n === 1)
-                       {
-                               return 1;
-                       }
-                       return n * factorial(n - 1);
-               }
-               /*
-        var sphereCenterY = sphere.position.y; // Y position of the sphere's center
-        var sphereRadius = 1; // Radius of the sphere
-
-        if (sphereCenterY <= sphereRadius) {
-            var intersectionRadius = Math.sqrt(Math.pow(sphereRadius, 2) - Math.pow(sphereCenterY, 2));
-
-            // Create a circle at the intersection
-            var circleGeometry = new THREE.CircleGeometry(intersectionRadius, 64);
-            var circleMaterial = new THREE.MeshBasicMaterial({ 
-                color: 0xff0000, 
-                side: THREE.DoubleSide,
-                transparent: true,    // Enable transparency
-                opacity: 1           // Set the opacity (0.0 to 1.0)
-            });
-                       var circle = new THREE.Mesh(circleGeometry, circleMaterial);
-
-            // Position and rotate the circle so it lies on the XZ plane
-            circle.rotation.x = -Math.PI / 2;
-            circle.position.set(sphere.position.x, 0, sphere.position.z);
-            scene.add(circle);
-        }
-               */
-
-        camera.position.x = 3;
-        camera.position.y = 2;
-        camera.position.z = 3;
-
-        var controls = new THREE.OrbitControls(camera, renderer.domElement);
-        controls.update();
-
-               function animate()
-               {
-            requestAnimationFrame(animate);
-            controls.update();
-            renderer.render(scene, camera);
-        }
-
-        animate();
-        window.addEventListener('resize', () =>
-               {
-            camera.aspect = window.innerWidth / window.innerHeight;
-            camera.updateProjectionMatrix();
-            renderer.setSize(window.innerWidth, window.innerHeight);
-        });
-
-               for (var i = 0; i < document.querySelectorAll("button").length; i++)
-               {
-                       document.querySelectorAll("button")[i].addEventListener("click", function()
-                       {
-                               var h = this.innerHTML.toLowerCase().trim();
-                               h = h.replace("<sup>†</sup>", "dg");
-                               h = h.replace("|0⟩", "reset");
-                               h = h.replace("🔍", "measure");
-                               if (gate[h] != undefined && gate[h + "h"] != undefined)
-                               {
-                                       qubit.smoothapply(gate[h], gate[h + "h"]);
-                                       return;
-                               }
-                               else if (gate[h] != undefined)
-                               {
-                                       qubit.apply(gate[h]);
-                               }
-                       });
-               }
-
-               function precomputedHamiltonian(name)
-               {
-                       var txt = document.getElementById("hamiltonian-" + name).innerHTML.trim().split("\n");
-                       var g = [];
-                       for (var i = 0; i < txt.length; i++)
-                       {
-                               var row = txt[i].trim().toLowerCase();
-                               if (row.length == 0) continue;
-                               if (row.includes("ans")) continue;
-                               if (row.includes("matrix")) continue;
-                               row = row.replace(/[\t]/g, " ");
-                               while (row.includes("  ")) row = row.replace("  ", " ");
-                               row = row.replace(/[+][ ]/g, "+");
-                               row = row.replace(/[-][ ]/g, "-");
-                               row = row.split(" ");
-                               var idx = g.length;
-                               g[idx] = [ [0, 0], [ 0, 0 ] ];
-                               var reals = 0;
-                               var imags = 0;
-                               for (var j = 0; j < row.length; j++)
-                               {
-                                       var isreal = !row[j].includes("i");
-                                       if (isreal) reals++; else imags++;
-                                       if (reals == 2) imags = 2;
-                                       if (isreal && reals == 1)
-                                       {
-                                               g[idx][0][0] = parseFloat(row[j]);
-                                       }
-                                       else if (isreal && reals == 2)
-                                       {
-                                               g[idx][1][0] = parseFloat(row[j]);
-                                       }
-                                       else if (!isreal && imags == 1)
-                                       {
-                                               g[idx][0][1] = parseFloat(row[j]);
-                                       }
-                                       else if (!isreal && imags == 2)
-                                       {
-                                               g[idx][1][1] = parseFloat(row[j]);
-                                       }
-                               }
-                       }
-                       var ret = [];
-                       for (var i = 0; i < g.length; i += 2)
-                       {
-                               ret[ret.length] = [ g[i][0], g[i][1], g[i+1][0], g[i+1][1] ];
-                       }
-                       return ret;
-               }
-    </script>
-<pre>
-X = [0, 1; 1, 0];
-Y = [0, -i; i, 0];
-Z = [1, 0; 0, -1];
-H = 1/sqrt(2) * [1, 1; 1, -1];
-S = [1, 0; 0, i];
-Sdg = transpose(conj(S));
-T = [ 1, 0; 0, 1/sqrt(2) + 1/sqrt(2)*i ];
-Tdg = transpose(conj(T));
-
-psi = eye(2);
-ham = i * logm(psi);
-for t=0:30
-       expm(-i*ham*(t/30))
-end
-</pre>
-<pre id="hamiltonian-x">
-       ans =
-
-       Diagonal Matrix
-       
-          1   0
-          0   1
-       
-       ans =
-       
-          0.997261 + 0.052264i   0.002739 - 0.052264i
-          0.002739 - 0.052264i   0.997261 + 0.052264i
-       
-       ans =
-       
-          0.9891 + 0.1040i   0.0109 - 0.1040i
-          0.0109 - 0.1040i   0.9891 + 0.1040i
-       
-       ans =
-       
-          0.9755 + 0.1545i   0.0245 - 0.1545i
-          0.0245 - 0.1545i   0.9755 + 0.1545i
-       
-       ans =
-       
-          0.9568 + 0.2034i   0.0432 - 0.2034i
-          0.0432 - 0.2034i   0.9568 + 0.2034i
-       
-       ans =
-       
-          0.9330 + 0.2500i   0.0670 - 0.2500i
-          0.0670 - 0.2500i   0.9330 + 0.2500i
-       
-       ans =
-       
-          0.9045 + 0.2939i   0.0955 - 0.2939i
-          0.0955 - 0.2939i   0.9045 + 0.2939i
-       
-       ans =
-       
-          0.8716 + 0.3346i   0.1284 - 0.3346i
-          0.1284 - 0.3346i   0.8716 + 0.3346i
-       
-       ans =
-       
-          0.8346 + 0.3716i   0.1654 - 0.3716i
-          0.1654 - 0.3716i   0.8346 + 0.3716i
-       
-       ans =
-       
-          0.7939 + 0.4045i   0.2061 - 0.4045i
-          0.2061 - 0.4045i   0.7939 + 0.4045i
-       
-       ans =
-       
-          0.7500 + 0.4330i   0.2500 - 0.4330i
-          0.2500 - 0.4330i   0.7500 + 0.4330i
-       
-       ans =
-       
-          0.7034 + 0.4568i   0.2966 - 0.4568i
-          0.2966 - 0.4568i   0.7034 + 0.4568i
-       
-       ans =
-       
-          0.6545 + 0.4755i   0.3455 - 0.4755i
-          0.3455 - 0.4755i   0.6545 + 0.4755i
-       
-       ans =
-       
-          0.6040 + 0.4891i   0.3960 - 0.4891i
-          0.3960 - 0.4891i   0.6040 + 0.4891i
-       
-       ans =
-       
-          0.5523 + 0.4973i   0.4477 - 0.4973i
-          0.4477 - 0.4973i   0.5523 + 0.4973i
-       
-       ans =
-       
-          0.5000 + 0.5000i   0.5000 - 0.5000i
-          0.5000 - 0.5000i   0.5000 + 0.5000i
-       
-       ans =
-       
-          0.4477 + 0.4973i   0.5523 - 0.4973i
-          0.5523 - 0.4973i   0.4477 + 0.4973i
-       
-       ans =
-       
-          0.3960 + 0.4891i   0.6040 - 0.4891i
-          0.6040 - 0.4891i   0.3960 + 0.4891i
-       
-       ans =
-       
-          0.3455 + 0.4755i   0.6545 - 0.4755i
-          0.6545 - 0.4755i   0.3455 + 0.4755i
-       
-       ans =
-       
-          0.2966 + 0.4568i   0.7034 - 0.4568i
-          0.7034 - 0.4568i   0.2966 + 0.4568i
-       
-       ans =
-       
-          0.2500 + 0.4330i   0.7500 - 0.4330i
-          0.7500 - 0.4330i   0.2500 + 0.4330i
-       
-       ans =
-       
-          0.2061 + 0.4045i   0.7939 - 0.4045i
-          0.7939 - 0.4045i   0.2061 + 0.4045i
-       
-       ans =
-       
-          0.1654 + 0.3716i   0.8346 - 0.3716i
-          0.8346 - 0.3716i   0.1654 + 0.3716i
-       
-       ans =
-       
-          0.1284 + 0.3346i   0.8716 - 0.3346i
-          0.8716 - 0.3346i   0.1284 + 0.3346i
-       
-       ans =
-       
-          0.0955 + 0.2939i   0.9045 - 0.2939i
-          0.9045 - 0.2939i   0.0955 + 0.2939i
-       
-       ans =
-       
-          0.0670 + 0.2500i   0.9330 - 0.2500i
-          0.9330 - 0.2500i   0.0670 + 0.2500i
-       
-       ans =
-       
-          0.0432 + 0.2034i   0.9568 - 0.2034i
-          0.9568 - 0.2034i   0.0432 + 0.2034i
-       
-       ans =
-       
-          0.0245 + 0.1545i   0.9755 - 0.1545i
-          0.9755 - 0.1545i   0.0245 + 0.1545i
-       
-       ans =
-       
-          0.0109 + 0.1040i   0.9891 - 0.1040i
-          0.9891 - 0.1040i   0.0109 + 0.1040i
-       
-       ans =
-       
-          0.002739 + 0.052264i   0.997261 - 0.052264i
-          0.997261 - 0.052264i   0.002739 + 0.052264i
-       
-       ans =
-       
-          7.8625e-32 + 2.7756e-16i   1.0000e+00 - 2.8328e-16i
-          1.0000e+00 - 2.8328e-16i   1.1008e-31 + 3.8858e-16i
-</pre>
-<pre id="hamiltonian-y">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-   0.997261 + 0.052264i  -0.052264 - 0.002739i
-   0.052264 + 0.002739i   0.997261 + 0.052264i
-
-ans =
-
-   0.9891 + 0.1040i  -0.1040 - 0.0109i
-   0.1040 + 0.0109i   0.9891 + 0.1040i
-
-ans =
-
-   0.9755 + 0.1545i  -0.1545 - 0.0245i
-   0.1545 + 0.0245i   0.9755 + 0.1545i
-
-ans =
-
-   0.9568 + 0.2034i  -0.2034 - 0.0432i
-   0.2034 + 0.0432i   0.9568 + 0.2034i
-
-ans =
-
-   0.9330 + 0.2500i  -0.2500 - 0.0670i
-   0.2500 + 0.0670i   0.9330 + 0.2500i
-
-ans =
-
-   0.9045 + 0.2939i  -0.2939 - 0.0955i
-   0.2939 + 0.0955i   0.9045 + 0.2939i
-
-ans =
-
-   0.8716 + 0.3346i  -0.3346 - 0.1284i
-   0.3346 + 0.1284i   0.8716 + 0.3346i
-
-ans =
-
-   0.8346 + 0.3716i  -0.3716 - 0.1654i
-   0.3716 + 0.1654i   0.8346 + 0.3716i
-
-ans =
-
-   0.7939 + 0.4045i  -0.4045 - 0.2061i
-   0.4045 + 0.2061i   0.7939 + 0.4045i
-
-ans =
-
-   0.7500 + 0.4330i  -0.4330 - 0.2500i
-   0.4330 + 0.2500i   0.7500 + 0.4330i
-
-ans =
-
-   0.7034 + 0.4568i  -0.4568 - 0.2966i
-   0.4568 + 0.2966i   0.7034 + 0.4568i
-
-ans =
-
-   0.6545 + 0.4755i  -0.4755 - 0.3455i
-   0.4755 + 0.3455i   0.6545 + 0.4755i
-
-ans =
-
-   0.6040 + 0.4891i  -0.4891 - 0.3960i
-   0.4891 + 0.3960i   0.6040 + 0.4891i
-
-ans =
-
-   0.5523 + 0.4973i  -0.4973 - 0.4477i
-   0.4973 + 0.4477i   0.5523 + 0.4973i
-
-ans =
-
-   0.5000 + 0.5000i  -0.5000 - 0.5000i
-   0.5000 + 0.5000i   0.5000 + 0.5000i
-
-ans =
-
-   0.4477 + 0.4973i  -0.4973 - 0.5523i
-   0.4973 + 0.5523i   0.4477 + 0.4973i
-
-ans =
-
-   0.3960 + 0.4891i  -0.4891 - 0.6040i
-   0.4891 + 0.6040i   0.3960 + 0.4891i
-
-ans =
-
-   0.3455 + 0.4755i  -0.4755 - 0.6545i
-   0.4755 + 0.6545i   0.3455 + 0.4755i
-
-ans =
-
-   0.2966 + 0.4568i  -0.4568 - 0.7034i
-   0.4568 + 0.7034i   0.2966 + 0.4568i
-
-ans =
-
-   0.2500 + 0.4330i  -0.4330 - 0.7500i
-   0.4330 + 0.7500i   0.2500 + 0.4330i
-
-ans =
-
-   0.2061 + 0.4045i  -0.4045 - 0.7939i
-   0.4045 + 0.7939i   0.2061 + 0.4045i
-
-ans =
-
-   0.1654 + 0.3716i  -0.3716 - 0.8346i
-   0.3716 + 0.8346i   0.1654 + 0.3716i
-
-ans =
-
-   0.1284 + 0.3346i  -0.3346 - 0.8716i
-   0.3346 + 0.8716i   0.1284 + 0.3346i
-
-ans =
-
-   0.0955 + 0.2939i  -0.2939 - 0.9045i
-   0.2939 + 0.9045i   0.0955 + 0.2939i
-
-ans =
-
-   0.0670 + 0.2500i  -0.2500 - 0.9330i
-   0.2500 + 0.9330i   0.0670 + 0.2500i
-
-ans =
-
-   0.0432 + 0.2034i  -0.2034 - 0.9568i
-   0.2034 + 0.9568i   0.0432 + 0.2034i
-
-ans =
-
-   0.0245 + 0.1545i  -0.1545 - 0.9755i
-   0.1545 + 0.9755i   0.0245 + 0.1545i
-
-ans =
-
-   0.0109 + 0.1040i  -0.1040 - 0.9891i
-   0.1040 + 0.9891i   0.0109 + 0.1040i
-
-ans =
-
-   0.002739 + 0.052264i  -0.052264 - 0.997261i
-   0.052264 + 0.997261i   0.002739 + 0.052264i
-
-ans =
-
-  -1.6653e-16 + 2.7818e-16i  -2.8328e-16 - 1.0000e+00i
-   2.8328e-16 + 1.0000e+00i  -1.6653e-16 + 3.9190e-16i
-</pre>
-<pre id="hamiltonian-z">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9945 + 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9781 + 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9511 + 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9135 + 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8660 + 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8090 + 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7431 + 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.6691 + 0.7431i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5878 + 0.8090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5000 + 0.8660i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.4067 + 0.9135i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.3090 + 0.9511i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.2079 + 0.9781i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.1045 + 0.9945i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.0000 + 1.0000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.1045 + 0.9945i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.2079 + 0.9781i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.3090 + 0.9511i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.4067 + 0.9135i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.5000 + 0.8660i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.5878 + 0.8090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.6691 + 0.7431i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.7431 + 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.8090 + 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.8660 + 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.9135 + 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.9511 + 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.9781 + 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -0.9945 + 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0  -1.0000 + 0.0000i
-</pre>
-<pre id="hamiltonian-h">
-       ans =
-       
-          1   0
-          0   1
-       
-       ans =
-       
-          0.999198 + 0.015308i   0.001937 - 0.036956i
-          0.001937 - 0.036956i   0.995324 + 0.089221i
-       
-       ans =
-       
-          0.996800 + 0.030448i   0.007726 - 0.073508i
-          0.007726 - 0.073508i   0.981348 + 0.177464i
-       
-       ans =
-       
-          0.992832 + 0.045254i   0.017304 - 0.109254i
-          0.017304 - 0.109254i   0.958224 + 0.263763i
-       
-       ans =
-       
-          0.987339 + 0.059565i   0.030566 - 0.143803i
-          0.030566 - 0.143803i   0.926206 + 0.347171i
-       
-       ans =
-       
-          0.980380 + 0.073223i   0.047367 - 0.176777i
-          0.047367 - 0.176777i   0.885646 + 0.426777i
-       
-       ans =
-       
-          0.972031 + 0.086079i   0.067523 - 0.207813i
-          0.067523 - 0.207813i   0.836986 + 0.501706i
-       
-       ans =
-       
-          0.962384 + 0.097992i   0.090812 - 0.236573i
-          0.090812 - 0.236573i   0.780760 + 0.571139i
-       
-       ans =
-       
-          0.9515 + 0.1088i   0.1170 - 0.2627i
-          0.1170 - 0.2627i   0.7176 + 0.6343i
-       
-       ans =
-       
-          0.9396 + 0.1185i   0.1457 - 0.2860i
-          0.1457 - 0.2860i   0.6482 + 0.6905i
-       
-       ans =
-       
-          0.9268 + 0.1268i   0.1768 - 0.3062i
-          0.1768 - 0.3062i   0.5732 + 0.7392i
-       
-       ans =
-       
-          0.9131 + 0.1338i   0.2098 - 0.3230i
-          0.2098 - 0.3230i   0.4936 + 0.7798i
-       
-       ans =
-       
-          0.8988 + 0.1393i   0.2443 - 0.3362i
-          0.2443 - 0.3362i   0.4102 + 0.8118i
-       
-       ans =
-       
-          0.8840 + 0.1432i   0.2800 - 0.3458i
-          0.2800 - 0.3458i   0.3239 + 0.8349i
-       
-       ans =
-       
-          0.8689 + 0.1456i   0.3166 - 0.3516i
-          0.3166 - 0.3516i   0.2357 + 0.8489i
-       
-       ans =
-       
-          0.8536 + 0.1464i   0.3536 - 0.3536i
-          0.3536 - 0.3536i   0.1464 + 0.8536i
-       
-       ans =
-       
-          0.8382 + 0.1456i   0.3905 - 0.3516i
-          0.3905 - 0.3516i   0.0572 + 0.8489i
-       
-       ans =
-       
-          0.8231 + 0.1432i   0.4271 - 0.3458i
-          0.4271 - 0.3458i  -0.0310 + 0.8349i
-       
-       ans =
-       
-          0.8083 + 0.1393i   0.4628 - 0.3362i
-          0.4628 - 0.3362i  -0.1173 + 0.8118i
-       
-       ans =
-       
-          0.7940 + 0.1338i   0.4974 - 0.3230i
-          0.4974 - 0.3230i  -0.2007 + 0.7798i
-       
-       ans =
-       
-          0.7803 + 0.1268i   0.5303 - 0.3062i
-          0.5303 - 0.3062i  -0.2803 + 0.7392i
-       
-       ans =
-       
-          0.7675 + 0.1185i   0.5614 - 0.2860i
-          0.5614 - 0.2860i  -0.3553 + 0.6905i
-       
-       ans =
-       
-          0.7556 + 0.1088i   0.5901 - 0.2627i
-          0.5901 - 0.2627i  -0.4247 + 0.6343i
-       
-       ans =
-       
-          0.7447 + 0.0980i   0.6163 - 0.2366i
-          0.6163 - 0.2366i  -0.4879 + 0.5711i
-       
-       ans =
-       
-          0.7351 + 0.0861i   0.6396 - 0.2078i
-          0.6396 - 0.2078i  -0.5441 + 0.5017i
-       
-       ans =
-       
-          0.7267 + 0.0732i   0.6597 - 0.1768i
-          0.6597 - 0.1768i  -0.5928 + 0.4268i
-       
-       ans =
-       
-          0.7198 + 0.0596i   0.6765 - 0.1438i
-          0.6765 - 0.1438i  -0.6333 + 0.3472i
-       
-       ans =
-       
-          0.7143 + 0.0453i   0.6898 - 0.1093i
-          0.6898 - 0.1093i  -0.6653 + 0.2638i
-       
-       ans =
-       
-          0.7103 + 0.0304i   0.6994 - 0.0735i
-          0.6994 - 0.0735i  -0.6885 + 0.1775i
-       
-       ans =
-       
-          0.7079 + 0.0153i   0.7052 - 0.0370i
-          0.7052 - 0.0370i  -0.7024 + 0.0892i
-       
-       ans =
-       
-          0.7071 - 0.0000i   0.7071 - 0.0000i
-          0.7071 - 0.0000i  -0.7071 + 0.0000i
-</pre>
-<pre id="hamiltonian-s">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9986 + 0.0523i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9945 + 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9877 + 0.1564i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9781 + 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9659 + 0.2588i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9511 + 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9336 + 0.3584i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9135 + 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8910 + 0.4540i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8660 + 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8387 + 0.5446i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8090 + 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7771 + 0.6293i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7431 + 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7071 + 0.7071i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.6691 + 0.7431i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.6293 + 0.7771i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5878 + 0.8090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5446 + 0.8387i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5000 + 0.8660i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.4540 + 0.8910i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.4067 + 0.9135i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.3584 + 0.9336i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.3090 + 0.9511i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.2588 + 0.9659i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.2079 + 0.9781i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.1564 + 0.9877i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.1045 + 0.9945i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.0523 + 0.9986i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.0000 + 1.0000i
-</pre>
-<pre id="hamiltonian-sdg">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9986 - 0.0523i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9945 - 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9877 - 0.1564i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9781 - 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9659 - 0.2588i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9511 - 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9336 - 0.3584i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9135 - 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8910 - 0.4540i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8660 - 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8387 - 0.5446i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8090 - 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7771 - 0.6293i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7431 - 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7071 - 0.7071i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.6691 - 0.7431i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.6293 - 0.7771i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5878 - 0.8090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5446 - 0.8387i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.5000 - 0.8660i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.4540 - 0.8910i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.4067 - 0.9135i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.3584 - 0.9336i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.3090 - 0.9511i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.2588 - 0.9659i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.2079 - 0.9781i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.1564 - 0.9877i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.1045 - 0.9945i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.0523 - 0.9986i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.0000 - 1.0000i
-</pre>
-<pre id="hamiltonian-t">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9997 + 0.0262i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9986 + 0.0523i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9969 + 0.0785i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9945 + 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9914 + 0.1305i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9877 + 0.1564i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9833 + 0.1822i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9781 + 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9724 + 0.2334i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9659 + 0.2588i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9588 + 0.2840i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9511 + 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9426 + 0.3338i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9336 + 0.3584i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9239 + 0.3827i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9135 + 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9026 + 0.4305i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8910 + 0.4540i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8788 + 0.4772i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8660 + 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8526 + 0.5225i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8387 + 0.5446i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8241 + 0.5664i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8090 + 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7934 + 0.6088i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7771 + 0.6293i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7604 + 0.6494i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7431 + 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7254 + 0.6884i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7071 + 0.7071i
-</pre>
-<pre id="hamiltonian-tdg">
-       ans =
-
-Diagonal Matrix
-
-   1   0
-   0   1
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9997 - 0.0262i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9986 - 0.0523i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9969 - 0.0785i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9945 - 0.1045i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9914 - 0.1305i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9877 - 0.1564i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9833 - 0.1822i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9781 - 0.2079i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9724 - 0.2334i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9659 - 0.2588i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9588 - 0.2840i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9511 - 0.3090i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9426 - 0.3338i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9336 - 0.3584i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9239 - 0.3827i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9135 - 0.4067i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.9026 - 0.4305i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8910 - 0.4540i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8788 - 0.4772i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8660 - 0.5000i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8526 - 0.5225i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8387 - 0.5446i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8241 - 0.5664i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.8090 - 0.5878i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7934 - 0.6088i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7771 - 0.6293i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7604 - 0.6494i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7431 - 0.6691i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7254 - 0.6884i
-
-ans =
-
-Diagonal Matrix
-
-   1.0000 +      0i                  0
-                  0   0.7071 - 0.7071i
-</pre>
-</body>
-</html>
diff --git a/src/imports/chart.js b/src/imports/chart.js
deleted file mode 100644 (file)
index c0f9743..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Skipped minification because the original files appears to be already minified.
- * Original file: /npm/[email protected]/dist/chart.umd.js
- *
- * Do NOT use SRI with dynamically generated files! More information: https://www.jsdelivr.com/using-sri-with-dynamic-files
- */
-/*!
- * Chart.js v4.4.3
- * https://www.chartjs.org
- * (c) 2024 Chart.js Contributors
- * Released under the MIT License
- */
-!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).Chart=e()}(this,(function(){"use strict";var t=Object.freeze({__proto__:null,get Colors(){return Go},get Decimation(){return Qo},get Filler(){return ma},get Legend(){return ya},get SubTitle(){return ka},get Title(){return Ma},get Tooltip(){return Ba}});function e(){}const i=(()=>{let t=0;return()=>t++})();function s(t){return null==t}function n(t){if(Array.isArray&&Array.isArray(t))return!0;const e=Object.prototype.toString.call(t);return"[object"===e.slice(0,7)&&"Array]"===e.slice(-6)}function o(t){return null!==t&&"[object Object]"===Object.prototype.toString.call(t)}function a(t){return("number"==typeof t||t instanceof Number)&&isFinite(+t)}function r(t,e){return a(t)?t:e}function l(t,e){return void 0===t?e:t}const h=(t,e)=>"string"==typeof t&&t.endsWith("%")?parseFloat(t)/100:+t/e,c=(t,e)=>"string"==typeof t&&t.endsWith("%")?parseFloat(t)/100*e:+t;function d(t,e,i){if(t&&"function"==typeof t.call)return t.apply(i,e)}function u(t,e,i,s){let a,r,l;if(n(t))if(r=t.length,s)for(a=r-1;a>=0;a--)e.call(i,t[a],a);else for(a=0;a<r;a++)e.call(i,t[a],a);else if(o(t))for(l=Object.keys(t),r=l.length,a=0;a<r;a++)e.call(i,t[l[a]],l[a])}function f(t,e){let i,s,n,o;if(!t||!e||t.length!==e.length)return!1;for(i=0,s=t.length;i<s;++i)if(n=t[i],o=e[i],n.datasetIndex!==o.datasetIndex||n.index!==o.index)return!1;return!0}function g(t){if(n(t))return t.map(g);if(o(t)){const e=Object.create(null),i=Object.keys(t),s=i.length;let n=0;for(;n<s;++n)e[i[n]]=g(t[i[n]]);return e}return t}function p(t){return-1===["__proto__","prototype","constructor"].indexOf(t)}function m(t,e,i,s){if(!p(t))return;const n=e[t],a=i[t];o(n)&&o(a)?x(n,a,s):e[t]=g(a)}function x(t,e,i){const s=n(e)?e:[e],a=s.length;if(!o(t))return t;const r=(i=i||{}).merger||m;let l;for(let e=0;e<a;++e){if(l=s[e],!o(l))continue;const n=Object.keys(l);for(let e=0,s=n.length;e<s;++e)r(n[e],t,l,i)}return t}function b(t,e){return x(t,e,{merger:_})}function _(t,e,i){if(!p(t))return;const s=e[t],n=i[t];o(s)&&o(n)?b(s,n):Object.prototype.hasOwnProperty.call(e,t)||(e[t]=g(n))}const y={"":t=>t,x:t=>t.x,y:t=>t.y};function v(t){const e=t.split("."),i=[];let s="";for(const t of e)s+=t,s.endsWith("\\")?s=s.slice(0,-1)+".":(i.push(s),s="");return i}function M(t,e){const i=y[e]||(y[e]=function(t){const e=v(t);return t=>{for(const i of e){if(""===i)break;t=t&&t[i]}return t}}(e));return i(t)}function w(t){return t.charAt(0).toUpperCase()+t.slice(1)}const k=t=>void 0!==t,S=t=>"function"==typeof t,P=(t,e)=>{if(t.size!==e.size)return!1;for(const i of t)if(!e.has(i))return!1;return!0};function D(t){return"mouseup"===t.type||"click"===t.type||"contextmenu"===t.type}const C=Math.PI,O=2*C,A=O+C,T=Number.POSITIVE_INFINITY,L=C/180,E=C/2,R=C/4,I=2*C/3,z=Math.log10,F=Math.sign;function V(t,e,i){return Math.abs(t-e)<i}function B(t){const e=Math.round(t);t=V(t,e,t/1e3)?e:t;const i=Math.pow(10,Math.floor(z(t))),s=t/i;return(s<=1?1:s<=2?2:s<=5?5:10)*i}function W(t){const e=[],i=Math.sqrt(t);let s;for(s=1;s<i;s++)t%s==0&&(e.push(s),e.push(t/s));return i===(0|i)&&e.push(i),e.sort(((t,e)=>t-e)).pop(),e}function N(t){return!isNaN(parseFloat(t))&&isFinite(t)}function H(t,e){const i=Math.round(t);return i-e<=t&&i+e>=t}function j(t,e,i){let s,n,o;for(s=0,n=t.length;s<n;s++)o=t[s][i],isNaN(o)||(e.min=Math.min(e.min,o),e.max=Math.max(e.max,o))}function $(t){return t*(C/180)}function Y(t){return t*(180/C)}function U(t){if(!a(t))return;let e=1,i=0;for(;Math.round(t*e)/e!==t;)e*=10,i++;return i}function X(t,e){const i=e.x-t.x,s=e.y-t.y,n=Math.sqrt(i*i+s*s);let o=Math.atan2(s,i);return o<-.5*C&&(o+=O),{angle:o,distance:n}}function q(t,e){return Math.sqrt(Math.pow(e.x-t.x,2)+Math.pow(e.y-t.y,2))}function K(t,e){return(t-e+A)%O-C}function G(t){return(t%O+O)%O}function Z(t,e,i,s){const n=G(t),o=G(e),a=G(i),r=G(o-n),l=G(a-n),h=G(n-o),c=G(n-a);return n===o||n===a||s&&o===a||r>l&&h<c}function J(t,e,i){return Math.max(e,Math.min(i,t))}function Q(t){return J(t,-32768,32767)}function tt(t,e,i,s=1e-6){return t>=Math.min(e,i)-s&&t<=Math.max(e,i)+s}function et(t,e,i){i=i||(i=>t[i]<e);let s,n=t.length-1,o=0;for(;n-o>1;)s=o+n>>1,i(s)?o=s:n=s;return{lo:o,hi:n}}const it=(t,e,i,s)=>et(t,i,s?s=>{const n=t[s][e];return n<i||n===i&&t[s+1][e]===i}:s=>t[s][e]<i),st=(t,e,i)=>et(t,i,(s=>t[s][e]>=i));function nt(t,e,i){let s=0,n=t.length;for(;s<n&&t[s]<e;)s++;for(;n>s&&t[n-1]>i;)n--;return s>0||n<t.length?t.slice(s,n):t}const ot=["push","pop","shift","splice","unshift"];function at(t,e){t._chartjs?t._chartjs.listeners.push(e):(Object.defineProperty(t,"_chartjs",{configurable:!0,enumerable:!1,value:{listeners:[e]}}),ot.forEach((e=>{const i="_onData"+w(e),s=t[e];Object.defineProperty(t,e,{configurable:!0,enumerable:!1,value(...e){const n=s.apply(this,e);return t._chartjs.listeners.forEach((t=>{"function"==typeof t[i]&&t[i](...e)})),n}})})))}function rt(t,e){const i=t._chartjs;if(!i)return;const s=i.listeners,n=s.indexOf(e);-1!==n&&s.splice(n,1),s.length>0||(ot.forEach((e=>{delete t[e]})),delete t._chartjs)}function lt(t){const e=new Set(t);return e.size===t.length?t:Array.from(e)}const ht="undefined"==typeof window?function(t){return t()}:window.requestAnimationFrame;function ct(t,e){let i=[],s=!1;return function(...n){i=n,s||(s=!0,ht.call(window,(()=>{s=!1,t.apply(e,i)})))}}function dt(t,e){let i;return function(...s){return e?(clearTimeout(i),i=setTimeout(t,e,s)):t.apply(this,s),e}}const ut=t=>"start"===t?"left":"end"===t?"right":"center",ft=(t,e,i)=>"start"===t?e:"end"===t?i:(e+i)/2,gt=(t,e,i,s)=>t===(s?"left":"right")?i:"center"===t?(e+i)/2:e;function pt(t,e,i){const s=e.length;let n=0,o=s;if(t._sorted){const{iScale:a,_parsed:r}=t,l=a.axis,{min:h,max:c,minDefined:d,maxDefined:u}=a.getUserBounds();d&&(n=J(Math.min(it(r,l,h).lo,i?s:it(e,l,a.getPixelForValue(h)).lo),0,s-1)),o=u?J(Math.max(it(r,a.axis,c,!0).hi+1,i?0:it(e,l,a.getPixelForValue(c),!0).hi+1),n,s)-n:s-n}return{start:n,count:o}}function mt(t){const{xScale:e,yScale:i,_scaleRanges:s}=t,n={xmin:e.min,xmax:e.max,ymin:i.min,ymax:i.max};if(!s)return t._scaleRanges=n,!0;const o=s.xmin!==e.min||s.xmax!==e.max||s.ymin!==i.min||s.ymax!==i.max;return Object.assign(s,n),o}class xt{constructor(){this._request=null,this._charts=new Map,this._running=!1,this._lastDate=void 0}_notify(t,e,i,s){const n=e.listeners[s],o=e.duration;n.forEach((s=>s({chart:t,initial:e.initial,numSteps:o,currentStep:Math.min(i-e.start,o)})))}_refresh(){this._request||(this._running=!0,this._request=ht.call(window,(()=>{this._update(),this._request=null,this._running&&this._refresh()})))}_update(t=Date.now()){let e=0;this._charts.forEach(((i,s)=>{if(!i.running||!i.items.length)return;const n=i.items;let o,a=n.length-1,r=!1;for(;a>=0;--a)o=n[a],o._active?(o._total>i.duration&&(i.duration=o._total),o.tick(t),r=!0):(n[a]=n[n.length-1],n.pop());r&&(s.draw(),this._notify(s,i,t,"progress")),n.length||(i.running=!1,this._notify(s,i,t,"complete"),i.initial=!1),e+=n.length})),this._lastDate=t,0===e&&(this._running=!1)}_getAnims(t){const e=this._charts;let i=e.get(t);return i||(i={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(t,i)),i}listen(t,e,i){this._getAnims(t).listeners[e].push(i)}add(t,e){e&&e.length&&this._getAnims(t).items.push(...e)}has(t){return this._getAnims(t).items.length>0}start(t){const e=this._charts.get(t);e&&(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce(((t,e)=>Math.max(t,e._duration)),0),this._refresh())}running(t){if(!this._running)return!1;const e=this._charts.get(t);return!!(e&&e.running&&e.items.length)}stop(t){const e=this._charts.get(t);if(!e||!e.items.length)return;const i=e.items;let s=i.length-1;for(;s>=0;--s)i[s].cancel();e.items=[],this._notify(t,e,Date.now(),"complete")}remove(t){return this._charts.delete(t)}}var bt=new xt;
-/*!
- * @kurkle/color v0.3.2
- * https://github.com/kurkle/color#readme
- * (c) 2023 Jukka Kurkela
- * Released under the MIT License
- */function _t(t){return t+.5|0}const yt=(t,e,i)=>Math.max(Math.min(t,i),e);function vt(t){return yt(_t(2.55*t),0,255)}function Mt(t){return yt(_t(255*t),0,255)}function wt(t){return yt(_t(t/2.55)/100,0,1)}function kt(t){return yt(_t(100*t),0,100)}const St={0:0,1:1,2:2,3:3,4:4,5:5,6:6,7:7,8:8,9:9,A:10,B:11,C:12,D:13,E:14,F:15,a:10,b:11,c:12,d:13,e:14,f:15},Pt=[..."0123456789ABCDEF"],Dt=t=>Pt[15&t],Ct=t=>Pt[(240&t)>>4]+Pt[15&t],Ot=t=>(240&t)>>4==(15&t);function At(t){var e=(t=>Ot(t.r)&&Ot(t.g)&&Ot(t.b)&&Ot(t.a))(t)?Dt:Ct;return t?"#"+e(t.r)+e(t.g)+e(t.b)+((t,e)=>t<255?e(t):"")(t.a,e):void 0}const Tt=/^(hsla?|hwb|hsv)\(\s*([-+.e\d]+)(?:deg)?[\s,]+([-+.e\d]+)%[\s,]+([-+.e\d]+)%(?:[\s,]+([-+.e\d]+)(%)?)?\s*\)$/;function Lt(t,e,i){const s=e*Math.min(i,1-i),n=(e,n=(e+t/30)%12)=>i-s*Math.max(Math.min(n-3,9-n,1),-1);return[n(0),n(8),n(4)]}function Et(t,e,i){const s=(s,n=(s+t/60)%6)=>i-i*e*Math.max(Math.min(n,4-n,1),0);return[s(5),s(3),s(1)]}function Rt(t,e,i){const s=Lt(t,1,.5);let n;for(e+i>1&&(n=1/(e+i),e*=n,i*=n),n=0;n<3;n++)s[n]*=1-e-i,s[n]+=e;return s}function It(t){const e=t.r/255,i=t.g/255,s=t.b/255,n=Math.max(e,i,s),o=Math.min(e,i,s),a=(n+o)/2;let r,l,h;return n!==o&&(h=n-o,l=a>.5?h/(2-n-o):h/(n+o),r=function(t,e,i,s,n){return t===n?(e-i)/s+(e<i?6:0):e===n?(i-t)/s+2:(t-e)/s+4}(e,i,s,h,n),r=60*r+.5),[0|r,l||0,a]}function zt(t,e,i,s){return(Array.isArray(e)?t(e[0],e[1],e[2]):t(e,i,s)).map(Mt)}function Ft(t,e,i){return zt(Lt,t,e,i)}function Vt(t){return(t%360+360)%360}function Bt(t){const e=Tt.exec(t);let i,s=255;if(!e)return;e[5]!==i&&(s=e[6]?vt(+e[5]):Mt(+e[5]));const n=Vt(+e[2]),o=+e[3]/100,a=+e[4]/100;return i="hwb"===e[1]?function(t,e,i){return zt(Rt,t,e,i)}(n,o,a):"hsv"===e[1]?function(t,e,i){return zt(Et,t,e,i)}(n,o,a):Ft(n,o,a),{r:i[0],g:i[1],b:i[2],a:s}}const Wt={x:"dark",Z:"light",Y:"re",X:"blu",W:"gr",V:"medium",U:"slate",A:"ee",T:"ol",S:"or",B:"ra",C:"lateg",D:"ights",R:"in",Q:"turquois",E:"hi",P:"ro",O:"al",N:"le",M:"de",L:"yello",F:"en",K:"ch",G:"arks",H:"ea",I:"ightg",J:"wh"},Nt={OiceXe:"f0f8ff",antiquewEte:"faebd7",aqua:"ffff",aquamarRe:"7fffd4",azuY:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"0",blanKedOmond:"ffebcd",Xe:"ff",XeviTet:"8a2be2",bPwn:"a52a2a",burlywood:"deb887",caMtXe:"5f9ea0",KartYuse:"7fff00",KocTate:"d2691e",cSO:"ff7f50",cSnflowerXe:"6495ed",cSnsilk:"fff8dc",crimson:"dc143c",cyan:"ffff",xXe:"8b",xcyan:"8b8b",xgTMnPd:"b8860b",xWay:"a9a9a9",xgYF:"6400",xgYy:"a9a9a9",xkhaki:"bdb76b",xmagFta:"8b008b",xTivegYF:"556b2f",xSange:"ff8c00",xScEd:"9932cc",xYd:"8b0000",xsOmon:"e9967a",xsHgYF:"8fbc8f",xUXe:"483d8b",xUWay:"2f4f4f",xUgYy:"2f4f4f",xQe:"ced1",xviTet:"9400d3",dAppRk:"ff1493",dApskyXe:"bfff",dimWay:"696969",dimgYy:"696969",dodgerXe:"1e90ff",fiYbrick:"b22222",flSOwEte:"fffaf0",foYstWAn:"228b22",fuKsia:"ff00ff",gaRsbSo:"dcdcdc",ghostwEte:"f8f8ff",gTd:"ffd700",gTMnPd:"daa520",Way:"808080",gYF:"8000",gYFLw:"adff2f",gYy:"808080",honeyMw:"f0fff0",hotpRk:"ff69b4",RdianYd:"cd5c5c",Rdigo:"4b0082",ivSy:"fffff0",khaki:"f0e68c",lavFMr:"e6e6fa",lavFMrXsh:"fff0f5",lawngYF:"7cfc00",NmoncEffon:"fffacd",ZXe:"add8e6",ZcSO:"f08080",Zcyan:"e0ffff",ZgTMnPdLw:"fafad2",ZWay:"d3d3d3",ZgYF:"90ee90",ZgYy:"d3d3d3",ZpRk:"ffb6c1",ZsOmon:"ffa07a",ZsHgYF:"20b2aa",ZskyXe:"87cefa",ZUWay:"778899",ZUgYy:"778899",ZstAlXe:"b0c4de",ZLw:"ffffe0",lime:"ff00",limegYF:"32cd32",lRF:"faf0e6",magFta:"ff00ff",maPon:"800000",VaquamarRe:"66cdaa",VXe:"cd",VScEd:"ba55d3",VpurpN:"9370db",VsHgYF:"3cb371",VUXe:"7b68ee",VsprRggYF:"fa9a",VQe:"48d1cc",VviTetYd:"c71585",midnightXe:"191970",mRtcYam:"f5fffa",mistyPse:"ffe4e1",moccasR:"ffe4b5",navajowEte:"ffdead",navy:"80",Tdlace:"fdf5e6",Tive:"808000",TivedBb:"6b8e23",Sange:"ffa500",SangeYd:"ff4500",ScEd:"da70d6",pOegTMnPd:"eee8aa",pOegYF:"98fb98",pOeQe:"afeeee",pOeviTetYd:"db7093",papayawEp:"ffefd5",pHKpuff:"ffdab9",peru:"cd853f",pRk:"ffc0cb",plum:"dda0dd",powMrXe:"b0e0e6",purpN:"800080",YbeccapurpN:"663399",Yd:"ff0000",Psybrown:"bc8f8f",PyOXe:"4169e1",saddNbPwn:"8b4513",sOmon:"fa8072",sandybPwn:"f4a460",sHgYF:"2e8b57",sHshell:"fff5ee",siFna:"a0522d",silver:"c0c0c0",skyXe:"87ceeb",UXe:"6a5acd",UWay:"708090",UgYy:"708090",snow:"fffafa",sprRggYF:"ff7f",stAlXe:"4682b4",tan:"d2b48c",teO:"8080",tEstN:"d8bfd8",tomato:"ff6347",Qe:"40e0d0",viTet:"ee82ee",JHt:"f5deb3",wEte:"ffffff",wEtesmoke:"f5f5f5",Lw:"ffff00",LwgYF:"9acd32"};let Ht;function jt(t){Ht||(Ht=function(){const t={},e=Object.keys(Nt),i=Object.keys(Wt);let s,n,o,a,r;for(s=0;s<e.length;s++){for(a=r=e[s],n=0;n<i.length;n++)o=i[n],r=r.replace(o,Wt[o]);o=parseInt(Nt[a],16),t[r]=[o>>16&255,o>>8&255,255&o]}return t}(),Ht.transparent=[0,0,0,0]);const e=Ht[t.toLowerCase()];return e&&{r:e[0],g:e[1],b:e[2],a:4===e.length?e[3]:255}}const $t=/^rgba?\(\s*([-+.\d]+)(%)?[\s,]+([-+.e\d]+)(%)?[\s,]+([-+.e\d]+)(%)?(?:[\s,/]+([-+.e\d]+)(%)?)?\s*\)$/;const Yt=t=>t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055,Ut=t=>t<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4);function Xt(t,e,i){if(t){let s=It(t);s[e]=Math.max(0,Math.min(s[e]+s[e]*i,0===e?360:1)),s=Ft(s),t.r=s[0],t.g=s[1],t.b=s[2]}}function qt(t,e){return t?Object.assign(e||{},t):t}function Kt(t){var e={r:0,g:0,b:0,a:255};return Array.isArray(t)?t.length>=3&&(e={r:t[0],g:t[1],b:t[2],a:255},t.length>3&&(e.a=Mt(t[3]))):(e=qt(t,{r:0,g:0,b:0,a:1})).a=Mt(e.a),e}function Gt(t){return"r"===t.charAt(0)?function(t){const e=$t.exec(t);let i,s,n,o=255;if(e){if(e[7]!==i){const t=+e[7];o=e[8]?vt(t):yt(255*t,0,255)}return i=+e[1],s=+e[3],n=+e[5],i=255&(e[2]?vt(i):yt(i,0,255)),s=255&(e[4]?vt(s):yt(s,0,255)),n=255&(e[6]?vt(n):yt(n,0,255)),{r:i,g:s,b:n,a:o}}}(t):Bt(t)}class Zt{constructor(t){if(t instanceof Zt)return t;const e=typeof t;let i;var s,n,o;"object"===e?i=Kt(t):"string"===e&&(o=(s=t).length,"#"===s[0]&&(4===o||5===o?n={r:255&17*St[s[1]],g:255&17*St[s[2]],b:255&17*St[s[3]],a:5===o?17*St[s[4]]:255}:7!==o&&9!==o||(n={r:St[s[1]]<<4|St[s[2]],g:St[s[3]]<<4|St[s[4]],b:St[s[5]]<<4|St[s[6]],a:9===o?St[s[7]]<<4|St[s[8]]:255})),i=n||jt(t)||Gt(t)),this._rgb=i,this._valid=!!i}get valid(){return this._valid}get rgb(){var t=qt(this._rgb);return t&&(t.a=wt(t.a)),t}set rgb(t){this._rgb=Kt(t)}rgbString(){return this._valid?(t=this._rgb)&&(t.a<255?`rgba(${t.r}, ${t.g}, ${t.b}, ${wt(t.a)})`:`rgb(${t.r}, ${t.g}, ${t.b})`):void 0;var t}hexString(){return this._valid?At(this._rgb):void 0}hslString(){return this._valid?function(t){if(!t)return;const e=It(t),i=e[0],s=kt(e[1]),n=kt(e[2]);return t.a<255?`hsla(${i}, ${s}%, ${n}%, ${wt(t.a)})`:`hsl(${i}, ${s}%, ${n}%)`}(this._rgb):void 0}mix(t,e){if(t){const i=this.rgb,s=t.rgb;let n;const o=e===n?.5:e,a=2*o-1,r=i.a-s.a,l=((a*r==-1?a:(a+r)/(1+a*r))+1)/2;n=1-l,i.r=255&l*i.r+n*s.r+.5,i.g=255&l*i.g+n*s.g+.5,i.b=255&l*i.b+n*s.b+.5,i.a=o*i.a+(1-o)*s.a,this.rgb=i}return this}interpolate(t,e){return t&&(this._rgb=function(t,e,i){const s=Ut(wt(t.r)),n=Ut(wt(t.g)),o=Ut(wt(t.b));return{r:Mt(Yt(s+i*(Ut(wt(e.r))-s))),g:Mt(Yt(n+i*(Ut(wt(e.g))-n))),b:Mt(Yt(o+i*(Ut(wt(e.b))-o))),a:t.a+i*(e.a-t.a)}}(this._rgb,t._rgb,e)),this}clone(){return new Zt(this.rgb)}alpha(t){return this._rgb.a=Mt(t),this}clearer(t){return this._rgb.a*=1-t,this}greyscale(){const t=this._rgb,e=_t(.3*t.r+.59*t.g+.11*t.b);return t.r=t.g=t.b=e,this}opaquer(t){return this._rgb.a*=1+t,this}negate(){const t=this._rgb;return t.r=255-t.r,t.g=255-t.g,t.b=255-t.b,this}lighten(t){return Xt(this._rgb,2,t),this}darken(t){return Xt(this._rgb,2,-t),this}saturate(t){return Xt(this._rgb,1,t),this}desaturate(t){return Xt(this._rgb,1,-t),this}rotate(t){return function(t,e){var i=It(t);i[0]=Vt(i[0]+e),i=Ft(i),t.r=i[0],t.g=i[1],t.b=i[2]}(this._rgb,t),this}}function Jt(t){if(t&&"object"==typeof t){const e=t.toString();return"[object CanvasPattern]"===e||"[object CanvasGradient]"===e}return!1}function Qt(t){return Jt(t)?t:new Zt(t)}function te(t){return Jt(t)?t:new Zt(t).saturate(.5).darken(.1).hexString()}const ee=["x","y","borderWidth","radius","tension"],ie=["color","borderColor","backgroundColor"];const se=new Map;function ne(t,e,i){return function(t,e){e=e||{};const i=t+JSON.stringify(e);let s=se.get(i);return s||(s=new Intl.NumberFormat(t,e),se.set(i,s)),s}(e,i).format(t)}const oe={values:t=>n(t)?t:""+t,numeric(t,e,i){if(0===t)return"0";const s=this.chart.options.locale;let n,o=t;if(i.length>1){const e=Math.max(Math.abs(i[0].value),Math.abs(i[i.length-1].value));(e<1e-4||e>1e15)&&(n="scientific"),o=function(t,e){let i=e.length>3?e[2].value-e[1].value:e[1].value-e[0].value;Math.abs(i)>=1&&t!==Math.floor(t)&&(i=t-Math.floor(t));return i}(t,i)}const a=z(Math.abs(o)),r=isNaN(a)?1:Math.max(Math.min(-1*Math.floor(a),20),0),l={notation:n,minimumFractionDigits:r,maximumFractionDigits:r};return Object.assign(l,this.options.ticks.format),ne(t,s,l)},logarithmic(t,e,i){if(0===t)return"0";const s=i[e].significand||t/Math.pow(10,Math.floor(z(t)));return[1,2,3,5,10,15].includes(s)||e>.8*i.length?oe.numeric.call(this,t,e,i):""}};var ae={formatters:oe};const re=Object.create(null),le=Object.create(null);function he(t,e){if(!e)return t;const i=e.split(".");for(let e=0,s=i.length;e<s;++e){const s=i[e];t=t[s]||(t[s]=Object.create(null))}return t}function ce(t,e,i){return"string"==typeof e?x(he(t,e),i):x(he(t,""),e)}class de{constructor(t,e){this.animation=void 0,this.backgroundColor="rgba(0,0,0,0.1)",this.borderColor="rgba(0,0,0,0.1)",this.color="#666",this.datasets={},this.devicePixelRatio=t=>t.chart.platform.getDevicePixelRatio(),this.elements={},this.events=["mousemove","mouseout","click","touchstart","touchmove"],this.font={family:"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif",size:12,style:"normal",lineHeight:1.2,weight:null},this.hover={},this.hoverBackgroundColor=(t,e)=>te(e.backgroundColor),this.hoverBorderColor=(t,e)=>te(e.borderColor),this.hoverColor=(t,e)=>te(e.color),this.indexAxis="x",this.interaction={mode:"nearest",intersect:!0,includeInvisible:!1},this.maintainAspectRatio=!0,this.onHover=null,this.onClick=null,this.parsing=!0,this.plugins={},this.responsive=!0,this.scale=void 0,this.scales={},this.showLine=!0,this.drawActiveElementsOnTop=!0,this.describe(t),this.apply(e)}set(t,e){return ce(this,t,e)}get(t){return he(this,t)}describe(t,e){return ce(le,t,e)}override(t,e){return ce(re,t,e)}route(t,e,i,s){const n=he(this,t),a=he(this,i),r="_"+e;Object.defineProperties(n,{[r]:{value:n[e],writable:!0},[e]:{enumerable:!0,get(){const t=this[r],e=a[s];return o(t)?Object.assign({},e,t):l(t,e)},set(t){this[r]=t}}})}apply(t){t.forEach((t=>t(this)))}}var ue=new de({_scriptable:t=>!t.startsWith("on"),_indexable:t=>"events"!==t,hover:{_fallback:"interaction"},interaction:{_scriptable:!1,_indexable:!1}},[function(t){t.set("animation",{delay:void 0,duration:1e3,easing:"easeOutQuart",fn:void 0,from:void 0,loop:void 0,to:void 0,type:void 0}),t.describe("animation",{_fallback:!1,_indexable:!1,_scriptable:t=>"onProgress"!==t&&"onComplete"!==t&&"fn"!==t}),t.set("animations",{colors:{type:"color",properties:ie},numbers:{type:"number",properties:ee}}),t.describe("animations",{_fallback:"animation"}),t.set("transitions",{active:{animation:{duration:400}},resize:{animation:{duration:0}},show:{animations:{colors:{from:"transparent"},visible:{type:"boolean",duration:0}}},hide:{animations:{colors:{to:"transparent"},visible:{type:"boolean",easing:"linear",fn:t=>0|t}}}})},function(t){t.set("layout",{autoPadding:!0,padding:{top:0,right:0,bottom:0,left:0}})},function(t){t.set("scale",{display:!0,offset:!1,reverse:!1,beginAtZero:!1,bounds:"ticks",clip:!0,grace:0,grid:{display:!0,lineWidth:1,drawOnChartArea:!0,drawTicks:!0,tickLength:8,tickWidth:(t,e)=>e.lineWidth,tickColor:(t,e)=>e.color,offset:!1},border:{display:!0,dash:[],dashOffset:0,width:1},title:{display:!1,text:"",padding:{top:4,bottom:4}},ticks:{minRotation:0,maxRotation:50,mirror:!1,textStrokeWidth:0,textStrokeColor:"",padding:3,display:!0,autoSkip:!0,autoSkipPadding:3,labelOffset:0,callback:ae.formatters.values,minor:{},major:{},align:"center",crossAlign:"near",showLabelBackdrop:!1,backdropColor:"rgba(255, 255, 255, 0.75)",backdropPadding:2}}),t.route("scale.ticks","color","","color"),t.route("scale.grid","color","","borderColor"),t.route("scale.border","color","","borderColor"),t.route("scale.title","color","","color"),t.describe("scale",{_fallback:!1,_scriptable:t=>!t.startsWith("before")&&!t.startsWith("after")&&"callback"!==t&&"parser"!==t,_indexable:t=>"borderDash"!==t&&"tickBorderDash"!==t&&"dash"!==t}),t.describe("scales",{_fallback:"scale"}),t.describe("scale.ticks",{_scriptable:t=>"backdropPadding"!==t&&"callback"!==t,_indexable:t=>"backdropPadding"!==t})}]);function fe(){return"undefined"!=typeof window&&"undefined"!=typeof document}function ge(t){let e=t.parentNode;return e&&"[object ShadowRoot]"===e.toString()&&(e=e.host),e}function pe(t,e,i){let s;return"string"==typeof t?(s=parseInt(t,10),-1!==t.indexOf("%")&&(s=s/100*e.parentNode[i])):s=t,s}const me=t=>t.ownerDocument.defaultView.getComputedStyle(t,null);function xe(t,e){return me(t).getPropertyValue(e)}const be=["top","right","bottom","left"];function _e(t,e,i){const s={};i=i?"-"+i:"";for(let n=0;n<4;n++){const o=be[n];s[o]=parseFloat(t[e+"-"+o+i])||0}return s.width=s.left+s.right,s.height=s.top+s.bottom,s}const ye=(t,e,i)=>(t>0||e>0)&&(!i||!i.shadowRoot);function ve(t,e){if("native"in t)return t;const{canvas:i,currentDevicePixelRatio:s}=e,n=me(i),o="border-box"===n.boxSizing,a=_e(n,"padding"),r=_e(n,"border","width"),{x:l,y:h,box:c}=function(t,e){const i=t.touches,s=i&&i.length?i[0]:t,{offsetX:n,offsetY:o}=s;let a,r,l=!1;if(ye(n,o,t.target))a=n,r=o;else{const t=e.getBoundingClientRect();a=s.clientX-t.left,r=s.clientY-t.top,l=!0}return{x:a,y:r,box:l}}(t,i),d=a.left+(c&&r.left),u=a.top+(c&&r.top);let{width:f,height:g}=e;return o&&(f-=a.width+r.width,g-=a.height+r.height),{x:Math.round((l-d)/f*i.width/s),y:Math.round((h-u)/g*i.height/s)}}const Me=t=>Math.round(10*t)/10;function we(t,e,i,s){const n=me(t),o=_e(n,"margin"),a=pe(n.maxWidth,t,"clientWidth")||T,r=pe(n.maxHeight,t,"clientHeight")||T,l=function(t,e,i){let s,n;if(void 0===e||void 0===i){const o=t&&ge(t);if(o){const t=o.getBoundingClientRect(),a=me(o),r=_e(a,"border","width"),l=_e(a,"padding");e=t.width-l.width-r.width,i=t.height-l.height-r.height,s=pe(a.maxWidth,o,"clientWidth"),n=pe(a.maxHeight,o,"clientHeight")}else e=t.clientWidth,i=t.clientHeight}return{width:e,height:i,maxWidth:s||T,maxHeight:n||T}}(t,e,i);let{width:h,height:c}=l;if("content-box"===n.boxSizing){const t=_e(n,"border","width"),e=_e(n,"padding");h-=e.width+t.width,c-=e.height+t.height}h=Math.max(0,h-o.width),c=Math.max(0,s?h/s:c-o.height),h=Me(Math.min(h,a,l.maxWidth)),c=Me(Math.min(c,r,l.maxHeight)),h&&!c&&(c=Me(h/2));return(void 0!==e||void 0!==i)&&s&&l.height&&c>l.height&&(c=l.height,h=Me(Math.floor(c*s))),{width:h,height:c}}function ke(t,e,i){const s=e||1,n=Math.floor(t.height*s),o=Math.floor(t.width*s);t.height=Math.floor(t.height),t.width=Math.floor(t.width);const a=t.canvas;return a.style&&(i||!a.style.height&&!a.style.width)&&(a.style.height=`${t.height}px`,a.style.width=`${t.width}px`),(t.currentDevicePixelRatio!==s||a.height!==n||a.width!==o)&&(t.currentDevicePixelRatio=s,a.height=n,a.width=o,t.ctx.setTransform(s,0,0,s,0,0),!0)}const Se=function(){let t=!1;try{const e={get passive(){return t=!0,!1}};fe()&&(window.addEventListener("test",null,e),window.removeEventListener("test",null,e))}catch(t){}return t}();function Pe(t,e){const i=xe(t,e),s=i&&i.match(/^(\d+)(\.\d+)?px$/);return s?+s[1]:void 0}function De(t){return!t||s(t.size)||s(t.family)?null:(t.style?t.style+" ":"")+(t.weight?t.weight+" ":"")+t.size+"px "+t.family}function Ce(t,e,i,s,n){let o=e[n];return o||(o=e[n]=t.measureText(n).width,i.push(n)),o>s&&(s=o),s}function Oe(t,e,i,s){let o=(s=s||{}).data=s.data||{},a=s.garbageCollect=s.garbageCollect||[];s.font!==e&&(o=s.data={},a=s.garbageCollect=[],s.font=e),t.save(),t.font=e;let r=0;const l=i.length;let h,c,d,u,f;for(h=0;h<l;h++)if(u=i[h],null==u||n(u)){if(n(u))for(c=0,d=u.length;c<d;c++)f=u[c],null==f||n(f)||(r=Ce(t,o,a,r,f))}else r=Ce(t,o,a,r,u);t.restore();const g=a.length/2;if(g>i.length){for(h=0;h<g;h++)delete o[a[h]];a.splice(0,g)}return r}function Ae(t,e,i){const s=t.currentDevicePixelRatio,n=0!==i?Math.max(i/2,.5):0;return Math.round((e-n)*s)/s+n}function Te(t,e){(e||t)&&((e=e||t.getContext("2d")).save(),e.resetTransform(),e.clearRect(0,0,t.width,t.height),e.restore())}function Le(t,e,i,s){Ee(t,e,i,s,null)}function Ee(t,e,i,s,n){let o,a,r,l,h,c,d,u;const f=e.pointStyle,g=e.rotation,p=e.radius;let m=(g||0)*L;if(f&&"object"==typeof f&&(o=f.toString(),"[object HTMLImageElement]"===o||"[object HTMLCanvasElement]"===o))return t.save(),t.translate(i,s),t.rotate(m),t.drawImage(f,-f.width/2,-f.height/2,f.width,f.height),void t.restore();if(!(isNaN(p)||p<=0)){switch(t.beginPath(),f){default:n?t.ellipse(i,s,n/2,p,0,0,O):t.arc(i,s,p,0,O),t.closePath();break;case"triangle":c=n?n/2:p,t.moveTo(i+Math.sin(m)*c,s-Math.cos(m)*p),m+=I,t.lineTo(i+Math.sin(m)*c,s-Math.cos(m)*p),m+=I,t.lineTo(i+Math.sin(m)*c,s-Math.cos(m)*p),t.closePath();break;case"rectRounded":h=.516*p,l=p-h,a=Math.cos(m+R)*l,d=Math.cos(m+R)*(n?n/2-h:l),r=Math.sin(m+R)*l,u=Math.sin(m+R)*(n?n/2-h:l),t.arc(i-d,s-r,h,m-C,m-E),t.arc(i+u,s-a,h,m-E,m),t.arc(i+d,s+r,h,m,m+E),t.arc(i-u,s+a,h,m+E,m+C),t.closePath();break;case"rect":if(!g){l=Math.SQRT1_2*p,c=n?n/2:l,t.rect(i-c,s-l,2*c,2*l);break}m+=R;case"rectRot":d=Math.cos(m)*(n?n/2:p),a=Math.cos(m)*p,r=Math.sin(m)*p,u=Math.sin(m)*(n?n/2:p),t.moveTo(i-d,s-r),t.lineTo(i+u,s-a),t.lineTo(i+d,s+r),t.lineTo(i-u,s+a),t.closePath();break;case"crossRot":m+=R;case"cross":d=Math.cos(m)*(n?n/2:p),a=Math.cos(m)*p,r=Math.sin(m)*p,u=Math.sin(m)*(n?n/2:p),t.moveTo(i-d,s-r),t.lineTo(i+d,s+r),t.moveTo(i+u,s-a),t.lineTo(i-u,s+a);break;case"star":d=Math.cos(m)*(n?n/2:p),a=Math.cos(m)*p,r=Math.sin(m)*p,u=Math.sin(m)*(n?n/2:p),t.moveTo(i-d,s-r),t.lineTo(i+d,s+r),t.moveTo(i+u,s-a),t.lineTo(i-u,s+a),m+=R,d=Math.cos(m)*(n?n/2:p),a=Math.cos(m)*p,r=Math.sin(m)*p,u=Math.sin(m)*(n?n/2:p),t.moveTo(i-d,s-r),t.lineTo(i+d,s+r),t.moveTo(i+u,s-a),t.lineTo(i-u,s+a);break;case"line":a=n?n/2:Math.cos(m)*p,r=Math.sin(m)*p,t.moveTo(i-a,s-r),t.lineTo(i+a,s+r);break;case"dash":t.moveTo(i,s),t.lineTo(i+Math.cos(m)*(n?n/2:p),s+Math.sin(m)*p);break;case!1:t.closePath()}t.fill(),e.borderWidth>0&&t.stroke()}}function Re(t,e,i){return i=i||.5,!e||t&&t.x>e.left-i&&t.x<e.right+i&&t.y>e.top-i&&t.y<e.bottom+i}function Ie(t,e){t.save(),t.beginPath(),t.rect(e.left,e.top,e.right-e.left,e.bottom-e.top),t.clip()}function ze(t){t.restore()}function Fe(t,e,i,s,n){if(!e)return t.lineTo(i.x,i.y);if("middle"===n){const s=(e.x+i.x)/2;t.lineTo(s,e.y),t.lineTo(s,i.y)}else"after"===n!=!!s?t.lineTo(e.x,i.y):t.lineTo(i.x,e.y);t.lineTo(i.x,i.y)}function Ve(t,e,i,s){if(!e)return t.lineTo(i.x,i.y);t.bezierCurveTo(s?e.cp1x:e.cp2x,s?e.cp1y:e.cp2y,s?i.cp2x:i.cp1x,s?i.cp2y:i.cp1y,i.x,i.y)}function Be(t,e,i,s,n){if(n.strikethrough||n.underline){const o=t.measureText(s),a=e-o.actualBoundingBoxLeft,r=e+o.actualBoundingBoxRight,l=i-o.actualBoundingBoxAscent,h=i+o.actualBoundingBoxDescent,c=n.strikethrough?(l+h)/2:h;t.strokeStyle=t.fillStyle,t.beginPath(),t.lineWidth=n.decorationWidth||2,t.moveTo(a,c),t.lineTo(r,c),t.stroke()}}function We(t,e){const i=t.fillStyle;t.fillStyle=e.color,t.fillRect(e.left,e.top,e.width,e.height),t.fillStyle=i}function Ne(t,e,i,o,a,r={}){const l=n(e)?e:[e],h=r.strokeWidth>0&&""!==r.strokeColor;let c,d;for(t.save(),t.font=a.string,function(t,e){e.translation&&t.translate(e.translation[0],e.translation[1]),s(e.rotation)||t.rotate(e.rotation),e.color&&(t.fillStyle=e.color),e.textAlign&&(t.textAlign=e.textAlign),e.textBaseline&&(t.textBaseline=e.textBaseline)}(t,r),c=0;c<l.length;++c)d=l[c],r.backdrop&&We(t,r.backdrop),h&&(r.strokeColor&&(t.strokeStyle=r.strokeColor),s(r.strokeWidth)||(t.lineWidth=r.strokeWidth),t.strokeText(d,i,o,r.maxWidth)),t.fillText(d,i,o,r.maxWidth),Be(t,i,o,d,r),o+=Number(a.lineHeight);t.restore()}function He(t,e){const{x:i,y:s,w:n,h:o,radius:a}=e;t.arc(i+a.topLeft,s+a.topLeft,a.topLeft,1.5*C,C,!0),t.lineTo(i,s+o-a.bottomLeft),t.arc(i+a.bottomLeft,s+o-a.bottomLeft,a.bottomLeft,C,E,!0),t.lineTo(i+n-a.bottomRight,s+o),t.arc(i+n-a.bottomRight,s+o-a.bottomRight,a.bottomRight,E,0,!0),t.lineTo(i+n,s+a.topRight),t.arc(i+n-a.topRight,s+a.topRight,a.topRight,0,-E,!0),t.lineTo(i+a.topLeft,s)}function je(t,e=[""],i,s,n=(()=>t[0])){const o=i||t;void 0===s&&(s=ti("_fallback",t));const a={[Symbol.toStringTag]:"Object",_cacheable:!0,_scopes:t,_rootScopes:o,_fallback:s,_getTarget:n,override:i=>je([i,...t],e,o,s)};return new Proxy(a,{deleteProperty:(e,i)=>(delete e[i],delete e._keys,delete t[0][i],!0),get:(i,s)=>qe(i,s,(()=>function(t,e,i,s){let n;for(const o of e)if(n=ti(Ue(o,t),i),void 0!==n)return Xe(t,n)?Je(i,s,t,n):n}(s,e,t,i))),getOwnPropertyDescriptor:(t,e)=>Reflect.getOwnPropertyDescriptor(t._scopes[0],e),getPrototypeOf:()=>Reflect.getPrototypeOf(t[0]),has:(t,e)=>ei(t).includes(e),ownKeys:t=>ei(t),set(t,e,i){const s=t._storage||(t._storage=n());return t[e]=s[e]=i,delete t._keys,!0}})}function $e(t,e,i,s){const a={_cacheable:!1,_proxy:t,_context:e,_subProxy:i,_stack:new Set,_descriptors:Ye(t,s),setContext:e=>$e(t,e,i,s),override:n=>$e(t.override(n),e,i,s)};return new Proxy(a,{deleteProperty:(e,i)=>(delete e[i],delete t[i],!0),get:(t,e,i)=>qe(t,e,(()=>function(t,e,i){const{_proxy:s,_context:a,_subProxy:r,_descriptors:l}=t;let h=s[e];S(h)&&l.isScriptable(e)&&(h=function(t,e,i,s){const{_proxy:n,_context:o,_subProxy:a,_stack:r}=i;if(r.has(t))throw new Error("Recursion detected: "+Array.from(r).join("->")+"->"+t);r.add(t);let l=e(o,a||s);r.delete(t),Xe(t,l)&&(l=Je(n._scopes,n,t,l));return l}(e,h,t,i));n(h)&&h.length&&(h=function(t,e,i,s){const{_proxy:n,_context:a,_subProxy:r,_descriptors:l}=i;if(void 0!==a.index&&s(t))return e[a.index%e.length];if(o(e[0])){const i=e,s=n._scopes.filter((t=>t!==i));e=[];for(const o of i){const i=Je(s,n,t,o);e.push($e(i,a,r&&r[t],l))}}return e}(e,h,t,l.isIndexable));Xe(e,h)&&(h=$e(h,a,r&&r[e],l));return h}(t,e,i))),getOwnPropertyDescriptor:(e,i)=>e._descriptors.allKeys?Reflect.has(t,i)?{enumerable:!0,configurable:!0}:void 0:Reflect.getOwnPropertyDescriptor(t,i),getPrototypeOf:()=>Reflect.getPrototypeOf(t),has:(e,i)=>Reflect.has(t,i),ownKeys:()=>Reflect.ownKeys(t),set:(e,i,s)=>(t[i]=s,delete e[i],!0)})}function Ye(t,e={scriptable:!0,indexable:!0}){const{_scriptable:i=e.scriptable,_indexable:s=e.indexable,_allKeys:n=e.allKeys}=t;return{allKeys:n,scriptable:i,indexable:s,isScriptable:S(i)?i:()=>i,isIndexable:S(s)?s:()=>s}}const Ue=(t,e)=>t?t+w(e):e,Xe=(t,e)=>o(e)&&"adapters"!==t&&(null===Object.getPrototypeOf(e)||e.constructor===Object);function qe(t,e,i){if(Object.prototype.hasOwnProperty.call(t,e)||"constructor"===e)return t[e];const s=i();return t[e]=s,s}function Ke(t,e,i){return S(t)?t(e,i):t}const Ge=(t,e)=>!0===t?e:"string"==typeof t?M(e,t):void 0;function Ze(t,e,i,s,n){for(const o of e){const e=Ge(i,o);if(e){t.add(e);const o=Ke(e._fallback,i,n);if(void 0!==o&&o!==i&&o!==s)return o}else if(!1===e&&void 0!==s&&i!==s)return null}return!1}function Je(t,e,i,s){const a=e._rootScopes,r=Ke(e._fallback,i,s),l=[...t,...a],h=new Set;h.add(s);let c=Qe(h,l,i,r||i,s);return null!==c&&((void 0===r||r===i||(c=Qe(h,l,r,c,s),null!==c))&&je(Array.from(h),[""],a,r,(()=>function(t,e,i){const s=t._getTarget();e in s||(s[e]={});const a=s[e];if(n(a)&&o(i))return i;return a||{}}(e,i,s))))}function Qe(t,e,i,s,n){for(;i;)i=Ze(t,e,i,s,n);return i}function ti(t,e){for(const i of e){if(!i)continue;const e=i[t];if(void 0!==e)return e}}function ei(t){let e=t._keys;return e||(e=t._keys=function(t){const e=new Set;for(const i of t)for(const t of Object.keys(i).filter((t=>!t.startsWith("_"))))e.add(t);return Array.from(e)}(t._scopes)),e}function ii(t,e,i,s){const{iScale:n}=t,{key:o="r"}=this._parsing,a=new Array(s);let r,l,h,c;for(r=0,l=s;r<l;++r)h=r+i,c=e[h],a[r]={r:n.parse(M(c,o),h)};return a}const si=Number.EPSILON||1e-14,ni=(t,e)=>e<t.length&&!t[e].skip&&t[e],oi=t=>"x"===t?"y":"x";function ai(t,e,i,s){const n=t.skip?e:t,o=e,a=i.skip?e:i,r=q(o,n),l=q(a,o);let h=r/(r+l),c=l/(r+l);h=isNaN(h)?0:h,c=isNaN(c)?0:c;const d=s*h,u=s*c;return{previous:{x:o.x-d*(a.x-n.x),y:o.y-d*(a.y-n.y)},next:{x:o.x+u*(a.x-n.x),y:o.y+u*(a.y-n.y)}}}function ri(t,e="x"){const i=oi(e),s=t.length,n=Array(s).fill(0),o=Array(s);let a,r,l,h=ni(t,0);for(a=0;a<s;++a)if(r=l,l=h,h=ni(t,a+1),l){if(h){const t=h[e]-l[e];n[a]=0!==t?(h[i]-l[i])/t:0}o[a]=r?h?F(n[a-1])!==F(n[a])?0:(n[a-1]+n[a])/2:n[a-1]:n[a]}!function(t,e,i){const s=t.length;let n,o,a,r,l,h=ni(t,0);for(let c=0;c<s-1;++c)l=h,h=ni(t,c+1),l&&h&&(V(e[c],0,si)?i[c]=i[c+1]=0:(n=i[c]/e[c],o=i[c+1]/e[c],r=Math.pow(n,2)+Math.pow(o,2),r<=9||(a=3/Math.sqrt(r),i[c]=n*a*e[c],i[c+1]=o*a*e[c])))}(t,n,o),function(t,e,i="x"){const s=oi(i),n=t.length;let o,a,r,l=ni(t,0);for(let h=0;h<n;++h){if(a=r,r=l,l=ni(t,h+1),!r)continue;const n=r[i],c=r[s];a&&(o=(n-a[i])/3,r[`cp1${i}`]=n-o,r[`cp1${s}`]=c-o*e[h]),l&&(o=(l[i]-n)/3,r[`cp2${i}`]=n+o,r[`cp2${s}`]=c+o*e[h])}}(t,o,e)}function li(t,e,i){return Math.max(Math.min(t,i),e)}function hi(t,e,i,s,n){let o,a,r,l;if(e.spanGaps&&(t=t.filter((t=>!t.skip))),"monotone"===e.cubicInterpolationMode)ri(t,n);else{let i=s?t[t.length-1]:t[0];for(o=0,a=t.length;o<a;++o)r=t[o],l=ai(i,r,t[Math.min(o+1,a-(s?0:1))%a],e.tension),r.cp1x=l.previous.x,r.cp1y=l.previous.y,r.cp2x=l.next.x,r.cp2y=l.next.y,i=r}e.capBezierPoints&&function(t,e){let i,s,n,o,a,r=Re(t[0],e);for(i=0,s=t.length;i<s;++i)a=o,o=r,r=i<s-1&&Re(t[i+1],e),o&&(n=t[i],a&&(n.cp1x=li(n.cp1x,e.left,e.right),n.cp1y=li(n.cp1y,e.top,e.bottom)),r&&(n.cp2x=li(n.cp2x,e.left,e.right),n.cp2y=li(n.cp2y,e.top,e.bottom)))}(t,i)}const ci=t=>0===t||1===t,di=(t,e,i)=>-Math.pow(2,10*(t-=1))*Math.sin((t-e)*O/i),ui=(t,e,i)=>Math.pow(2,-10*t)*Math.sin((t-e)*O/i)+1,fi={linear:t=>t,easeInQuad:t=>t*t,easeOutQuad:t=>-t*(t-2),easeInOutQuad:t=>(t/=.5)<1?.5*t*t:-.5*(--t*(t-2)-1),easeInCubic:t=>t*t*t,easeOutCubic:t=>(t-=1)*t*t+1,easeInOutCubic:t=>(t/=.5)<1?.5*t*t*t:.5*((t-=2)*t*t+2),easeInQuart:t=>t*t*t*t,easeOutQuart:t=>-((t-=1)*t*t*t-1),easeInOutQuart:t=>(t/=.5)<1?.5*t*t*t*t:-.5*((t-=2)*t*t*t-2),easeInQuint:t=>t*t*t*t*t,easeOutQuint:t=>(t-=1)*t*t*t*t+1,easeInOutQuint:t=>(t/=.5)<1?.5*t*t*t*t*t:.5*((t-=2)*t*t*t*t+2),easeInSine:t=>1-Math.cos(t*E),easeOutSine:t=>Math.sin(t*E),easeInOutSine:t=>-.5*(Math.cos(C*t)-1),easeInExpo:t=>0===t?0:Math.pow(2,10*(t-1)),easeOutExpo:t=>1===t?1:1-Math.pow(2,-10*t),easeInOutExpo:t=>ci(t)?t:t<.5?.5*Math.pow(2,10*(2*t-1)):.5*(2-Math.pow(2,-10*(2*t-1))),easeInCirc:t=>t>=1?t:-(Math.sqrt(1-t*t)-1),easeOutCirc:t=>Math.sqrt(1-(t-=1)*t),easeInOutCirc:t=>(t/=.5)<1?-.5*(Math.sqrt(1-t*t)-1):.5*(Math.sqrt(1-(t-=2)*t)+1),easeInElastic:t=>ci(t)?t:di(t,.075,.3),easeOutElastic:t=>ci(t)?t:ui(t,.075,.3),easeInOutElastic(t){const e=.1125;return ci(t)?t:t<.5?.5*di(2*t,e,.45):.5+.5*ui(2*t-1,e,.45)},easeInBack(t){const e=1.70158;return t*t*((e+1)*t-e)},easeOutBack(t){const e=1.70158;return(t-=1)*t*((e+1)*t+e)+1},easeInOutBack(t){let e=1.70158;return(t/=.5)<1?t*t*((1+(e*=1.525))*t-e)*.5:.5*((t-=2)*t*((1+(e*=1.525))*t+e)+2)},easeInBounce:t=>1-fi.easeOutBounce(1-t),easeOutBounce(t){const e=7.5625,i=2.75;return t<1/i?e*t*t:t<2/i?e*(t-=1.5/i)*t+.75:t<2.5/i?e*(t-=2.25/i)*t+.9375:e*(t-=2.625/i)*t+.984375},easeInOutBounce:t=>t<.5?.5*fi.easeInBounce(2*t):.5*fi.easeOutBounce(2*t-1)+.5};function gi(t,e,i,s){return{x:t.x+i*(e.x-t.x),y:t.y+i*(e.y-t.y)}}function pi(t,e,i,s){return{x:t.x+i*(e.x-t.x),y:"middle"===s?i<.5?t.y:e.y:"after"===s?i<1?t.y:e.y:i>0?e.y:t.y}}function mi(t,e,i,s){const n={x:t.cp2x,y:t.cp2y},o={x:e.cp1x,y:e.cp1y},a=gi(t,n,i),r=gi(n,o,i),l=gi(o,e,i),h=gi(a,r,i),c=gi(r,l,i);return gi(h,c,i)}const xi=/^(normal|(\d+(?:\.\d+)?)(px|em|%)?)$/,bi=/^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;function _i(t,e){const i=(""+t).match(xi);if(!i||"normal"===i[1])return 1.2*e;switch(t=+i[2],i[3]){case"px":return t;case"%":t/=100}return e*t}const yi=t=>+t||0;function vi(t,e){const i={},s=o(e),n=s?Object.keys(e):e,a=o(t)?s?i=>l(t[i],t[e[i]]):e=>t[e]:()=>t;for(const t of n)i[t]=yi(a(t));return i}function Mi(t){return vi(t,{top:"y",right:"x",bottom:"y",left:"x"})}function wi(t){return vi(t,["topLeft","topRight","bottomLeft","bottomRight"])}function ki(t){const e=Mi(t);return e.width=e.left+e.right,e.height=e.top+e.bottom,e}function Si(t,e){t=t||{},e=e||ue.font;let i=l(t.size,e.size);"string"==typeof i&&(i=parseInt(i,10));let s=l(t.style,e.style);s&&!(""+s).match(bi)&&(console.warn('Invalid font style specified: "'+s+'"'),s=void 0);const n={family:l(t.family,e.family),lineHeight:_i(l(t.lineHeight,e.lineHeight),i),size:i,style:s,weight:l(t.weight,e.weight),string:""};return n.string=De(n),n}function Pi(t,e,i,s){let o,a,r,l=!0;for(o=0,a=t.length;o<a;++o)if(r=t[o],void 0!==r&&(void 0!==e&&"function"==typeof r&&(r=r(e),l=!1),void 0!==i&&n(r)&&(r=r[i%r.length],l=!1),void 0!==r))return s&&!l&&(s.cacheable=!1),r}function Di(t,e,i){const{min:s,max:n}=t,o=c(e,(n-s)/2),a=(t,e)=>i&&0===t?0:t+e;return{min:a(s,-Math.abs(o)),max:a(n,o)}}function Ci(t,e){return Object.assign(Object.create(t),e)}function Oi(t,e,i){return t?function(t,e){return{x:i=>t+t+e-i,setWidth(t){e=t},textAlign:t=>"center"===t?t:"right"===t?"left":"right",xPlus:(t,e)=>t-e,leftForLtr:(t,e)=>t-e}}(e,i):{x:t=>t,setWidth(t){},textAlign:t=>t,xPlus:(t,e)=>t+e,leftForLtr:(t,e)=>t}}function Ai(t,e){let i,s;"ltr"!==e&&"rtl"!==e||(i=t.canvas.style,s=[i.getPropertyValue("direction"),i.getPropertyPriority("direction")],i.setProperty("direction",e,"important"),t.prevTextDirection=s)}function Ti(t,e){void 0!==e&&(delete t.prevTextDirection,t.canvas.style.setProperty("direction",e[0],e[1]))}function Li(t){return"angle"===t?{between:Z,compare:K,normalize:G}:{between:tt,compare:(t,e)=>t-e,normalize:t=>t}}function Ei({start:t,end:e,count:i,loop:s,style:n}){return{start:t%i,end:e%i,loop:s&&(e-t+1)%i==0,style:n}}function Ri(t,e,i){if(!i)return[t];const{property:s,start:n,end:o}=i,a=e.length,{compare:r,between:l,normalize:h}=Li(s),{start:c,end:d,loop:u,style:f}=function(t,e,i){const{property:s,start:n,end:o}=i,{between:a,normalize:r}=Li(s),l=e.length;let h,c,{start:d,end:u,loop:f}=t;if(f){for(d+=l,u+=l,h=0,c=l;h<c&&a(r(e[d%l][s]),n,o);++h)d--,u--;d%=l,u%=l}return u<d&&(u+=l),{start:d,end:u,loop:f,style:t.style}}(t,e,i),g=[];let p,m,x,b=!1,_=null;const y=()=>b||l(n,x,p)&&0!==r(n,x),v=()=>!b||0===r(o,p)||l(o,x,p);for(let t=c,i=c;t<=d;++t)m=e[t%a],m.skip||(p=h(m[s]),p!==x&&(b=l(p,n,o),null===_&&y()&&(_=0===r(p,n)?t:i),null!==_&&v()&&(g.push(Ei({start:_,end:t,loop:u,count:a,style:f})),_=null),i=t,x=p));return null!==_&&g.push(Ei({start:_,end:d,loop:u,count:a,style:f})),g}function Ii(t,e){const i=[],s=t.segments;for(let n=0;n<s.length;n++){const o=Ri(s[n],t.points,e);o.length&&i.push(...o)}return i}function zi(t,e){const i=t.points,s=t.options.spanGaps,n=i.length;if(!n)return[];const o=!!t._loop,{start:a,end:r}=function(t,e,i,s){let n=0,o=e-1;if(i&&!s)for(;n<e&&!t[n].skip;)n++;for(;n<e&&t[n].skip;)n++;for(n%=e,i&&(o+=n);o>n&&t[o%e].skip;)o--;return o%=e,{start:n,end:o}}(i,n,o,s);if(!0===s)return Fi(t,[{start:a,end:r,loop:o}],i,e);return Fi(t,function(t,e,i,s){const n=t.length,o=[];let a,r=e,l=t[e];for(a=e+1;a<=i;++a){const i=t[a%n];i.skip||i.stop?l.skip||(s=!1,o.push({start:e%n,end:(a-1)%n,loop:s}),e=r=i.stop?a:null):(r=a,l.skip&&(e=a)),l=i}return null!==r&&o.push({start:e%n,end:r%n,loop:s}),o}(i,a,r<a?r+n:r,!!t._fullLoop&&0===a&&r===n-1),i,e)}function Fi(t,e,i,s){return s&&s.setContext&&i?function(t,e,i,s){const n=t._chart.getContext(),o=Vi(t.options),{_datasetIndex:a,options:{spanGaps:r}}=t,l=i.length,h=[];let c=o,d=e[0].start,u=d;function f(t,e,s,n){const o=r?-1:1;if(t!==e){for(t+=l;i[t%l].skip;)t-=o;for(;i[e%l].skip;)e+=o;t%l!=e%l&&(h.push({start:t%l,end:e%l,loop:s,style:n}),c=n,d=e%l)}}for(const t of e){d=r?d:t.start;let e,o=i[d%l];for(u=d+1;u<=t.end;u++){const r=i[u%l];e=Vi(s.setContext(Ci(n,{type:"segment",p0:o,p1:r,p0DataIndex:(u-1)%l,p1DataIndex:u%l,datasetIndex:a}))),Bi(e,c)&&f(d,u-1,t.loop,c),o=r,c=e}d<u-1&&f(d,u-1,t.loop,c)}return h}(t,e,i,s):e}function Vi(t){return{backgroundColor:t.backgroundColor,borderCapStyle:t.borderCapStyle,borderDash:t.borderDash,borderDashOffset:t.borderDashOffset,borderJoinStyle:t.borderJoinStyle,borderWidth:t.borderWidth,borderColor:t.borderColor}}function Bi(t,e){if(!e)return!1;const i=[],s=function(t,e){return Jt(e)?(i.includes(e)||i.push(e),i.indexOf(e)):e};return JSON.stringify(t,s)!==JSON.stringify(e,s)}var Wi=Object.freeze({__proto__:null,HALF_PI:E,INFINITY:T,PI:C,PITAU:A,QUARTER_PI:R,RAD_PER_DEG:L,TAU:O,TWO_THIRDS_PI:I,_addGrace:Di,_alignPixel:Ae,_alignStartEnd:ft,_angleBetween:Z,_angleDiff:K,_arrayUnique:lt,_attachContext:$e,_bezierCurveTo:Ve,_bezierInterpolation:mi,_boundSegment:Ri,_boundSegments:Ii,_capitalize:w,_computeSegments:zi,_createResolver:je,_decimalPlaces:U,_deprecated:function(t,e,i,s){void 0!==e&&console.warn(t+': "'+i+'" is deprecated. Please use "'+s+'" instead')},_descriptors:Ye,_elementsEqual:f,_factorize:W,_filterBetween:nt,_getParentNode:ge,_getStartAndCountOfVisiblePoints:pt,_int16Range:Q,_isBetween:tt,_isClickEvent:D,_isDomSupported:fe,_isPointInArea:Re,_limitValue:J,_longestText:Oe,_lookup:et,_lookupByKey:it,_measureText:Ce,_merger:m,_mergerIf:_,_normalizeAngle:G,_parseObjectDataRadialScale:ii,_pointInLine:gi,_readValueToProps:vi,_rlookupByKey:st,_scaleRangesChanged:mt,_setMinAndMaxByKey:j,_splitKey:v,_steppedInterpolation:pi,_steppedLineTo:Fe,_textX:gt,_toLeftRightCenter:ut,_updateBezierControlPoints:hi,addRoundedRectPath:He,almostEquals:V,almostWhole:H,callback:d,clearCanvas:Te,clipArea:Ie,clone:g,color:Qt,createContext:Ci,debounce:dt,defined:k,distanceBetweenPoints:q,drawPoint:Le,drawPointLegend:Ee,each:u,easingEffects:fi,finiteOrDefault:r,fontString:function(t,e,i){return e+" "+t+"px "+i},formatNumber:ne,getAngleFromPoint:X,getHoverColor:te,getMaximumSize:we,getRelativePosition:ve,getRtlAdapter:Oi,getStyle:xe,isArray:n,isFinite:a,isFunction:S,isNullOrUndef:s,isNumber:N,isObject:o,isPatternOrGradient:Jt,listenArrayEvents:at,log10:z,merge:x,mergeIf:b,niceNum:B,noop:e,overrideTextDirection:Ai,readUsedSize:Pe,renderText:Ne,requestAnimFrame:ht,resolve:Pi,resolveObjectKey:M,restoreTextDirection:Ti,retinaScale:ke,setsEqual:P,sign:F,splineCurve:ai,splineCurveMonotone:ri,supportsEventListenerOptions:Se,throttled:ct,toDegrees:Y,toDimension:c,toFont:Si,toFontString:De,toLineHeight:_i,toPadding:ki,toPercentage:h,toRadians:$,toTRBL:Mi,toTRBLCorners:wi,uid:i,unclipArea:ze,unlistenArrayEvents:rt,valueOrDefault:l});function Ni(t,e,i,s){const{controller:n,data:o,_sorted:a}=t,r=n._cachedMeta.iScale;if(r&&e===r.axis&&"r"!==e&&a&&o.length){const t=r._reversePixels?st:it;if(!s)return t(o,e,i);if(n._sharedOptions){const s=o[0],n="function"==typeof s.getRange&&s.getRange(e);if(n){const s=t(o,e,i-n),a=t(o,e,i+n);return{lo:s.lo,hi:a.hi}}}}return{lo:0,hi:o.length-1}}function Hi(t,e,i,s,n){const o=t.getSortedVisibleDatasetMetas(),a=i[e];for(let t=0,i=o.length;t<i;++t){const{index:i,data:r}=o[t],{lo:l,hi:h}=Ni(o[t],e,a,n);for(let t=l;t<=h;++t){const e=r[t];e.skip||s(e,i,t)}}}function ji(t,e,i,s,n){const o=[];if(!n&&!t.isPointInArea(e))return o;return Hi(t,i,e,(function(i,a,r){(n||Re(i,t.chartArea,0))&&i.inRange(e.x,e.y,s)&&o.push({element:i,datasetIndex:a,index:r})}),!0),o}function $i(t,e,i,s,n,o){let a=[];const r=function(t){const e=-1!==t.indexOf("x"),i=-1!==t.indexOf("y");return function(t,s){const n=e?Math.abs(t.x-s.x):0,o=i?Math.abs(t.y-s.y):0;return Math.sqrt(Math.pow(n,2)+Math.pow(o,2))}}(i);let l=Number.POSITIVE_INFINITY;return Hi(t,i,e,(function(i,h,c){const d=i.inRange(e.x,e.y,n);if(s&&!d)return;const u=i.getCenterPoint(n);if(!(!!o||t.isPointInArea(u))&&!d)return;const f=r(e,u);f<l?(a=[{element:i,datasetIndex:h,index:c}],l=f):f===l&&a.push({element:i,datasetIndex:h,index:c})})),a}function Yi(t,e,i,s,n,o){return o||t.isPointInArea(e)?"r"!==i||s?$i(t,e,i,s,n,o):function(t,e,i,s){let n=[];return Hi(t,i,e,(function(t,i,o){const{startAngle:a,endAngle:r}=t.getProps(["startAngle","endAngle"],s),{angle:l}=X(t,{x:e.x,y:e.y});Z(l,a,r)&&n.push({element:t,datasetIndex:i,index:o})})),n}(t,e,i,n):[]}function Ui(t,e,i,s,n){const o=[],a="x"===i?"inXRange":"inYRange";let r=!1;return Hi(t,i,e,((t,s,l)=>{t[a](e[i],n)&&(o.push({element:t,datasetIndex:s,index:l}),r=r||t.inRange(e.x,e.y,n))})),s&&!r?[]:o}var Xi={evaluateInteractionItems:Hi,modes:{index(t,e,i,s){const n=ve(e,t),o=i.axis||"x",a=i.includeInvisible||!1,r=i.intersect?ji(t,n,o,s,a):Yi(t,n,o,!1,s,a),l=[];return r.length?(t.getSortedVisibleDatasetMetas().forEach((t=>{const e=r[0].index,i=t.data[e];i&&!i.skip&&l.push({element:i,datasetIndex:t.index,index:e})})),l):[]},dataset(t,e,i,s){const n=ve(e,t),o=i.axis||"xy",a=i.includeInvisible||!1;let r=i.intersect?ji(t,n,o,s,a):Yi(t,n,o,!1,s,a);if(r.length>0){const e=r[0].datasetIndex,i=t.getDatasetMeta(e).data;r=[];for(let t=0;t<i.length;++t)r.push({element:i[t],datasetIndex:e,index:t})}return r},point:(t,e,i,s)=>ji(t,ve(e,t),i.axis||"xy",s,i.includeInvisible||!1),nearest(t,e,i,s){const n=ve(e,t),o=i.axis||"xy",a=i.includeInvisible||!1;return Yi(t,n,o,i.intersect,s,a)},x:(t,e,i,s)=>Ui(t,ve(e,t),"x",i.intersect,s),y:(t,e,i,s)=>Ui(t,ve(e,t),"y",i.intersect,s)}};const qi=["left","top","right","bottom"];function Ki(t,e){return t.filter((t=>t.pos===e))}function Gi(t,e){return t.filter((t=>-1===qi.indexOf(t.pos)&&t.box.axis===e))}function Zi(t,e){return t.sort(((t,i)=>{const s=e?i:t,n=e?t:i;return s.weight===n.weight?s.index-n.index:s.weight-n.weight}))}function Ji(t,e){const i=function(t){const e={};for(const i of t){const{stack:t,pos:s,stackWeight:n}=i;if(!t||!qi.includes(s))continue;const o=e[t]||(e[t]={count:0,placed:0,weight:0,size:0});o.count++,o.weight+=n}return e}(t),{vBoxMaxWidth:s,hBoxMaxHeight:n}=e;let o,a,r;for(o=0,a=t.length;o<a;++o){r=t[o];const{fullSize:a}=r.box,l=i[r.stack],h=l&&r.stackWeight/l.weight;r.horizontal?(r.width=h?h*s:a&&e.availableWidth,r.height=n):(r.width=s,r.height=h?h*n:a&&e.availableHeight)}return i}function Qi(t,e,i,s){return Math.max(t[i],e[i])+Math.max(t[s],e[s])}function ts(t,e){t.top=Math.max(t.top,e.top),t.left=Math.max(t.left,e.left),t.bottom=Math.max(t.bottom,e.bottom),t.right=Math.max(t.right,e.right)}function es(t,e,i,s){const{pos:n,box:a}=i,r=t.maxPadding;if(!o(n)){i.size&&(t[n]-=i.size);const e=s[i.stack]||{size:0,count:1};e.size=Math.max(e.size,i.horizontal?a.height:a.width),i.size=e.size/e.count,t[n]+=i.size}a.getPadding&&ts(r,a.getPadding());const l=Math.max(0,e.outerWidth-Qi(r,t,"left","right")),h=Math.max(0,e.outerHeight-Qi(r,t,"top","bottom")),c=l!==t.w,d=h!==t.h;return t.w=l,t.h=h,i.horizontal?{same:c,other:d}:{same:d,other:c}}function is(t,e){const i=e.maxPadding;function s(t){const s={left:0,top:0,right:0,bottom:0};return t.forEach((t=>{s[t]=Math.max(e[t],i[t])})),s}return s(t?["left","right"]:["top","bottom"])}function ss(t,e,i,s){const n=[];let o,a,r,l,h,c;for(o=0,a=t.length,h=0;o<a;++o){r=t[o],l=r.box,l.update(r.width||e.w,r.height||e.h,is(r.horizontal,e));const{same:a,other:d}=es(e,i,r,s);h|=a&&n.length,c=c||d,l.fullSize||n.push(r)}return h&&ss(n,e,i,s)||c}function ns(t,e,i,s,n){t.top=i,t.left=e,t.right=e+s,t.bottom=i+n,t.width=s,t.height=n}function os(t,e,i,s){const n=i.padding;let{x:o,y:a}=e;for(const r of t){const t=r.box,l=s[r.stack]||{count:1,placed:0,weight:1},h=r.stackWeight/l.weight||1;if(r.horizontal){const s=e.w*h,o=l.size||t.height;k(l.start)&&(a=l.start),t.fullSize?ns(t,n.left,a,i.outerWidth-n.right-n.left,o):ns(t,e.left+l.placed,a,s,o),l.start=a,l.placed+=s,a=t.bottom}else{const s=e.h*h,a=l.size||t.width;k(l.start)&&(o=l.start),t.fullSize?ns(t,o,n.top,a,i.outerHeight-n.bottom-n.top):ns(t,o,e.top+l.placed,a,s),l.start=o,l.placed+=s,o=t.right}}e.x=o,e.y=a}var as={addBox(t,e){t.boxes||(t.boxes=[]),e.fullSize=e.fullSize||!1,e.position=e.position||"top",e.weight=e.weight||0,e._layers=e._layers||function(){return[{z:0,draw(t){e.draw(t)}}]},t.boxes.push(e)},removeBox(t,e){const i=t.boxes?t.boxes.indexOf(e):-1;-1!==i&&t.boxes.splice(i,1)},configure(t,e,i){e.fullSize=i.fullSize,e.position=i.position,e.weight=i.weight},update(t,e,i,s){if(!t)return;const n=ki(t.options.layout.padding),o=Math.max(e-n.width,0),a=Math.max(i-n.height,0),r=function(t){const e=function(t){const e=[];let i,s,n,o,a,r;for(i=0,s=(t||[]).length;i<s;++i)n=t[i],({position:o,options:{stack:a,stackWeight:r=1}}=n),e.push({index:i,box:n,pos:o,horizontal:n.isHorizontal(),weight:n.weight,stack:a&&o+a,stackWeight:r});return e}(t),i=Zi(e.filter((t=>t.box.fullSize)),!0),s=Zi(Ki(e,"left"),!0),n=Zi(Ki(e,"right")),o=Zi(Ki(e,"top"),!0),a=Zi(Ki(e,"bottom")),r=Gi(e,"x"),l=Gi(e,"y");return{fullSize:i,leftAndTop:s.concat(o),rightAndBottom:n.concat(l).concat(a).concat(r),chartArea:Ki(e,"chartArea"),vertical:s.concat(n).concat(l),horizontal:o.concat(a).concat(r)}}(t.boxes),l=r.vertical,h=r.horizontal;u(t.boxes,(t=>{"function"==typeof t.beforeLayout&&t.beforeLayout()}));const c=l.reduce(((t,e)=>e.box.options&&!1===e.box.options.display?t:t+1),0)||1,d=Object.freeze({outerWidth:e,outerHeight:i,padding:n,availableWidth:o,availableHeight:a,vBoxMaxWidth:o/2/c,hBoxMaxHeight:a/2}),f=Object.assign({},n);ts(f,ki(s));const g=Object.assign({maxPadding:f,w:o,h:a,x:n.left,y:n.top},n),p=Ji(l.concat(h),d);ss(r.fullSize,g,d,p),ss(l,g,d,p),ss(h,g,d,p)&&ss(l,g,d,p),function(t){const e=t.maxPadding;function i(i){const s=Math.max(e[i]-t[i],0);return t[i]+=s,s}t.y+=i("top"),t.x+=i("left"),i("right"),i("bottom")}(g),os(r.leftAndTop,g,d,p),g.x+=g.w,g.y+=g.h,os(r.rightAndBottom,g,d,p),t.chartArea={left:g.left,top:g.top,right:g.left+g.w,bottom:g.top+g.h,height:g.h,width:g.w},u(r.chartArea,(e=>{const i=e.box;Object.assign(i,t.chartArea),i.update(g.w,g.h,{left:0,top:0,right:0,bottom:0})}))}};class rs{acquireContext(t,e){}releaseContext(t){return!1}addEventListener(t,e,i){}removeEventListener(t,e,i){}getDevicePixelRatio(){return 1}getMaximumSize(t,e,i,s){return e=Math.max(0,e||t.width),i=i||t.height,{width:e,height:Math.max(0,s?Math.floor(e/s):i)}}isAttached(t){return!0}updateConfig(t){}}class ls extends rs{acquireContext(t){return t&&t.getContext&&t.getContext("2d")||null}updateConfig(t){t.options.animation=!1}}const hs="$chartjs",cs={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},ds=t=>null===t||""===t;const us=!!Se&&{passive:!0};function fs(t,e,i){t&&t.canvas&&t.canvas.removeEventListener(e,i,us)}function gs(t,e){for(const i of t)if(i===e||i.contains(e))return!0}function ps(t,e,i){const s=t.canvas,n=new MutationObserver((t=>{let e=!1;for(const i of t)e=e||gs(i.addedNodes,s),e=e&&!gs(i.removedNodes,s);e&&i()}));return n.observe(document,{childList:!0,subtree:!0}),n}function ms(t,e,i){const s=t.canvas,n=new MutationObserver((t=>{let e=!1;for(const i of t)e=e||gs(i.removedNodes,s),e=e&&!gs(i.addedNodes,s);e&&i()}));return n.observe(document,{childList:!0,subtree:!0}),n}const xs=new Map;let bs=0;function _s(){const t=window.devicePixelRatio;t!==bs&&(bs=t,xs.forEach(((e,i)=>{i.currentDevicePixelRatio!==t&&e()})))}function ys(t,e,i){const s=t.canvas,n=s&&ge(s);if(!n)return;const o=ct(((t,e)=>{const s=n.clientWidth;i(t,e),s<n.clientWidth&&i()}),window),a=new ResizeObserver((t=>{const e=t[0],i=e.contentRect.width,s=e.contentRect.height;0===i&&0===s||o(i,s)}));return a.observe(n),function(t,e){xs.size||window.addEventListener("resize",_s),xs.set(t,e)}(t,o),a}function vs(t,e,i){i&&i.disconnect(),"resize"===e&&function(t){xs.delete(t),xs.size||window.removeEventListener("resize",_s)}(t)}function Ms(t,e,i){const s=t.canvas,n=ct((e=>{null!==t.ctx&&i(function(t,e){const i=cs[t.type]||t.type,{x:s,y:n}=ve(t,e);return{type:i,chart:e,native:t,x:void 0!==s?s:null,y:void 0!==n?n:null}}(e,t))}),t);return function(t,e,i){t&&t.addEventListener(e,i,us)}(s,e,n),n}class ws extends rs{acquireContext(t,e){const i=t&&t.getContext&&t.getContext("2d");return i&&i.canvas===t?(function(t,e){const i=t.style,s=t.getAttribute("height"),n=t.getAttribute("width");if(t[hs]={initial:{height:s,width:n,style:{display:i.display,height:i.height,width:i.width}}},i.display=i.display||"block",i.boxSizing=i.boxSizing||"border-box",ds(n)){const e=Pe(t,"width");void 0!==e&&(t.width=e)}if(ds(s))if(""===t.style.height)t.height=t.width/(e||2);else{const e=Pe(t,"height");void 0!==e&&(t.height=e)}}(t,e),i):null}releaseContext(t){const e=t.canvas;if(!e[hs])return!1;const i=e[hs].initial;["height","width"].forEach((t=>{const n=i[t];s(n)?e.removeAttribute(t):e.setAttribute(t,n)}));const n=i.style||{};return Object.keys(n).forEach((t=>{e.style[t]=n[t]})),e.width=e.width,delete e[hs],!0}addEventListener(t,e,i){this.removeEventListener(t,e);const s=t.$proxies||(t.$proxies={}),n={attach:ps,detach:ms,resize:ys}[e]||Ms;s[e]=n(t,e,i)}removeEventListener(t,e){const i=t.$proxies||(t.$proxies={}),s=i[e];if(!s)return;({attach:vs,detach:vs,resize:vs}[e]||fs)(t,e,s),i[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(t,e,i,s){return we(t,e,i,s)}isAttached(t){const e=t&&ge(t);return!(!e||!e.isConnected)}}function ks(t){return!fe()||"undefined"!=typeof OffscreenCanvas&&t instanceof OffscreenCanvas?ls:ws}var Ss=Object.freeze({__proto__:null,BasePlatform:rs,BasicPlatform:ls,DomPlatform:ws,_detectPlatform:ks});const Ps="transparent",Ds={boolean:(t,e,i)=>i>.5?e:t,color(t,e,i){const s=Qt(t||Ps),n=s.valid&&Qt(e||Ps);return n&&n.valid?n.mix(s,i).hexString():e},number:(t,e,i)=>t+(e-t)*i};class Cs{constructor(t,e,i,s){const n=e[i];s=Pi([t.to,s,n,t.from]);const o=Pi([t.from,n,s]);this._active=!0,this._fn=t.fn||Ds[t.type||typeof o],this._easing=fi[t.easing]||fi.linear,this._start=Math.floor(Date.now()+(t.delay||0)),this._duration=this._total=Math.floor(t.duration),this._loop=!!t.loop,this._target=e,this._prop=i,this._from=o,this._to=s,this._promises=void 0}active(){return this._active}update(t,e,i){if(this._active){this._notify(!1);const s=this._target[this._prop],n=i-this._start,o=this._duration-n;this._start=i,this._duration=Math.floor(Math.max(o,t.duration)),this._total+=n,this._loop=!!t.loop,this._to=Pi([t.to,e,s,t.from]),this._from=Pi([t.from,s,e])}}cancel(){this._active&&(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(t){const e=t-this._start,i=this._duration,s=this._prop,n=this._from,o=this._loop,a=this._to;let r;if(this._active=n!==a&&(o||e<i),!this._active)return this._target[s]=a,void this._notify(!0);e<0?this._target[s]=n:(r=e/i%2,r=o&&r>1?2-r:r,r=this._easing(Math.min(1,Math.max(0,r))),this._target[s]=this._fn(n,a,r))}wait(){const t=this._promises||(this._promises=[]);return new Promise(((e,i)=>{t.push({res:e,rej:i})}))}_notify(t){const e=t?"res":"rej",i=this._promises||[];for(let t=0;t<i.length;t++)i[t][e]()}}class Os{constructor(t,e){this._chart=t,this._properties=new Map,this.configure(e)}configure(t){if(!o(t))return;const e=Object.keys(ue.animation),i=this._properties;Object.getOwnPropertyNames(t).forEach((s=>{const a=t[s];if(!o(a))return;const r={};for(const t of e)r[t]=a[t];(n(a.properties)&&a.properties||[s]).forEach((t=>{t!==s&&i.has(t)||i.set(t,r)}))}))}_animateOptions(t,e){const i=e.options,s=function(t,e){if(!e)return;let i=t.options;if(!i)return void(t.options=e);i.$shared&&(t.options=i=Object.assign({},i,{$shared:!1,$animations:{}}));return i}(t,i);if(!s)return[];const n=this._createAnimations(s,i);return i.$shared&&function(t,e){const i=[],s=Object.keys(e);for(let e=0;e<s.length;e++){const n=t[s[e]];n&&n.active()&&i.push(n.wait())}return Promise.all(i)}(t.options.$animations,i).then((()=>{t.options=i}),(()=>{})),n}_createAnimations(t,e){const i=this._properties,s=[],n=t.$animations||(t.$animations={}),o=Object.keys(e),a=Date.now();let r;for(r=o.length-1;r>=0;--r){const l=o[r];if("$"===l.charAt(0))continue;if("options"===l){s.push(...this._animateOptions(t,e));continue}const h=e[l];let c=n[l];const d=i.get(l);if(c){if(d&&c.active()){c.update(d,h,a);continue}c.cancel()}d&&d.duration?(n[l]=c=new Cs(d,t,l,h),s.push(c)):t[l]=h}return s}update(t,e){if(0===this._properties.size)return void Object.assign(t,e);const i=this._createAnimations(t,e);return i.length?(bt.add(this._chart,i),!0):void 0}}function As(t,e){const i=t&&t.options||{},s=i.reverse,n=void 0===i.min?e:0,o=void 0===i.max?e:0;return{start:s?o:n,end:s?n:o}}function Ts(t,e){const i=[],s=t._getSortedDatasetMetas(e);let n,o;for(n=0,o=s.length;n<o;++n)i.push(s[n].index);return i}function Ls(t,e,i,s={}){const n=t.keys,o="single"===s.mode;let r,l,h,c;if(null!==e){for(r=0,l=n.length;r<l;++r){if(h=+n[r],h===i){if(s.all)continue;break}c=t.values[h],a(c)&&(o||0===e||F(e)===F(c))&&(e+=c)}return e}}function Es(t,e){const i=t&&t.options.stacked;return i||void 0===i&&void 0!==e.stack}function Rs(t,e,i){const s=t[e]||(t[e]={});return s[i]||(s[i]={})}function Is(t,e,i,s){for(const n of e.getMatchingVisibleMetas(s).reverse()){const e=t[n.index];if(i&&e>0||!i&&e<0)return n.index}return null}function zs(t,e){const{chart:i,_cachedMeta:s}=t,n=i._stacks||(i._stacks={}),{iScale:o,vScale:a,index:r}=s,l=o.axis,h=a.axis,c=function(t,e,i){return`${t.id}.${e.id}.${i.stack||i.type}`}(o,a,s),d=e.length;let u;for(let t=0;t<d;++t){const i=e[t],{[l]:o,[h]:d}=i;u=(i._stacks||(i._stacks={}))[h]=Rs(n,c,o),u[r]=d,u._top=Is(u,a,!0,s.type),u._bottom=Is(u,a,!1,s.type);(u._visualValues||(u._visualValues={}))[r]=d}}function Fs(t,e){const i=t.scales;return Object.keys(i).filter((t=>i[t].axis===e)).shift()}function Vs(t,e){const i=t.controller.index,s=t.vScale&&t.vScale.axis;if(s){e=e||t._parsed;for(const t of e){const e=t._stacks;if(!e||void 0===e[s]||void 0===e[s][i])return;delete e[s][i],void 0!==e[s]._visualValues&&void 0!==e[s]._visualValues[i]&&delete e[s]._visualValues[i]}}}const Bs=t=>"reset"===t||"none"===t,Ws=(t,e)=>e?t:Object.assign({},t);class Ns{static defaults={};static datasetElementType=null;static dataElementType=null;constructor(t,e){this.chart=t,this._ctx=t.ctx,this.index=e,this._cachedDataOpts={},this._cachedMeta=this.getMeta(),this._type=this._cachedMeta.type,this.options=void 0,this._parsing=!1,this._data=void 0,this._objectData=void 0,this._sharedOptions=void 0,this._drawStart=void 0,this._drawCount=void 0,this.enableOptionSharing=!1,this.supportsDecimation=!1,this.$context=void 0,this._syncList=[],this.datasetElementType=new.target.datasetElementType,this.dataElementType=new.target.dataElementType,this.initialize()}initialize(){const t=this._cachedMeta;this.configure(),this.linkScales(),t._stacked=Es(t.vScale,t),this.addElements(),this.options.fill&&!this.chart.isPluginEnabled("filler")&&console.warn("Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options")}updateIndex(t){this.index!==t&&Vs(this._cachedMeta),this.index=t}linkScales(){const t=this.chart,e=this._cachedMeta,i=this.getDataset(),s=(t,e,i,s)=>"x"===t?e:"r"===t?s:i,n=e.xAxisID=l(i.xAxisID,Fs(t,"x")),o=e.yAxisID=l(i.yAxisID,Fs(t,"y")),a=e.rAxisID=l(i.rAxisID,Fs(t,"r")),r=e.indexAxis,h=e.iAxisID=s(r,n,o,a),c=e.vAxisID=s(r,o,n,a);e.xScale=this.getScaleForId(n),e.yScale=this.getScaleForId(o),e.rScale=this.getScaleForId(a),e.iScale=this.getScaleForId(h),e.vScale=this.getScaleForId(c)}getDataset(){return this.chart.data.datasets[this.index]}getMeta(){return this.chart.getDatasetMeta(this.index)}getScaleForId(t){return this.chart.scales[t]}_getOtherScale(t){const e=this._cachedMeta;return t===e.iScale?e.vScale:e.iScale}reset(){this._update("reset")}_destroy(){const t=this._cachedMeta;this._data&&rt(this._data,this),t._stacked&&Vs(t)}_dataCheck(){const t=this.getDataset(),e=t.data||(t.data=[]),i=this._data;if(o(e)){const t=this._cachedMeta;this._data=function(t,e){const{iScale:i,vScale:s}=e,n="x"===i.axis?"x":"y",o="x"===s.axis?"x":"y",a=Object.keys(t),r=new Array(a.length);let l,h,c;for(l=0,h=a.length;l<h;++l)c=a[l],r[l]={[n]:c,[o]:t[c]};return r}(e,t)}else if(i!==e){if(i){rt(i,this);const t=this._cachedMeta;Vs(t),t._parsed=[]}e&&Object.isExtensible(e)&&at(e,this),this._syncList=[],this._data=e}}addElements(){const t=this._cachedMeta;this._dataCheck(),this.datasetElementType&&(t.dataset=new this.datasetElementType)}buildOrUpdateElements(t){const e=this._cachedMeta,i=this.getDataset();let s=!1;this._dataCheck();const n=e._stacked;e._stacked=Es(e.vScale,e),e.stack!==i.stack&&(s=!0,Vs(e),e.stack=i.stack),this._resyncElements(t),(s||n!==e._stacked)&&zs(this,e._parsed)}configure(){const t=this.chart.config,e=t.datasetScopeKeys(this._type),i=t.getOptionScopes(this.getDataset(),e,!0);this.options=t.createResolver(i,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(t,e){const{_cachedMeta:i,_data:s}=this,{iScale:a,_stacked:r}=i,l=a.axis;let h,c,d,u=0===t&&e===s.length||i._sorted,f=t>0&&i._parsed[t-1];if(!1===this._parsing)i._parsed=s,i._sorted=!0,d=s;else{d=n(s[t])?this.parseArrayData(i,s,t,e):o(s[t])?this.parseObjectData(i,s,t,e):this.parsePrimitiveData(i,s,t,e);const a=()=>null===c[l]||f&&c[l]<f[l];for(h=0;h<e;++h)i._parsed[h+t]=c=d[h],u&&(a()&&(u=!1),f=c);i._sorted=u}r&&zs(this,d)}parsePrimitiveData(t,e,i,s){const{iScale:n,vScale:o}=t,a=n.axis,r=o.axis,l=n.getLabels(),h=n===o,c=new Array(s);let d,u,f;for(d=0,u=s;d<u;++d)f=d+i,c[d]={[a]:h||n.parse(l[f],f),[r]:o.parse(e[f],f)};return c}parseArrayData(t,e,i,s){const{xScale:n,yScale:o}=t,a=new Array(s);let r,l,h,c;for(r=0,l=s;r<l;++r)h=r+i,c=e[h],a[r]={x:n.parse(c[0],h),y:o.parse(c[1],h)};return a}parseObjectData(t,e,i,s){const{xScale:n,yScale:o}=t,{xAxisKey:a="x",yAxisKey:r="y"}=this._parsing,l=new Array(s);let h,c,d,u;for(h=0,c=s;h<c;++h)d=h+i,u=e[d],l[h]={x:n.parse(M(u,a),d),y:o.parse(M(u,r),d)};return l}getParsed(t){return this._cachedMeta._parsed[t]}getDataElement(t){return this._cachedMeta.data[t]}applyStack(t,e,i){const s=this.chart,n=this._cachedMeta,o=e[t.axis];return Ls({keys:Ts(s,!0),values:e._stacks[t.axis]._visualValues},o,n.index,{mode:i})}updateRangeFromParsed(t,e,i,s){const n=i[e.axis];let o=null===n?NaN:n;const a=s&&i._stacks[e.axis];s&&a&&(s.values=a,o=Ls(s,n,this._cachedMeta.index)),t.min=Math.min(t.min,o),t.max=Math.max(t.max,o)}getMinMax(t,e){const i=this._cachedMeta,s=i._parsed,n=i._sorted&&t===i.iScale,o=s.length,r=this._getOtherScale(t),l=((t,e,i)=>t&&!e.hidden&&e._stacked&&{keys:Ts(i,!0),values:null})(e,i,this.chart),h={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY},{min:c,max:d}=function(t){const{min:e,max:i,minDefined:s,maxDefined:n}=t.getUserBounds();return{min:s?e:Number.NEGATIVE_INFINITY,max:n?i:Number.POSITIVE_INFINITY}}(r);let u,f;function g(){f=s[u];const e=f[r.axis];return!a(f[t.axis])||c>e||d<e}for(u=0;u<o&&(g()||(this.updateRangeFromParsed(h,t,f,l),!n));++u);if(n)for(u=o-1;u>=0;--u)if(!g()){this.updateRangeFromParsed(h,t,f,l);break}return h}getAllParsedValues(t){const e=this._cachedMeta._parsed,i=[];let s,n,o;for(s=0,n=e.length;s<n;++s)o=e[s][t.axis],a(o)&&i.push(o);return i}getMaxOverflow(){return!1}getLabelAndValue(t){const e=this._cachedMeta,i=e.iScale,s=e.vScale,n=this.getParsed(t);return{label:i?""+i.getLabelForValue(n[i.axis]):"",value:s?""+s.getLabelForValue(n[s.axis]):""}}_update(t){const e=this._cachedMeta;this.update(t||"default"),e._clip=function(t){let e,i,s,n;return o(t)?(e=t.top,i=t.right,s=t.bottom,n=t.left):e=i=s=n=t,{top:e,right:i,bottom:s,left:n,disabled:!1===t}}(l(this.options.clip,function(t,e,i){if(!1===i)return!1;const s=As(t,i),n=As(e,i);return{top:n.end,right:s.end,bottom:n.start,left:s.start}}(e.xScale,e.yScale,this.getMaxOverflow())))}update(t){}draw(){const t=this._ctx,e=this.chart,i=this._cachedMeta,s=i.data||[],n=e.chartArea,o=[],a=this._drawStart||0,r=this._drawCount||s.length-a,l=this.options.drawActiveElementsOnTop;let h;for(i.dataset&&i.dataset.draw(t,n,a,r),h=a;h<a+r;++h){const e=s[h];e.hidden||(e.active&&l?o.push(e):e.draw(t,n))}for(h=0;h<o.length;++h)o[h].draw(t,n)}getStyle(t,e){const i=e?"active":"default";return void 0===t&&this._cachedMeta.dataset?this.resolveDatasetElementOptions(i):this.resolveDataElementOptions(t||0,i)}getContext(t,e,i){const s=this.getDataset();let n;if(t>=0&&t<this._cachedMeta.data.length){const e=this._cachedMeta.data[t];n=e.$context||(e.$context=function(t,e,i){return Ci(t,{active:!1,dataIndex:e,parsed:void 0,raw:void 0,element:i,index:e,mode:"default",type:"data"})}(this.getContext(),t,e)),n.parsed=this.getParsed(t),n.raw=s.data[t],n.index=n.dataIndex=t}else n=this.$context||(this.$context=function(t,e){return Ci(t,{active:!1,dataset:void 0,datasetIndex:e,index:e,mode:"default",type:"dataset"})}(this.chart.getContext(),this.index)),n.dataset=s,n.index=n.datasetIndex=this.index;return n.active=!!e,n.mode=i,n}resolveDatasetElementOptions(t){return this._resolveElementOptions(this.datasetElementType.id,t)}resolveDataElementOptions(t,e){return this._resolveElementOptions(this.dataElementType.id,e,t)}_resolveElementOptions(t,e="default",i){const s="active"===e,n=this._cachedDataOpts,o=t+"-"+e,a=n[o],r=this.enableOptionSharing&&k(i);if(a)return Ws(a,r);const l=this.chart.config,h=l.datasetElementScopeKeys(this._type,t),c=s?[`${t}Hover`,"hover",t,""]:[t,""],d=l.getOptionScopes(this.getDataset(),h),u=Object.keys(ue.elements[t]),f=l.resolveNamedOptions(d,u,(()=>this.getContext(i,s,e)),c);return f.$shared&&(f.$shared=r,n[o]=Object.freeze(Ws(f,r))),f}_resolveAnimations(t,e,i){const s=this.chart,n=this._cachedDataOpts,o=`animation-${e}`,a=n[o];if(a)return a;let r;if(!1!==s.options.animation){const s=this.chart.config,n=s.datasetAnimationScopeKeys(this._type,e),o=s.getOptionScopes(this.getDataset(),n);r=s.createResolver(o,this.getContext(t,i,e))}const l=new Os(s,r&&r.animations);return r&&r._cacheable&&(n[o]=Object.freeze(l)),l}getSharedOptions(t){if(t.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},t))}includeOptions(t,e){return!e||Bs(t)||this.chart._animationsDisabled}_getSharedOptions(t,e){const i=this.resolveDataElementOptions(t,e),s=this._sharedOptions,n=this.getSharedOptions(i),o=this.includeOptions(e,n)||n!==s;return this.updateSharedOptions(n,e,i),{sharedOptions:n,includeOptions:o}}updateElement(t,e,i,s){Bs(s)?Object.assign(t,i):this._resolveAnimations(e,s).update(t,i)}updateSharedOptions(t,e,i){t&&!Bs(e)&&this._resolveAnimations(void 0,e).update(t,i)}_setStyle(t,e,i,s){t.active=s;const n=this.getStyle(e,s);this._resolveAnimations(e,i,s).update(t,{options:!s&&this.getSharedOptions(n)||n})}removeHoverStyle(t,e,i){this._setStyle(t,i,"active",!1)}setHoverStyle(t,e,i){this._setStyle(t,i,"active",!0)}_removeDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!1)}_setDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!0)}_resyncElements(t){const e=this._data,i=this._cachedMeta.data;for(const[t,e,i]of this._syncList)this[t](e,i);this._syncList=[];const s=i.length,n=e.length,o=Math.min(n,s);o&&this.parse(0,o),n>s?this._insertElements(s,n-s,t):n<s&&this._removeElements(n,s-n)}_insertElements(t,e,i=!0){const s=this._cachedMeta,n=s.data,o=t+e;let a;const r=t=>{for(t.length+=e,a=t.length-1;a>=o;a--)t[a]=t[a-e]};for(r(n),a=t;a<o;++a)n[a]=new this.dataElementType;this._parsing&&r(s._parsed),this.parse(t,e),i&&this.updateElements(n,t,e,"reset")}updateElements(t,e,i,s){}_removeElements(t,e){const i=this._cachedMeta;if(this._parsing){const s=i._parsed.splice(t,e);i._stacked&&Vs(i,s)}i.data.splice(t,e)}_sync(t){if(this._parsing)this._syncList.push(t);else{const[e,i,s]=t;this[e](i,s)}this.chart._dataChanges.push([this.index,...t])}_onDataPush(){const t=arguments.length;this._sync(["_insertElements",this.getDataset().data.length-t,t])}_onDataPop(){this._sync(["_removeElements",this._cachedMeta.data.length-1,1])}_onDataShift(){this._sync(["_removeElements",0,1])}_onDataSplice(t,e){e&&this._sync(["_removeElements",t,e]);const i=arguments.length-2;i&&this._sync(["_insertElements",t,i])}_onDataUnshift(){this._sync(["_insertElements",0,arguments.length])}}class Hs{static defaults={};static defaultRoutes=void 0;x;y;active=!1;options;$animations;tooltipPosition(t){const{x:e,y:i}=this.getProps(["x","y"],t);return{x:e,y:i}}hasValue(){return N(this.x)&&N(this.y)}getProps(t,e){const i=this.$animations;if(!e||!i)return this;const s={};return t.forEach((t=>{s[t]=i[t]&&i[t].active()?i[t]._to:this[t]})),s}}function js(t,e){const i=t.options.ticks,n=function(t){const e=t.options.offset,i=t._tickSize(),s=t._length/i+(e?0:1),n=t._maxLength/i;return Math.floor(Math.min(s,n))}(t),o=Math.min(i.maxTicksLimit||n,n),a=i.major.enabled?function(t){const e=[];let i,s;for(i=0,s=t.length;i<s;i++)t[i].major&&e.push(i);return e}(e):[],r=a.length,l=a[0],h=a[r-1],c=[];if(r>o)return function(t,e,i,s){let n,o=0,a=i[0];for(s=Math.ceil(s),n=0;n<t.length;n++)n===a&&(e.push(t[n]),o++,a=i[o*s])}(e,c,a,r/o),c;const d=function(t,e,i){const s=function(t){const e=t.length;let i,s;if(e<2)return!1;for(s=t[0],i=1;i<e;++i)if(t[i]-t[i-1]!==s)return!1;return s}(t),n=e.length/i;if(!s)return Math.max(n,1);const o=W(s);for(let t=0,e=o.length-1;t<e;t++){const e=o[t];if(e>n)return e}return Math.max(n,1)}(a,e,o);if(r>0){let t,i;const n=r>1?Math.round((h-l)/(r-1)):null;for($s(e,c,d,s(n)?0:l-n,l),t=0,i=r-1;t<i;t++)$s(e,c,d,a[t],a[t+1]);return $s(e,c,d,h,s(n)?e.length:h+n),c}return $s(e,c,d),c}function $s(t,e,i,s,n){const o=l(s,0),a=Math.min(l(n,t.length),t.length);let r,h,c,d=0;for(i=Math.ceil(i),n&&(r=n-s,i=r/Math.floor(r/i)),c=o;c<0;)d++,c=Math.round(o+d*i);for(h=Math.max(o,0);h<a;h++)h===c&&(e.push(t[h]),d++,c=Math.round(o+d*i))}const Ys=(t,e,i)=>"top"===e||"left"===e?t[e]+i:t[e]-i,Us=(t,e)=>Math.min(e||t,t);function Xs(t,e){const i=[],s=t.length/e,n=t.length;let o=0;for(;o<n;o+=s)i.push(t[Math.floor(o)]);return i}function qs(t,e,i){const s=t.ticks.length,n=Math.min(e,s-1),o=t._startPixel,a=t._endPixel,r=1e-6;let l,h=t.getPixelForTick(n);if(!(i&&(l=1===s?Math.max(h-o,a-h):0===e?(t.getPixelForTick(1)-h)/2:(h-t.getPixelForTick(n-1))/2,h+=n<e?l:-l,h<o-r||h>a+r)))return h}function Ks(t){return t.drawTicks?t.tickLength:0}function Gs(t,e){if(!t.display)return 0;const i=Si(t.font,e),s=ki(t.padding);return(n(t.text)?t.text.length:1)*i.lineHeight+s.height}function Zs(t,e,i){let s=ut(t);return(i&&"right"!==e||!i&&"right"===e)&&(s=(t=>"left"===t?"right":"right"===t?"left":t)(s)),s}class Js extends Hs{constructor(t){super(),this.id=t.id,this.type=t.type,this.options=void 0,this.ctx=t.ctx,this.chart=t.chart,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.width=void 0,this.height=void 0,this._margins={left:0,right:0,top:0,bottom:0},this.maxWidth=void 0,this.maxHeight=void 0,this.paddingTop=void 0,this.paddingBottom=void 0,this.paddingLeft=void 0,this.paddingRight=void 0,this.axis=void 0,this.labelRotation=void 0,this.min=void 0,this.max=void 0,this._range=void 0,this.ticks=[],this._gridLineItems=null,this._labelItems=null,this._labelSizes=null,this._length=0,this._maxLength=0,this._longestTextCache={},this._startPixel=void 0,this._endPixel=void 0,this._reversePixels=!1,this._userMax=void 0,this._userMin=void 0,this._suggestedMax=void 0,this._suggestedMin=void 0,this._ticksLength=0,this._borderValue=0,this._cache={},this._dataLimitsCached=!1,this.$context=void 0}init(t){this.options=t.setContext(this.getContext()),this.axis=t.axis,this._userMin=this.parse(t.min),this._userMax=this.parse(t.max),this._suggestedMin=this.parse(t.suggestedMin),this._suggestedMax=this.parse(t.suggestedMax)}parse(t,e){return t}getUserBounds(){let{_userMin:t,_userMax:e,_suggestedMin:i,_suggestedMax:s}=this;return t=r(t,Number.POSITIVE_INFINITY),e=r(e,Number.NEGATIVE_INFINITY),i=r(i,Number.POSITIVE_INFINITY),s=r(s,Number.NEGATIVE_INFINITY),{min:r(t,i),max:r(e,s),minDefined:a(t),maxDefined:a(e)}}getMinMax(t){let e,{min:i,max:s,minDefined:n,maxDefined:o}=this.getUserBounds();if(n&&o)return{min:i,max:s};const a=this.getMatchingVisibleMetas();for(let r=0,l=a.length;r<l;++r)e=a[r].controller.getMinMax(this,t),n||(i=Math.min(i,e.min)),o||(s=Math.max(s,e.max));return i=o&&i>s?s:i,s=n&&i>s?i:s,{min:r(i,r(s,i)),max:r(s,r(i,s))}}getPadding(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}}getTicks(){return this.ticks}getLabels(){const t=this.chart.data;return this.options.labels||(this.isHorizontal()?t.xLabels:t.yLabels)||t.labels||[]}getLabelItems(t=this.chart.chartArea){return this._labelItems||(this._labelItems=this._computeLabelItems(t))}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){d(this.options.beforeUpdate,[this])}update(t,e,i){const{beginAtZero:s,grace:n,ticks:o}=this.options,a=o.sampleSize;this.beforeUpdate(),this.maxWidth=t,this.maxHeight=e,this._margins=i=Object.assign({left:0,right:0,top:0,bottom:0},i),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+i.left+i.right:this.height+i.top+i.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=Di(this,n,s),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const r=a<this.ticks.length;this._convertTicksToLabels(r?Xs(this.ticks,a):this.ticks),this.configure(),this.beforeCalculateLabelRotation(),this.calculateLabelRotation(),this.afterCalculateLabelRotation(),o.display&&(o.autoSkip||"auto"===o.source)&&(this.ticks=js(this,this.ticks),this._labelSizes=null,this.afterAutoSkip()),r&&this._convertTicksToLabels(this.ticks),this.beforeFit(),this.fit(),this.afterFit(),this.afterUpdate()}configure(){let t,e,i=this.options.reverse;this.isHorizontal()?(t=this.left,e=this.right):(t=this.top,e=this.bottom,i=!i),this._startPixel=t,this._endPixel=e,this._reversePixels=i,this._length=e-t,this._alignToPixels=this.options.alignToPixels}afterUpdate(){d(this.options.afterUpdate,[this])}beforeSetDimensions(){d(this.options.beforeSetDimensions,[this])}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=0,this.right=this.width):(this.height=this.maxHeight,this.top=0,this.bottom=this.height),this.paddingLeft=0,this.paddingTop=0,this.paddingRight=0,this.paddingBottom=0}afterSetDimensions(){d(this.options.afterSetDimensions,[this])}_callHooks(t){this.chart.notifyPlugins(t,this.getContext()),d(this.options[t],[this])}beforeDataLimits(){this._callHooks("beforeDataLimits")}determineDataLimits(){}afterDataLimits(){this._callHooks("afterDataLimits")}beforeBuildTicks(){this._callHooks("beforeBuildTicks")}buildTicks(){return[]}afterBuildTicks(){this._callHooks("afterBuildTicks")}beforeTickToLabelConversion(){d(this.options.beforeTickToLabelConversion,[this])}generateTickLabels(t){const e=this.options.ticks;let i,s,n;for(i=0,s=t.length;i<s;i++)n=t[i],n.label=d(e.callback,[n.value,i,t],this)}afterTickToLabelConversion(){d(this.options.afterTickToLabelConversion,[this])}beforeCalculateLabelRotation(){d(this.options.beforeCalculateLabelRotation,[this])}calculateLabelRotation(){const t=this.options,e=t.ticks,i=Us(this.ticks.length,t.ticks.maxTicksLimit),s=e.minRotation||0,n=e.maxRotation;let o,a,r,l=s;if(!this._isVisible()||!e.display||s>=n||i<=1||!this.isHorizontal())return void(this.labelRotation=s);const h=this._getLabelSizes(),c=h.widest.width,d=h.highest.height,u=J(this.chart.width-c,0,this.maxWidth);o=t.offset?this.maxWidth/i:u/(i-1),c+6>o&&(o=u/(i-(t.offset?.5:1)),a=this.maxHeight-Ks(t.grid)-e.padding-Gs(t.title,this.chart.options.font),r=Math.sqrt(c*c+d*d),l=Y(Math.min(Math.asin(J((h.highest.height+6)/o,-1,1)),Math.asin(J(a/r,-1,1))-Math.asin(J(d/r,-1,1)))),l=Math.max(s,Math.min(n,l))),this.labelRotation=l}afterCalculateLabelRotation(){d(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){d(this.options.beforeFit,[this])}fit(){const t={width:0,height:0},{chart:e,options:{ticks:i,title:s,grid:n}}=this,o=this._isVisible(),a=this.isHorizontal();if(o){const o=Gs(s,e.options.font);if(a?(t.width=this.maxWidth,t.height=Ks(n)+o):(t.height=this.maxHeight,t.width=Ks(n)+o),i.display&&this.ticks.length){const{first:e,last:s,widest:n,highest:o}=this._getLabelSizes(),r=2*i.padding,l=$(this.labelRotation),h=Math.cos(l),c=Math.sin(l);if(a){const e=i.mirror?0:c*n.width+h*o.height;t.height=Math.min(this.maxHeight,t.height+e+r)}else{const e=i.mirror?0:h*n.width+c*o.height;t.width=Math.min(this.maxWidth,t.width+e+r)}this._calculatePadding(e,s,c,h)}}this._handleMargins(),a?(this.width=this._length=e.width-this._margins.left-this._margins.right,this.height=t.height):(this.width=t.width,this.height=this._length=e.height-this._margins.top-this._margins.bottom)}_calculatePadding(t,e,i,s){const{ticks:{align:n,padding:o},position:a}=this.options,r=0!==this.labelRotation,l="top"!==a&&"x"===this.axis;if(this.isHorizontal()){const a=this.getPixelForTick(0)-this.left,h=this.right-this.getPixelForTick(this.ticks.length-1);let c=0,d=0;r?l?(c=s*t.width,d=i*e.height):(c=i*t.height,d=s*e.width):"start"===n?d=e.width:"end"===n?c=t.width:"inner"!==n&&(c=t.width/2,d=e.width/2),this.paddingLeft=Math.max((c-a+o)*this.width/(this.width-a),0),this.paddingRight=Math.max((d-h+o)*this.width/(this.width-h),0)}else{let i=e.height/2,s=t.height/2;"start"===n?(i=0,s=t.height):"end"===n&&(i=e.height,s=0),this.paddingTop=i+o,this.paddingBottom=s+o}}_handleMargins(){this._margins&&(this._margins.left=Math.max(this.paddingLeft,this._margins.left),this._margins.top=Math.max(this.paddingTop,this._margins.top),this._margins.right=Math.max(this.paddingRight,this._margins.right),this._margins.bottom=Math.max(this.paddingBottom,this._margins.bottom))}afterFit(){d(this.options.afterFit,[this])}isHorizontal(){const{axis:t,position:e}=this.options;return"top"===e||"bottom"===e||"x"===t}isFullSize(){return this.options.fullSize}_convertTicksToLabels(t){let e,i;for(this.beforeTickToLabelConversion(),this.generateTickLabels(t),e=0,i=t.length;e<i;e++)s(t[e].label)&&(t.splice(e,1),i--,e--);this.afterTickToLabelConversion()}_getLabelSizes(){let t=this._labelSizes;if(!t){const e=this.options.ticks.sampleSize;let i=this.ticks;e<i.length&&(i=Xs(i,e)),this._labelSizes=t=this._computeLabelSizes(i,i.length,this.options.ticks.maxTicksLimit)}return t}_computeLabelSizes(t,e,i){const{ctx:o,_longestTextCache:a}=this,r=[],l=[],h=Math.floor(e/Us(e,i));let c,d,f,g,p,m,x,b,_,y,v,M=0,w=0;for(c=0;c<e;c+=h){if(g=t[c].label,p=this._resolveTickFontOptions(c),o.font=m=p.string,x=a[m]=a[m]||{data:{},gc:[]},b=p.lineHeight,_=y=0,s(g)||n(g)){if(n(g))for(d=0,f=g.length;d<f;++d)v=g[d],s(v)||n(v)||(_=Ce(o,x.data,x.gc,_,v),y+=b)}else _=Ce(o,x.data,x.gc,_,g),y=b;r.push(_),l.push(y),M=Math.max(_,M),w=Math.max(y,w)}!function(t,e){u(t,(t=>{const i=t.gc,s=i.length/2;let n;if(s>e){for(n=0;n<s;++n)delete t.data[i[n]];i.splice(0,s)}}))}(a,e);const k=r.indexOf(M),S=l.indexOf(w),P=t=>({width:r[t]||0,height:l[t]||0});return{first:P(0),last:P(e-1),widest:P(k),highest:P(S),widths:r,heights:l}}getLabelForValue(t){return t}getPixelForValue(t,e){return NaN}getValueForPixel(t){}getPixelForTick(t){const e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t].value)}getPixelForDecimal(t){this._reversePixels&&(t=1-t);const e=this._startPixel+t*this._length;return Q(this._alignToPixels?Ae(this.chart,e,0):e)}getDecimalForPixel(t){const e=(t-this._startPixel)/this._length;return this._reversePixels?1-e:e}getBasePixel(){return this.getPixelForValue(this.getBaseValue())}getBaseValue(){const{min:t,max:e}=this;return t<0&&e<0?e:t>0&&e>0?t:0}getContext(t){const e=this.ticks||[];if(t>=0&&t<e.length){const i=e[t];return i.$context||(i.$context=function(t,e,i){return Ci(t,{tick:i,index:e,type:"tick"})}(this.getContext(),t,i))}return this.$context||(this.$context=Ci(this.chart.getContext(),{scale:this,type:"scale"}))}_tickSize(){const t=this.options.ticks,e=$(this.labelRotation),i=Math.abs(Math.cos(e)),s=Math.abs(Math.sin(e)),n=this._getLabelSizes(),o=t.autoSkipPadding||0,a=n?n.widest.width+o:0,r=n?n.highest.height+o:0;return this.isHorizontal()?r*i>a*s?a/i:r/s:r*s<a*i?r/i:a/s}_isVisible(){const t=this.options.display;return"auto"!==t?!!t:this.getMatchingVisibleMetas().length>0}_computeGridLineItems(t){const e=this.axis,i=this.chart,s=this.options,{grid:n,position:a,border:r}=s,h=n.offset,c=this.isHorizontal(),d=this.ticks.length+(h?1:0),u=Ks(n),f=[],g=r.setContext(this.getContext()),p=g.display?g.width:0,m=p/2,x=function(t){return Ae(i,t,p)};let b,_,y,v,M,w,k,S,P,D,C,O;if("top"===a)b=x(this.bottom),w=this.bottom-u,S=b-m,D=x(t.top)+m,O=t.bottom;else if("bottom"===a)b=x(this.top),D=t.top,O=x(t.bottom)-m,w=b+m,S=this.top+u;else if("left"===a)b=x(this.right),M=this.right-u,k=b-m,P=x(t.left)+m,C=t.right;else if("right"===a)b=x(this.left),P=t.left,C=x(t.right)-m,M=b+m,k=this.left+u;else if("x"===e){if("center"===a)b=x((t.top+t.bottom)/2+.5);else if(o(a)){const t=Object.keys(a)[0],e=a[t];b=x(this.chart.scales[t].getPixelForValue(e))}D=t.top,O=t.bottom,w=b+m,S=w+u}else if("y"===e){if("center"===a)b=x((t.left+t.right)/2);else if(o(a)){const t=Object.keys(a)[0],e=a[t];b=x(this.chart.scales[t].getPixelForValue(e))}M=b-m,k=M-u,P=t.left,C=t.right}const A=l(s.ticks.maxTicksLimit,d),T=Math.max(1,Math.ceil(d/A));for(_=0;_<d;_+=T){const t=this.getContext(_),e=n.setContext(t),s=r.setContext(t),o=e.lineWidth,a=e.color,l=s.dash||[],d=s.dashOffset,u=e.tickWidth,g=e.tickColor,p=e.tickBorderDash||[],m=e.tickBorderDashOffset;y=qs(this,_,h),void 0!==y&&(v=Ae(i,y,o),c?M=k=P=C=v:w=S=D=O=v,f.push({tx1:M,ty1:w,tx2:k,ty2:S,x1:P,y1:D,x2:C,y2:O,width:o,color:a,borderDash:l,borderDashOffset:d,tickWidth:u,tickColor:g,tickBorderDash:p,tickBorderDashOffset:m}))}return this._ticksLength=d,this._borderValue=b,f}_computeLabelItems(t){const e=this.axis,i=this.options,{position:s,ticks:a}=i,r=this.isHorizontal(),l=this.ticks,{align:h,crossAlign:c,padding:d,mirror:u}=a,f=Ks(i.grid),g=f+d,p=u?-d:g,m=-$(this.labelRotation),x=[];let b,_,y,v,M,w,k,S,P,D,C,O,A="middle";if("top"===s)w=this.bottom-p,k=this._getXAxisLabelAlignment();else if("bottom"===s)w=this.top+p,k=this._getXAxisLabelAlignment();else if("left"===s){const t=this._getYAxisLabelAlignment(f);k=t.textAlign,M=t.x}else if("right"===s){const t=this._getYAxisLabelAlignment(f);k=t.textAlign,M=t.x}else if("x"===e){if("center"===s)w=(t.top+t.bottom)/2+g;else if(o(s)){const t=Object.keys(s)[0],e=s[t];w=this.chart.scales[t].getPixelForValue(e)+g}k=this._getXAxisLabelAlignment()}else if("y"===e){if("center"===s)M=(t.left+t.right)/2-g;else if(o(s)){const t=Object.keys(s)[0],e=s[t];M=this.chart.scales[t].getPixelForValue(e)}k=this._getYAxisLabelAlignment(f).textAlign}"y"===e&&("start"===h?A="top":"end"===h&&(A="bottom"));const T=this._getLabelSizes();for(b=0,_=l.length;b<_;++b){y=l[b],v=y.label;const t=a.setContext(this.getContext(b));S=this.getPixelForTick(b)+a.labelOffset,P=this._resolveTickFontOptions(b),D=P.lineHeight,C=n(v)?v.length:1;const e=C/2,i=t.color,o=t.textStrokeColor,h=t.textStrokeWidth;let d,f=k;if(r?(M=S,"inner"===k&&(f=b===_-1?this.options.reverse?"left":"right":0===b?this.options.reverse?"right":"left":"center"),O="top"===s?"near"===c||0!==m?-C*D+D/2:"center"===c?-T.highest.height/2-e*D+D:-T.highest.height+D/2:"near"===c||0!==m?D/2:"center"===c?T.highest.height/2-e*D:T.highest.height-C*D,u&&(O*=-1),0===m||t.showLabelBackdrop||(M+=D/2*Math.sin(m))):(w=S,O=(1-C)*D/2),t.showLabelBackdrop){const e=ki(t.backdropPadding),i=T.heights[b],s=T.widths[b];let n=O-e.top,o=0-e.left;switch(A){case"middle":n-=i/2;break;case"bottom":n-=i}switch(k){case"center":o-=s/2;break;case"right":o-=s;break;case"inner":b===_-1?o-=s:b>0&&(o-=s/2)}d={left:o,top:n,width:s+e.width,height:i+e.height,color:t.backdropColor}}x.push({label:v,font:P,textOffset:O,options:{rotation:m,color:i,strokeColor:o,strokeWidth:h,textAlign:f,textBaseline:A,translation:[M,w],backdrop:d}})}return x}_getXAxisLabelAlignment(){const{position:t,ticks:e}=this.options;if(-$(this.labelRotation))return"top"===t?"left":"right";let i="center";return"start"===e.align?i="left":"end"===e.align?i="right":"inner"===e.align&&(i="inner"),i}_getYAxisLabelAlignment(t){const{position:e,ticks:{crossAlign:i,mirror:s,padding:n}}=this.options,o=t+n,a=this._getLabelSizes().widest.width;let r,l;return"left"===e?s?(l=this.right+n,"near"===i?r="left":"center"===i?(r="center",l+=a/2):(r="right",l+=a)):(l=this.right-o,"near"===i?r="right":"center"===i?(r="center",l-=a/2):(r="left",l=this.left)):"right"===e?s?(l=this.left+n,"near"===i?r="right":"center"===i?(r="center",l-=a/2):(r="left",l-=a)):(l=this.left+o,"near"===i?r="left":"center"===i?(r="center",l+=a/2):(r="right",l=this.right)):r="right",{textAlign:r,x:l}}_computeLabelArea(){if(this.options.ticks.mirror)return;const t=this.chart,e=this.options.position;return"left"===e||"right"===e?{top:0,left:this.left,bottom:t.height,right:this.right}:"top"===e||"bottom"===e?{top:this.top,left:0,bottom:this.bottom,right:t.width}:void 0}drawBackground(){const{ctx:t,options:{backgroundColor:e},left:i,top:s,width:n,height:o}=this;e&&(t.save(),t.fillStyle=e,t.fillRect(i,s,n,o),t.restore())}getLineWidthForValue(t){const e=this.options.grid;if(!this._isVisible()||!e.display)return 0;const i=this.ticks.findIndex((e=>e.value===t));if(i>=0){return e.setContext(this.getContext(i)).lineWidth}return 0}drawGrid(t){const e=this.options.grid,i=this.ctx,s=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(t));let n,o;const a=(t,e,s)=>{s.width&&s.color&&(i.save(),i.lineWidth=s.width,i.strokeStyle=s.color,i.setLineDash(s.borderDash||[]),i.lineDashOffset=s.borderDashOffset,i.beginPath(),i.moveTo(t.x,t.y),i.lineTo(e.x,e.y),i.stroke(),i.restore())};if(e.display)for(n=0,o=s.length;n<o;++n){const t=s[n];e.drawOnChartArea&&a({x:t.x1,y:t.y1},{x:t.x2,y:t.y2},t),e.drawTicks&&a({x:t.tx1,y:t.ty1},{x:t.tx2,y:t.ty2},{color:t.tickColor,width:t.tickWidth,borderDash:t.tickBorderDash,borderDashOffset:t.tickBorderDashOffset})}}drawBorder(){const{chart:t,ctx:e,options:{border:i,grid:s}}=this,n=i.setContext(this.getContext()),o=i.display?n.width:0;if(!o)return;const a=s.setContext(this.getContext(0)).lineWidth,r=this._borderValue;let l,h,c,d;this.isHorizontal()?(l=Ae(t,this.left,o)-o/2,h=Ae(t,this.right,a)+a/2,c=d=r):(c=Ae(t,this.top,o)-o/2,d=Ae(t,this.bottom,a)+a/2,l=h=r),e.save(),e.lineWidth=n.width,e.strokeStyle=n.color,e.beginPath(),e.moveTo(l,c),e.lineTo(h,d),e.stroke(),e.restore()}drawLabels(t){if(!this.options.ticks.display)return;const e=this.ctx,i=this._computeLabelArea();i&&Ie(e,i);const s=this.getLabelItems(t);for(const t of s){const i=t.options,s=t.font;Ne(e,t.label,0,t.textOffset,s,i)}i&&ze(e)}drawTitle(){const{ctx:t,options:{position:e,title:i,reverse:s}}=this;if(!i.display)return;const a=Si(i.font),r=ki(i.padding),l=i.align;let h=a.lineHeight/2;"bottom"===e||"center"===e||o(e)?(h+=r.bottom,n(i.text)&&(h+=a.lineHeight*(i.text.length-1))):h+=r.top;const{titleX:c,titleY:d,maxWidth:u,rotation:f}=function(t,e,i,s){const{top:n,left:a,bottom:r,right:l,chart:h}=t,{chartArea:c,scales:d}=h;let u,f,g,p=0;const m=r-n,x=l-a;if(t.isHorizontal()){if(f=ft(s,a,l),o(i)){const t=Object.keys(i)[0],s=i[t];g=d[t].getPixelForValue(s)+m-e}else g="center"===i?(c.bottom+c.top)/2+m-e:Ys(t,i,e);u=l-a}else{if(o(i)){const t=Object.keys(i)[0],s=i[t];f=d[t].getPixelForValue(s)-x+e}else f="center"===i?(c.left+c.right)/2-x+e:Ys(t,i,e);g=ft(s,r,n),p="left"===i?-E:E}return{titleX:f,titleY:g,maxWidth:u,rotation:p}}(this,h,e,l);Ne(t,i.text,0,0,a,{color:i.color,maxWidth:u,rotation:f,textAlign:Zs(l,e,s),textBaseline:"middle",translation:[c,d]})}draw(t){this._isVisible()&&(this.drawBackground(),this.drawGrid(t),this.drawBorder(),this.drawTitle(),this.drawLabels(t))}_layers(){const t=this.options,e=t.ticks&&t.ticks.z||0,i=l(t.grid&&t.grid.z,-1),s=l(t.border&&t.border.z,0);return this._isVisible()&&this.draw===Js.prototype.draw?[{z:i,draw:t=>{this.drawBackground(),this.drawGrid(t),this.drawTitle()}},{z:s,draw:()=>{this.drawBorder()}},{z:e,draw:t=>{this.drawLabels(t)}}]:[{z:e,draw:t=>{this.draw(t)}}]}getMatchingVisibleMetas(t){const e=this.chart.getSortedVisibleDatasetMetas(),i=this.axis+"AxisID",s=[];let n,o;for(n=0,o=e.length;n<o;++n){const o=e[n];o[i]!==this.id||t&&o.type!==t||s.push(o)}return s}_resolveTickFontOptions(t){return Si(this.options.ticks.setContext(this.getContext(t)).font)}_maxDigits(){const t=this._resolveTickFontOptions(0).lineHeight;return(this.isHorizontal()?this.width:this.height)/t}}class Qs{constructor(t,e,i){this.type=t,this.scope=e,this.override=i,this.items=Object.create(null)}isForType(t){return Object.prototype.isPrototypeOf.call(this.type.prototype,t.prototype)}register(t){const e=Object.getPrototypeOf(t);let i;(function(t){return"id"in t&&"defaults"in t})(e)&&(i=this.register(e));const s=this.items,n=t.id,o=this.scope+"."+n;if(!n)throw new Error("class does not have id: "+t);return n in s||(s[n]=t,function(t,e,i){const s=x(Object.create(null),[i?ue.get(i):{},ue.get(e),t.defaults]);ue.set(e,s),t.defaultRoutes&&function(t,e){Object.keys(e).forEach((i=>{const s=i.split("."),n=s.pop(),o=[t].concat(s).join("."),a=e[i].split("."),r=a.pop(),l=a.join(".");ue.route(o,n,l,r)}))}(e,t.defaultRoutes);t.descriptors&&ue.describe(e,t.descriptors)}(t,o,i),this.override&&ue.override(t.id,t.overrides)),o}get(t){return this.items[t]}unregister(t){const e=this.items,i=t.id,s=this.scope;i in e&&delete e[i],s&&i in ue[s]&&(delete ue[s][i],this.override&&delete re[i])}}class tn{constructor(){this.controllers=new Qs(Ns,"datasets",!0),this.elements=new Qs(Hs,"elements"),this.plugins=new Qs(Object,"plugins"),this.scales=new Qs(Js,"scales"),this._typedRegistries=[this.controllers,this.scales,this.elements]}add(...t){this._each("register",t)}remove(...t){this._each("unregister",t)}addControllers(...t){this._each("register",t,this.controllers)}addElements(...t){this._each("register",t,this.elements)}addPlugins(...t){this._each("register",t,this.plugins)}addScales(...t){this._each("register",t,this.scales)}getController(t){return this._get(t,this.controllers,"controller")}getElement(t){return this._get(t,this.elements,"element")}getPlugin(t){return this._get(t,this.plugins,"plugin")}getScale(t){return this._get(t,this.scales,"scale")}removeControllers(...t){this._each("unregister",t,this.controllers)}removeElements(...t){this._each("unregister",t,this.elements)}removePlugins(...t){this._each("unregister",t,this.plugins)}removeScales(...t){this._each("unregister",t,this.scales)}_each(t,e,i){[...e].forEach((e=>{const s=i||this._getRegistryForType(e);i||s.isForType(e)||s===this.plugins&&e.id?this._exec(t,s,e):u(e,(e=>{const s=i||this._getRegistryForType(e);this._exec(t,s,e)}))}))}_exec(t,e,i){const s=w(t);d(i["before"+s],[],i),e[t](i),d(i["after"+s],[],i)}_getRegistryForType(t){for(let e=0;e<this._typedRegistries.length;e++){const i=this._typedRegistries[e];if(i.isForType(t))return i}return this.plugins}_get(t,e,i){const s=e.get(t);if(void 0===s)throw new Error('"'+t+'" is not a registered '+i+".");return s}}var en=new tn;class sn{constructor(){this._init=[]}notify(t,e,i,s){"beforeInit"===e&&(this._init=this._createDescriptors(t,!0),this._notify(this._init,t,"install"));const n=s?this._descriptors(t).filter(s):this._descriptors(t),o=this._notify(n,t,e,i);return"afterDestroy"===e&&(this._notify(n,t,"stop"),this._notify(this._init,t,"uninstall")),o}_notify(t,e,i,s){s=s||{};for(const n of t){const t=n.plugin;if(!1===d(t[i],[e,s,n.options],t)&&s.cancelable)return!1}return!0}invalidate(){s(this._cache)||(this._oldCache=this._cache,this._cache=void 0)}_descriptors(t){if(this._cache)return this._cache;const e=this._cache=this._createDescriptors(t);return this._notifyStateChanges(t),e}_createDescriptors(t,e){const i=t&&t.config,s=l(i.options&&i.options.plugins,{}),n=function(t){const e={},i=[],s=Object.keys(en.plugins.items);for(let t=0;t<s.length;t++)i.push(en.getPlugin(s[t]));const n=t.plugins||[];for(let t=0;t<n.length;t++){const s=n[t];-1===i.indexOf(s)&&(i.push(s),e[s.id]=!0)}return{plugins:i,localIds:e}}(i);return!1!==s||e?function(t,{plugins:e,localIds:i},s,n){const o=[],a=t.getContext();for(const r of e){const e=r.id,l=nn(s[e],n);null!==l&&o.push({plugin:r,options:on(t.config,{plugin:r,local:i[e]},l,a)})}return o}(t,n,s,e):[]}_notifyStateChanges(t){const e=this._oldCache||[],i=this._cache,s=(t,e)=>t.filter((t=>!e.some((e=>t.plugin.id===e.plugin.id))));this._notify(s(e,i),t,"stop"),this._notify(s(i,e),t,"start")}}function nn(t,e){return e||!1!==t?!0===t?{}:t:null}function on(t,{plugin:e,local:i},s,n){const o=t.pluginScopeKeys(e),a=t.getOptionScopes(s,o);return i&&e.defaults&&a.push(e.defaults),t.createResolver(a,n,[""],{scriptable:!1,indexable:!1,allKeys:!0})}function an(t,e){const i=ue.datasets[t]||{};return((e.datasets||{})[t]||{}).indexAxis||e.indexAxis||i.indexAxis||"x"}function rn(t){if("x"===t||"y"===t||"r"===t)return t}function ln(t,...e){if(rn(t))return t;for(const s of e){const e=s.axis||("top"===(i=s.position)||"bottom"===i?"x":"left"===i||"right"===i?"y":void 0)||t.length>1&&rn(t[0].toLowerCase());if(e)return e}var i;throw new Error(`Cannot determine type of '${t}' axis. Please provide 'axis' or 'position' option.`)}function hn(t,e,i){if(i[e+"AxisID"]===t)return{axis:e}}function cn(t,e){const i=re[t.type]||{scales:{}},s=e.scales||{},n=an(t.type,e),a=Object.create(null);return Object.keys(s).forEach((e=>{const r=s[e];if(!o(r))return console.error(`Invalid scale configuration for scale: ${e}`);if(r._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${e}`);const l=ln(e,r,function(t,e){if(e.data&&e.data.datasets){const i=e.data.datasets.filter((e=>e.xAxisID===t||e.yAxisID===t));if(i.length)return hn(t,"x",i[0])||hn(t,"y",i[0])}return{}}(e,t),ue.scales[r.type]),h=function(t,e){return t===e?"_index_":"_value_"}(l,n),c=i.scales||{};a[e]=b(Object.create(null),[{axis:l},r,c[l],c[h]])})),t.data.datasets.forEach((i=>{const n=i.type||t.type,o=i.indexAxis||an(n,e),r=(re[n]||{}).scales||{};Object.keys(r).forEach((t=>{const e=function(t,e){let i=t;return"_index_"===t?i=e:"_value_"===t&&(i="x"===e?"y":"x"),i}(t,o),n=i[e+"AxisID"]||e;a[n]=a[n]||Object.create(null),b(a[n],[{axis:e},s[n],r[t]])}))})),Object.keys(a).forEach((t=>{const e=a[t];b(e,[ue.scales[e.type],ue.scale])})),a}function dn(t){const e=t.options||(t.options={});e.plugins=l(e.plugins,{}),e.scales=cn(t,e)}function un(t){return(t=t||{}).datasets=t.datasets||[],t.labels=t.labels||[],t}const fn=new Map,gn=new Set;function pn(t,e){let i=fn.get(t);return i||(i=e(),fn.set(t,i),gn.add(i)),i}const mn=(t,e,i)=>{const s=M(e,i);void 0!==s&&t.add(s)};class xn{constructor(t){this._config=function(t){return(t=t||{}).data=un(t.data),dn(t),t}(t),this._scopeCache=new Map,this._resolverCache=new Map}get platform(){return this._config.platform}get type(){return this._config.type}set type(t){this._config.type=t}get data(){return this._config.data}set data(t){this._config.data=un(t)}get options(){return this._config.options}set options(t){this._config.options=t}get plugins(){return this._config.plugins}update(){const t=this._config;this.clearCache(),dn(t)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(t){return pn(t,(()=>[[`datasets.${t}`,""]]))}datasetAnimationScopeKeys(t,e){return pn(`${t}.transition.${e}`,(()=>[[`datasets.${t}.transitions.${e}`,`transitions.${e}`],[`datasets.${t}`,""]]))}datasetElementScopeKeys(t,e){return pn(`${t}-${e}`,(()=>[[`datasets.${t}.elements.${e}`,`datasets.${t}`,`elements.${e}`,""]]))}pluginScopeKeys(t){const e=t.id;return pn(`${this.type}-plugin-${e}`,(()=>[[`plugins.${e}`,...t.additionalOptionScopes||[]]]))}_cachedScopes(t,e){const i=this._scopeCache;let s=i.get(t);return s&&!e||(s=new Map,i.set(t,s)),s}getOptionScopes(t,e,i){const{options:s,type:n}=this,o=this._cachedScopes(t,i),a=o.get(e);if(a)return a;const r=new Set;e.forEach((e=>{t&&(r.add(t),e.forEach((e=>mn(r,t,e)))),e.forEach((t=>mn(r,s,t))),e.forEach((t=>mn(r,re[n]||{},t))),e.forEach((t=>mn(r,ue,t))),e.forEach((t=>mn(r,le,t)))}));const l=Array.from(r);return 0===l.length&&l.push(Object.create(null)),gn.has(e)&&o.set(e,l),l}chartOptionScopes(){const{options:t,type:e}=this;return[t,re[e]||{},ue.datasets[e]||{},{type:e},ue,le]}resolveNamedOptions(t,e,i,s=[""]){const o={$shared:!0},{resolver:a,subPrefixes:r}=bn(this._resolverCache,t,s);let l=a;if(function(t,e){const{isScriptable:i,isIndexable:s}=Ye(t);for(const o of e){const e=i(o),a=s(o),r=(a||e)&&t[o];if(e&&(S(r)||_n(r))||a&&n(r))return!0}return!1}(a,e)){o.$shared=!1;l=$e(a,i=S(i)?i():i,this.createResolver(t,i,r))}for(const t of e)o[t]=l[t];return o}createResolver(t,e,i=[""],s){const{resolver:n}=bn(this._resolverCache,t,i);return o(e)?$e(n,e,void 0,s):n}}function bn(t,e,i){let s=t.get(e);s||(s=new Map,t.set(e,s));const n=i.join();let o=s.get(n);if(!o){o={resolver:je(e,i),subPrefixes:i.filter((t=>!t.toLowerCase().includes("hover")))},s.set(n,o)}return o}const _n=t=>o(t)&&Object.getOwnPropertyNames(t).some((e=>S(t[e])));const yn=["top","bottom","left","right","chartArea"];function vn(t,e){return"top"===t||"bottom"===t||-1===yn.indexOf(t)&&"x"===e}function Mn(t,e){return function(i,s){return i[t]===s[t]?i[e]-s[e]:i[t]-s[t]}}function wn(t){const e=t.chart,i=e.options.animation;e.notifyPlugins("afterRender"),d(i&&i.onComplete,[t],e)}function kn(t){const e=t.chart,i=e.options.animation;d(i&&i.onProgress,[t],e)}function Sn(t){return fe()&&"string"==typeof t?t=document.getElementById(t):t&&t.length&&(t=t[0]),t&&t.canvas&&(t=t.canvas),t}const Pn={},Dn=t=>{const e=Sn(t);return Object.values(Pn).filter((t=>t.canvas===e)).pop()};function Cn(t,e,i){const s=Object.keys(t);for(const n of s){const s=+n;if(s>=e){const o=t[n];delete t[n],(i>0||s>e)&&(t[s+i]=o)}}}function On(t,e,i){return t.options.clip?t[i]:e[i]}class An{static defaults=ue;static instances=Pn;static overrides=re;static registry=en;static version="4.4.3";static getChart=Dn;static register(...t){en.add(...t),Tn()}static unregister(...t){en.remove(...t),Tn()}constructor(t,e){const s=this.config=new xn(e),n=Sn(t),o=Dn(n);if(o)throw new Error("Canvas is already in use. Chart with ID '"+o.id+"' must be destroyed before the canvas with ID '"+o.canvas.id+"' can be reused.");const a=s.createResolver(s.chartOptionScopes(),this.getContext());this.platform=new(s.platform||ks(n)),this.platform.updateConfig(s);const r=this.platform.acquireContext(n,a.aspectRatio),l=r&&r.canvas,h=l&&l.height,c=l&&l.width;this.id=i(),this.ctx=r,this.canvas=l,this.width=c,this.height=h,this._options=a,this._aspectRatio=this.aspectRatio,this._layers=[],this._metasets=[],this._stacks=void 0,this.boxes=[],this.currentDevicePixelRatio=void 0,this.chartArea=void 0,this._active=[],this._lastEvent=void 0,this._listeners={},this._responsiveListeners=void 0,this._sortedMetasets=[],this.scales={},this._plugins=new sn,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=dt((t=>this.update(t)),a.resizeDelay||0),this._dataChanges=[],Pn[this.id]=this,r&&l?(bt.listen(this,"complete",wn),bt.listen(this,"progress",kn),this._initialize(),this.attached&&this.update()):console.error("Failed to create chart: can't acquire context from the given item")}get aspectRatio(){const{options:{aspectRatio:t,maintainAspectRatio:e},width:i,height:n,_aspectRatio:o}=this;return s(t)?e&&o?o:n?i/n:null:t}get data(){return this.config.data}set data(t){this.config.data=t}get options(){return this._options}set options(t){this.config.options=t}get registry(){return en}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():ke(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return Te(this.canvas,this.ctx),this}stop(){return bt.stop(this),this}resize(t,e){bt.running(this)?this._resizeBeforeDraw={width:t,height:e}:this._resize(t,e)}_resize(t,e){const i=this.options,s=this.canvas,n=i.maintainAspectRatio&&this.aspectRatio,o=this.platform.getMaximumSize(s,t,e,n),a=i.devicePixelRatio||this.platform.getDevicePixelRatio(),r=this.width?"resize":"attach";this.width=o.width,this.height=o.height,this._aspectRatio=this.aspectRatio,ke(this,a,!0)&&(this.notifyPlugins("resize",{size:o}),d(i.onResize,[this,o],this),this.attached&&this._doResize(r)&&this.render())}ensureScalesHaveIDs(){u(this.options.scales||{},((t,e)=>{t.id=e}))}buildOrUpdateScales(){const t=this.options,e=t.scales,i=this.scales,s=Object.keys(i).reduce(((t,e)=>(t[e]=!1,t)),{});let n=[];e&&(n=n.concat(Object.keys(e).map((t=>{const i=e[t],s=ln(t,i),n="r"===s,o="x"===s;return{options:i,dposition:n?"chartArea":o?"bottom":"left",dtype:n?"radialLinear":o?"category":"linear"}})))),u(n,(e=>{const n=e.options,o=n.id,a=ln(o,n),r=l(n.type,e.dtype);void 0!==n.position&&vn(n.position,a)===vn(e.dposition)||(n.position=e.dposition),s[o]=!0;let h=null;if(o in i&&i[o].type===r)h=i[o];else{h=new(en.getScale(r))({id:o,type:r,ctx:this.ctx,chart:this}),i[h.id]=h}h.init(n,t)})),u(s,((t,e)=>{t||delete i[e]})),u(i,(t=>{as.configure(this,t,t.options),as.addBox(this,t)}))}_updateMetasets(){const t=this._metasets,e=this.data.datasets.length,i=t.length;if(t.sort(((t,e)=>t.index-e.index)),i>e){for(let t=e;t<i;++t)this._destroyDatasetMeta(t);t.splice(e,i-e)}this._sortedMetasets=t.slice(0).sort(Mn("order","index"))}_removeUnreferencedMetasets(){const{_metasets:t,data:{datasets:e}}=this;t.length>e.length&&delete this._stacks,t.forEach(((t,i)=>{0===e.filter((e=>e===t._dataset)).length&&this._destroyDatasetMeta(i)}))}buildOrUpdateControllers(){const t=[],e=this.data.datasets;let i,s;for(this._removeUnreferencedMetasets(),i=0,s=e.length;i<s;i++){const s=e[i];let n=this.getDatasetMeta(i);const o=s.type||this.config.type;if(n.type&&n.type!==o&&(this._destroyDatasetMeta(i),n=this.getDatasetMeta(i)),n.type=o,n.indexAxis=s.indexAxis||an(o,this.options),n.order=s.order||0,n.index=i,n.label=""+s.label,n.visible=this.isDatasetVisible(i),n.controller)n.controller.updateIndex(i),n.controller.linkScales();else{const e=en.getController(o),{datasetElementType:s,dataElementType:a}=ue.datasets[o];Object.assign(e,{dataElementType:en.getElement(a),datasetElementType:s&&en.getElement(s)}),n.controller=new e(this,i),t.push(n.controller)}}return this._updateMetasets(),t}_resetElements(){u(this.data.datasets,((t,e)=>{this.getDatasetMeta(e).controller.reset()}),this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(t){const e=this.config;e.update();const i=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),s=this._animationsDisabled=!i.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),!1===this.notifyPlugins("beforeUpdate",{mode:t,cancelable:!0}))return;const n=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let o=0;for(let t=0,e=this.data.datasets.length;t<e;t++){const{controller:e}=this.getDatasetMeta(t),i=!s&&-1===n.indexOf(e);e.buildOrUpdateElements(i),o=Math.max(+e.getMaxOverflow(),o)}o=this._minPadding=i.layout.autoPadding?o:0,this._updateLayout(o),s||u(n,(t=>{t.reset()})),this._updateDatasets(t),this.notifyPlugins("afterUpdate",{mode:t}),this._layers.sort(Mn("z","_idx"));const{_active:a,_lastEvent:r}=this;r?this._eventHandler(r,!0):a.length&&this._updateHoverStyles(a,a,!0),this.render()}_updateScales(){u(this.scales,(t=>{as.removeBox(this,t)})),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const t=this.options,e=new Set(Object.keys(this._listeners)),i=new Set(t.events);P(e,i)&&!!this._responsiveListeners===t.responsive||(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:t}=this,e=this._getUniformDataChanges()||[];for(const{method:i,start:s,count:n}of e){Cn(t,s,"_removeElements"===i?-n:n)}}_getUniformDataChanges(){const t=this._dataChanges;if(!t||!t.length)return;this._dataChanges=[];const e=this.data.datasets.length,i=e=>new Set(t.filter((t=>t[0]===e)).map(((t,e)=>e+","+t.splice(1).join(",")))),s=i(0);for(let t=1;t<e;t++)if(!P(s,i(t)))return;return Array.from(s).map((t=>t.split(","))).map((t=>({method:t[1],start:+t[2],count:+t[3]})))}_updateLayout(t){if(!1===this.notifyPlugins("beforeLayout",{cancelable:!0}))return;as.update(this,this.width,this.height,t);const e=this.chartArea,i=e.width<=0||e.height<=0;this._layers=[],u(this.boxes,(t=>{i&&"chartArea"===t.position||(t.configure&&t.configure(),this._layers.push(...t._layers()))}),this),this._layers.forEach(((t,e)=>{t._idx=e})),this.notifyPlugins("afterLayout")}_updateDatasets(t){if(!1!==this.notifyPlugins("beforeDatasetsUpdate",{mode:t,cancelable:!0})){for(let t=0,e=this.data.datasets.length;t<e;++t)this.getDatasetMeta(t).controller.configure();for(let e=0,i=this.data.datasets.length;e<i;++e)this._updateDataset(e,S(t)?t({datasetIndex:e}):t);this.notifyPlugins("afterDatasetsUpdate",{mode:t})}}_updateDataset(t,e){const i=this.getDatasetMeta(t),s={meta:i,index:t,mode:e,cancelable:!0};!1!==this.notifyPlugins("beforeDatasetUpdate",s)&&(i.controller._update(e),s.cancelable=!1,this.notifyPlugins("afterDatasetUpdate",s))}render(){!1!==this.notifyPlugins("beforeRender",{cancelable:!0})&&(bt.has(this)?this.attached&&!bt.running(this)&&bt.start(this):(this.draw(),wn({chart:this})))}draw(){let t;if(this._resizeBeforeDraw){const{width:t,height:e}=this._resizeBeforeDraw;this._resize(t,e),this._resizeBeforeDraw=null}if(this.clear(),this.width<=0||this.height<=0)return;if(!1===this.notifyPlugins("beforeDraw",{cancelable:!0}))return;const e=this._layers;for(t=0;t<e.length&&e[t].z<=0;++t)e[t].draw(this.chartArea);for(this._drawDatasets();t<e.length;++t)e[t].draw(this.chartArea);this.notifyPlugins("afterDraw")}_getSortedDatasetMetas(t){const e=this._sortedMetasets,i=[];let s,n;for(s=0,n=e.length;s<n;++s){const n=e[s];t&&!n.visible||i.push(n)}return i}getSortedVisibleDatasetMetas(){return this._getSortedDatasetMetas(!0)}_drawDatasets(){if(!1===this.notifyPlugins("beforeDatasetsDraw",{cancelable:!0}))return;const t=this.getSortedVisibleDatasetMetas();for(let e=t.length-1;e>=0;--e)this._drawDataset(t[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(t){const e=this.ctx,i=t._clip,s=!i.disabled,n=function(t,e){const{xScale:i,yScale:s}=t;return i&&s?{left:On(i,e,"left"),right:On(i,e,"right"),top:On(s,e,"top"),bottom:On(s,e,"bottom")}:e}(t,this.chartArea),o={meta:t,index:t.index,cancelable:!0};!1!==this.notifyPlugins("beforeDatasetDraw",o)&&(s&&Ie(e,{left:!1===i.left?0:n.left-i.left,right:!1===i.right?this.width:n.right+i.right,top:!1===i.top?0:n.top-i.top,bottom:!1===i.bottom?this.height:n.bottom+i.bottom}),t.controller.draw(),s&&ze(e),o.cancelable=!1,this.notifyPlugins("afterDatasetDraw",o))}isPointInArea(t){return Re(t,this.chartArea,this._minPadding)}getElementsAtEventForMode(t,e,i,s){const n=Xi.modes[e];return"function"==typeof n?n(this,t,i,s):[]}getDatasetMeta(t){const e=this.data.datasets[t],i=this._metasets;let s=i.filter((t=>t&&t._dataset===e)).pop();return s||(s={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&&e.order||0,index:t,_dataset:e,_parsed:[],_sorted:!1},i.push(s)),s}getContext(){return this.$context||(this.$context=Ci(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(t){const e=this.data.datasets[t];if(!e)return!1;const i=this.getDatasetMeta(t);return"boolean"==typeof i.hidden?!i.hidden:!e.hidden}setDatasetVisibility(t,e){this.getDatasetMeta(t).hidden=!e}toggleDataVisibility(t){this._hiddenIndices[t]=!this._hiddenIndices[t]}getDataVisibility(t){return!this._hiddenIndices[t]}_updateVisibility(t,e,i){const s=i?"show":"hide",n=this.getDatasetMeta(t),o=n.controller._resolveAnimations(void 0,s);k(e)?(n.data[e].hidden=!i,this.update()):(this.setDatasetVisibility(t,i),o.update(n,{visible:i}),this.update((e=>e.datasetIndex===t?s:void 0)))}hide(t,e){this._updateVisibility(t,e,!1)}show(t,e){this._updateVisibility(t,e,!0)}_destroyDatasetMeta(t){const e=this._metasets[t];e&&e.controller&&e.controller._destroy(),delete this._metasets[t]}_stop(){let t,e;for(this.stop(),bt.remove(this),t=0,e=this.data.datasets.length;t<e;++t)this._destroyDatasetMeta(t)}destroy(){this.notifyPlugins("beforeDestroy");const{canvas:t,ctx:e}=this;this._stop(),this.config.clearCache(),t&&(this.unbindEvents(),Te(t,e),this.platform.releaseContext(e),this.canvas=null,this.ctx=null),delete Pn[this.id],this.notifyPlugins("afterDestroy")}toBase64Image(...t){return this.canvas.toDataURL(...t)}bindEvents(){this.bindUserEvents(),this.options.responsive?this.bindResponsiveEvents():this.attached=!0}bindUserEvents(){const t=this._listeners,e=this.platform,i=(i,s)=>{e.addEventListener(this,i,s),t[i]=s},s=(t,e,i)=>{t.offsetX=e,t.offsetY=i,this._eventHandler(t)};u(this.options.events,(t=>i(t,s)))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const t=this._responsiveListeners,e=this.platform,i=(i,s)=>{e.addEventListener(this,i,s),t[i]=s},s=(i,s)=>{t[i]&&(e.removeEventListener(this,i,s),delete t[i])},n=(t,e)=>{this.canvas&&this.resize(t,e)};let o;const a=()=>{s("attach",a),this.attached=!0,this.resize(),i("resize",n),i("detach",o)};o=()=>{this.attached=!1,s("resize",n),this._stop(),this._resize(0,0),i("attach",a)},e.isAttached(this.canvas)?a():o()}unbindEvents(){u(this._listeners,((t,e)=>{this.platform.removeEventListener(this,e,t)})),this._listeners={},u(this._responsiveListeners,((t,e)=>{this.platform.removeEventListener(this,e,t)})),this._responsiveListeners=void 0}updateHoverStyle(t,e,i){const s=i?"set":"remove";let n,o,a,r;for("dataset"===e&&(n=this.getDatasetMeta(t[0].datasetIndex),n.controller["_"+s+"DatasetHoverStyle"]()),a=0,r=t.length;a<r;++a){o=t[a];const e=o&&this.getDatasetMeta(o.datasetIndex).controller;e&&e[s+"HoverStyle"](o.element,o.datasetIndex,o.index)}}getActiveElements(){return this._active||[]}setActiveElements(t){const e=this._active||[],i=t.map((({datasetIndex:t,index:e})=>{const i=this.getDatasetMeta(t);if(!i)throw new Error("No dataset found at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}));!f(i,e)&&(this._active=i,this._lastEvent=null,this._updateHoverStyles(i,e))}notifyPlugins(t,e,i){return this._plugins.notify(this,t,e,i)}isPluginEnabled(t){return 1===this._plugins._cache.filter((e=>e.plugin.id===t)).length}_updateHoverStyles(t,e,i){const s=this.options.hover,n=(t,e)=>t.filter((t=>!e.some((e=>t.datasetIndex===e.datasetIndex&&t.index===e.index)))),o=n(e,t),a=i?t:n(t,e);o.length&&this.updateHoverStyle(o,s.mode,!1),a.length&&s.mode&&this.updateHoverStyle(a,s.mode,!0)}_eventHandler(t,e){const i={event:t,replay:e,cancelable:!0,inChartArea:this.isPointInArea(t)},s=e=>(e.options.events||this.options.events).includes(t.native.type);if(!1===this.notifyPlugins("beforeEvent",i,s))return;const n=this._handleEvent(t,e,i.inChartArea);return i.cancelable=!1,this.notifyPlugins("afterEvent",i,s),(n||i.changed)&&this.render(),this}_handleEvent(t,e,i){const{_active:s=[],options:n}=this,o=e,a=this._getActiveElements(t,s,i,o),r=D(t),l=function(t,e,i,s){return i&&"mouseout"!==t.type?s?e:t:null}(t,this._lastEvent,i,r);i&&(this._lastEvent=null,d(n.onHover,[t,a,this],this),r&&d(n.onClick,[t,a,this],this));const h=!f(a,s);return(h||e)&&(this._active=a,this._updateHoverStyles(a,s,e)),this._lastEvent=l,h}_getActiveElements(t,e,i,s){if("mouseout"===t.type)return[];if(!i)return e;const n=this.options.hover;return this.getElementsAtEventForMode(t,n.mode,n,s)}}function Tn(){return u(An.instances,(t=>t._plugins.invalidate()))}function Ln(){throw new Error("This method is not implemented: Check that a complete date adapter is provided.")}class En{static override(t){Object.assign(En.prototype,t)}options;constructor(t){this.options=t||{}}init(){}formats(){return Ln()}parse(){return Ln()}format(){return Ln()}add(){return Ln()}diff(){return Ln()}startOf(){return Ln()}endOf(){return Ln()}}var Rn={_date:En};function In(t){const e=t.iScale,i=function(t,e){if(!t._cache.$bar){const i=t.getMatchingVisibleMetas(e);let s=[];for(let e=0,n=i.length;e<n;e++)s=s.concat(i[e].controller.getAllParsedValues(t));t._cache.$bar=lt(s.sort(((t,e)=>t-e)))}return t._cache.$bar}(e,t.type);let s,n,o,a,r=e._length;const l=()=>{32767!==o&&-32768!==o&&(k(a)&&(r=Math.min(r,Math.abs(o-a)||r)),a=o)};for(s=0,n=i.length;s<n;++s)o=e.getPixelForValue(i[s]),l();for(a=void 0,s=0,n=e.ticks.length;s<n;++s)o=e.getPixelForTick(s),l();return r}function zn(t,e,i,s){return n(t)?function(t,e,i,s){const n=i.parse(t[0],s),o=i.parse(t[1],s),a=Math.min(n,o),r=Math.max(n,o);let l=a,h=r;Math.abs(a)>Math.abs(r)&&(l=r,h=a),e[i.axis]=h,e._custom={barStart:l,barEnd:h,start:n,end:o,min:a,max:r}}(t,e,i,s):e[i.axis]=i.parse(t,s),e}function Fn(t,e,i,s){const n=t.iScale,o=t.vScale,a=n.getLabels(),r=n===o,l=[];let h,c,d,u;for(h=i,c=i+s;h<c;++h)u=e[h],d={},d[n.axis]=r||n.parse(a[h],h),l.push(zn(u,d,o,h));return l}function Vn(t){return t&&void 0!==t.barStart&&void 0!==t.barEnd}function Bn(t,e,i,s){let n=e.borderSkipped;const o={};if(!n)return void(t.borderSkipped=o);if(!0===n)return void(t.borderSkipped={top:!0,right:!0,bottom:!0,left:!0});const{start:a,end:r,reverse:l,top:h,bottom:c}=function(t){let e,i,s,n,o;return t.horizontal?(e=t.base>t.x,i="left",s="right"):(e=t.base<t.y,i="bottom",s="top"),e?(n="end",o="start"):(n="start",o="end"),{start:i,end:s,reverse:e,top:n,bottom:o}}(t);"middle"===n&&i&&(t.enableBorderRadius=!0,(i._top||0)===s?n=h:(i._bottom||0)===s?n=c:(o[Wn(c,a,r,l)]=!0,n=h)),o[Wn(n,a,r,l)]=!0,t.borderSkipped=o}function Wn(t,e,i,s){var n,o,a;return s?(a=i,t=Nn(t=(n=t)===(o=e)?a:n===a?o:n,i,e)):t=Nn(t,e,i),t}function Nn(t,e,i){return"start"===t?e:"end"===t?i:t}function Hn(t,{inflateAmount:e},i){t.inflateAmount="auto"===e?1===i?.33:0:e}class jn extends Ns{static id="doughnut";static defaults={datasetElementType:!1,dataElementType:"arc",animation:{animateRotate:!0,animateScale:!1},animations:{numbers:{type:"number",properties:["circumference","endAngle","innerRadius","outerRadius","startAngle","x","y","offset","borderWidth","spacing"]}},cutout:"50%",rotation:0,circumference:360,radius:"100%",spacing:0,indexAxis:"r"};static descriptors={_scriptable:t=>"spacing"!==t,_indexable:t=>"spacing"!==t&&!t.startsWith("borderDash")&&!t.startsWith("hoverBorderDash")};static overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:i,color:s}}=t.legend.options;return e.labels.map(((e,n)=>{const o=t.getDatasetMeta(0).controller.getStyle(n);return{text:e,fillStyle:o.backgroundColor,strokeStyle:o.borderColor,fontColor:s,lineWidth:o.borderWidth,pointStyle:i,hidden:!t.getDataVisibility(n),index:n}}))}return[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}}};constructor(t,e){super(t,e),this.enableOptionSharing=!0,this.innerRadius=void 0,this.outerRadius=void 0,this.offsetX=void 0,this.offsetY=void 0}linkScales(){}parse(t,e){const i=this.getDataset().data,s=this._cachedMeta;if(!1===this._parsing)s._parsed=i;else{let n,a,r=t=>+i[t];if(o(i[t])){const{key:t="value"}=this._parsing;r=e=>+M(i[e],t)}for(n=t,a=t+e;n<a;++n)s._parsed[n]=r(n)}}_getRotation(){return $(this.options.rotation-90)}_getCircumference(){return $(this.options.circumference)}_getRotationExtents(){let t=O,e=-O;for(let i=0;i<this.chart.data.datasets.length;++i)if(this.chart.isDatasetVisible(i)&&this.chart.getDatasetMeta(i).type===this._type){const s=this.chart.getDatasetMeta(i).controller,n=s._getRotation(),o=s._getCircumference();t=Math.min(t,n),e=Math.max(e,n+o)}return{rotation:t,circumference:e-t}}update(t){const e=this.chart,{chartArea:i}=e,s=this._cachedMeta,n=s.data,o=this.getMaxBorderWidth()+this.getMaxOffset(n)+this.options.spacing,a=Math.max((Math.min(i.width,i.height)-o)/2,0),r=Math.min(h(this.options.cutout,a),1),l=this._getRingWeight(this.index),{circumference:d,rotation:u}=this._getRotationExtents(),{ratioX:f,ratioY:g,offsetX:p,offsetY:m}=function(t,e,i){let s=1,n=1,o=0,a=0;if(e<O){const r=t,l=r+e,h=Math.cos(r),c=Math.sin(r),d=Math.cos(l),u=Math.sin(l),f=(t,e,s)=>Z(t,r,l,!0)?1:Math.max(e,e*i,s,s*i),g=(t,e,s)=>Z(t,r,l,!0)?-1:Math.min(e,e*i,s,s*i),p=f(0,h,d),m=f(E,c,u),x=g(C,h,d),b=g(C+E,c,u);s=(p-x)/2,n=(m-b)/2,o=-(p+x)/2,a=-(m+b)/2}return{ratioX:s,ratioY:n,offsetX:o,offsetY:a}}(u,d,r),x=(i.width-o)/f,b=(i.height-o)/g,_=Math.max(Math.min(x,b)/2,0),y=c(this.options.radius,_),v=(y-Math.max(y*r,0))/this._getVisibleDatasetWeightTotal();this.offsetX=p*y,this.offsetY=m*y,s.total=this.calculateTotal(),this.outerRadius=y-v*this._getRingWeightOffset(this.index),this.innerRadius=Math.max(this.outerRadius-v*l,0),this.updateElements(n,0,n.length,t)}_circumference(t,e){const i=this.options,s=this._cachedMeta,n=this._getCircumference();return e&&i.animation.animateRotate||!this.chart.getDataVisibility(t)||null===s._parsed[t]||s.data[t].hidden?0:this.calculateCircumference(s._parsed[t]*n/O)}updateElements(t,e,i,s){const n="reset"===s,o=this.chart,a=o.chartArea,r=o.options.animation,l=(a.left+a.right)/2,h=(a.top+a.bottom)/2,c=n&&r.animateScale,d=c?0:this.innerRadius,u=c?0:this.outerRadius,{sharedOptions:f,includeOptions:g}=this._getSharedOptions(e,s);let p,m=this._getRotation();for(p=0;p<e;++p)m+=this._circumference(p,n);for(p=e;p<e+i;++p){const e=this._circumference(p,n),i=t[p],o={x:l+this.offsetX,y:h+this.offsetY,startAngle:m,endAngle:m+e,circumference:e,outerRadius:u,innerRadius:d};g&&(o.options=f||this.resolveDataElementOptions(p,i.active?"active":s)),m+=e,this.updateElement(i,p,o,s)}}calculateTotal(){const t=this._cachedMeta,e=t.data;let i,s=0;for(i=0;i<e.length;i++){const n=t._parsed[i];null===n||isNaN(n)||!this.chart.getDataVisibility(i)||e[i].hidden||(s+=Math.abs(n))}return s}calculateCircumference(t){const e=this._cachedMeta.total;return e>0&&!isNaN(t)?O*(Math.abs(t)/e):0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=ne(e._parsed[t],i.options.locale);return{label:s[t]||"",value:n}}getMaxBorderWidth(t){let e=0;const i=this.chart;let s,n,o,a,r;if(!t)for(s=0,n=i.data.datasets.length;s<n;++s)if(i.isDatasetVisible(s)){o=i.getDatasetMeta(s),t=o.data,a=o.controller;break}if(!t)return 0;for(s=0,n=t.length;s<n;++s)r=a.resolveDataElementOptions(s),"inner"!==r.borderAlign&&(e=Math.max(e,r.borderWidth||0,r.hoverBorderWidth||0));return e}getMaxOffset(t){let e=0;for(let i=0,s=t.length;i<s;++i){const t=this.resolveDataElementOptions(i);e=Math.max(e,t.offset||0,t.hoverOffset||0)}return e}_getRingWeightOffset(t){let e=0;for(let i=0;i<t;++i)this.chart.isDatasetVisible(i)&&(e+=this._getRingWeight(i));return e}_getRingWeight(t){return Math.max(l(this.chart.data.datasets[t].weight,1),0)}_getVisibleDatasetWeightTotal(){return this._getRingWeightOffset(this.chart.data.datasets.length)||1}}class $n extends Ns{static id="polarArea";static defaults={dataElementType:"arc",animation:{animateRotate:!0,animateScale:!0},animations:{numbers:{type:"number",properties:["x","y","startAngle","endAngle","innerRadius","outerRadius"]}},indexAxis:"r",startAngle:0};static overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data;if(e.labels.length&&e.datasets.length){const{labels:{pointStyle:i,color:s}}=t.legend.options;return e.labels.map(((e,n)=>{const o=t.getDatasetMeta(0).controller.getStyle(n);return{text:e,fillStyle:o.backgroundColor,strokeStyle:o.borderColor,fontColor:s,lineWidth:o.borderWidth,pointStyle:i,hidden:!t.getDataVisibility(n),index:n}}))}return[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}},scales:{r:{type:"radialLinear",angleLines:{display:!1},beginAtZero:!0,grid:{circular:!0},pointLabels:{display:!1},startAngle:0}}};constructor(t,e){super(t,e),this.innerRadius=void 0,this.outerRadius=void 0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,s=i.data.labels||[],n=ne(e._parsed[t].r,i.options.locale);return{label:s[t]||"",value:n}}parseObjectData(t,e,i,s){return ii.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta.data;this._updateRadius(),this.updateElements(e,0,e.length,t)}getMinMax(){const t=this._cachedMeta,e={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};return t.data.forEach(((t,i)=>{const s=this.getParsed(i).r;!isNaN(s)&&this.chart.getDataVisibility(i)&&(s<e.min&&(e.min=s),s>e.max&&(e.max=s))})),e}_updateRadius(){const t=this.chart,e=t.chartArea,i=t.options,s=Math.min(e.right-e.left,e.bottom-e.top),n=Math.max(s/2,0),o=(n-Math.max(i.cutoutPercentage?n/100*i.cutoutPercentage:1,0))/t.getVisibleDatasetCount();this.outerRadius=n-o*this.index,this.innerRadius=this.outerRadius-o}updateElements(t,e,i,s){const n="reset"===s,o=this.chart,a=o.options.animation,r=this._cachedMeta.rScale,l=r.xCenter,h=r.yCenter,c=r.getIndexAngle(0)-.5*C;let d,u=c;const f=360/this.countVisibleElements();for(d=0;d<e;++d)u+=this._computeAngle(d,s,f);for(d=e;d<e+i;d++){const e=t[d];let i=u,g=u+this._computeAngle(d,s,f),p=o.getDataVisibility(d)?r.getDistanceFromCenterForValue(this.getParsed(d).r):0;u=g,n&&(a.animateScale&&(p=0),a.animateRotate&&(i=g=c));const m={x:l,y:h,innerRadius:0,outerRadius:p,startAngle:i,endAngle:g,options:this.resolveDataElementOptions(d,e.active?"active":s)};this.updateElement(e,d,m,s)}}countVisibleElements(){const t=this._cachedMeta;let e=0;return t.data.forEach(((t,i)=>{!isNaN(this.getParsed(i).r)&&this.chart.getDataVisibility(i)&&e++})),e}_computeAngle(t,e,i){return this.chart.getDataVisibility(t)?$(this.resolveDataElementOptions(t,e).angle||i):0}}var Yn=Object.freeze({__proto__:null,BarController:class extends Ns{static id="bar";static defaults={datasetElementType:!1,dataElementType:"bar",categoryPercentage:.8,barPercentage:.9,grouped:!0,animations:{numbers:{type:"number",properties:["x","y","base","width","height"]}}};static overrides={scales:{_index_:{type:"category",offset:!0,grid:{offset:!0}},_value_:{type:"linear",beginAtZero:!0}}};parsePrimitiveData(t,e,i,s){return Fn(t,e,i,s)}parseArrayData(t,e,i,s){return Fn(t,e,i,s)}parseObjectData(t,e,i,s){const{iScale:n,vScale:o}=t,{xAxisKey:a="x",yAxisKey:r="y"}=this._parsing,l="x"===n.axis?a:r,h="x"===o.axis?a:r,c=[];let d,u,f,g;for(d=i,u=i+s;d<u;++d)g=e[d],f={},f[n.axis]=n.parse(M(g,l),d),c.push(zn(M(g,h),f,o,d));return c}updateRangeFromParsed(t,e,i,s){super.updateRangeFromParsed(t,e,i,s);const n=i._custom;n&&e===this._cachedMeta.vScale&&(t.min=Math.min(t.min,n.min),t.max=Math.max(t.max,n.max))}getMaxOverflow(){return 0}getLabelAndValue(t){const e=this._cachedMeta,{iScale:i,vScale:s}=e,n=this.getParsed(t),o=n._custom,a=Vn(o)?"["+o.start+", "+o.end+"]":""+s.getLabelForValue(n[s.axis]);return{label:""+i.getLabelForValue(n[i.axis]),value:a}}initialize(){this.enableOptionSharing=!0,super.initialize();this._cachedMeta.stack=this.getDataset().stack}update(t){const e=this._cachedMeta;this.updateElements(e.data,0,e.data.length,t)}updateElements(t,e,i,n){const o="reset"===n,{index:a,_cachedMeta:{vScale:r}}=this,l=r.getBasePixel(),h=r.isHorizontal(),c=this._getRuler(),{sharedOptions:d,includeOptions:u}=this._getSharedOptions(e,n);for(let f=e;f<e+i;f++){const e=this.getParsed(f),i=o||s(e[r.axis])?{base:l,head:l}:this._calculateBarValuePixels(f),g=this._calculateBarIndexPixels(f,c),p=(e._stacks||{})[r.axis],m={horizontal:h,base:i.base,enableBorderRadius:!p||Vn(e._custom)||a===p._top||a===p._bottom,x:h?i.head:g.center,y:h?g.center:i.head,height:h?g.size:Math.abs(i.size),width:h?Math.abs(i.size):g.size};u&&(m.options=d||this.resolveDataElementOptions(f,t[f].active?"active":n));const x=m.options||t[f].options;Bn(m,x,p,a),Hn(m,x,c.ratio),this.updateElement(t[f],f,m,n)}}_getStacks(t,e){const{iScale:i}=this._cachedMeta,n=i.getMatchingVisibleMetas(this._type).filter((t=>t.controller.options.grouped)),o=i.options.stacked,a=[],r=t=>{const i=t.controller.getParsed(e),n=i&&i[t.vScale.axis];if(s(n)||isNaN(n))return!0};for(const i of n)if((void 0===e||!r(i))&&((!1===o||-1===a.indexOf(i.stack)||void 0===o&&void 0===i.stack)&&a.push(i.stack),i.index===t))break;return a.length||a.push(void 0),a}_getStackCount(t){return this._getStacks(void 0,t).length}_getStackIndex(t,e,i){const s=this._getStacks(t,i),n=void 0!==e?s.indexOf(e):-1;return-1===n?s.length-1:n}_getRuler(){const t=this.options,e=this._cachedMeta,i=e.iScale,s=[];let n,o;for(n=0,o=e.data.length;n<o;++n)s.push(i.getPixelForValue(this.getParsed(n)[i.axis],n));const a=t.barThickness;return{min:a||In(e),pixels:s,start:i._startPixel,end:i._endPixel,stackCount:this._getStackCount(),scale:i,grouped:t.grouped,ratio:a?1:t.categoryPercentage*t.barPercentage}}_calculateBarValuePixels(t){const{_cachedMeta:{vScale:e,_stacked:i,index:n},options:{base:o,minBarLength:a}}=this,r=o||0,l=this.getParsed(t),h=l._custom,c=Vn(h);let d,u,f=l[e.axis],g=0,p=i?this.applyStack(e,l,i):f;p!==f&&(g=p-f,p=f),c&&(f=h.barStart,p=h.barEnd-h.barStart,0!==f&&F(f)!==F(h.barEnd)&&(g=0),g+=f);const m=s(o)||c?g:o;let x=e.getPixelForValue(m);if(d=this.chart.getDataVisibility(t)?e.getPixelForValue(g+p):x,u=d-x,Math.abs(u)<a){u=function(t,e,i){return 0!==t?F(t):(e.isHorizontal()?1:-1)*(e.min>=i?1:-1)}(u,e,r)*a,f===r&&(x-=u/2);const t=e.getPixelForDecimal(0),s=e.getPixelForDecimal(1),o=Math.min(t,s),h=Math.max(t,s);x=Math.max(Math.min(x,h),o),d=x+u,i&&!c&&(l._stacks[e.axis]._visualValues[n]=e.getValueForPixel(d)-e.getValueForPixel(x))}if(x===e.getPixelForValue(r)){const t=F(u)*e.getLineWidthForValue(r)/2;x+=t,u-=t}return{size:u,base:x,head:d,center:d+u/2}}_calculateBarIndexPixels(t,e){const i=e.scale,n=this.options,o=n.skipNull,a=l(n.maxBarThickness,1/0);let r,h;if(e.grouped){const i=o?this._getStackCount(t):e.stackCount,l="flex"===n.barThickness?function(t,e,i,s){const n=e.pixels,o=n[t];let a=t>0?n[t-1]:null,r=t<n.length-1?n[t+1]:null;const l=i.categoryPercentage;null===a&&(a=o-(null===r?e.end-e.start:r-o)),null===r&&(r=o+o-a);const h=o-(o-Math.min(a,r))/2*l;return{chunk:Math.abs(r-a)/2*l/s,ratio:i.barPercentage,start:h}}(t,e,n,i):function(t,e,i,n){const o=i.barThickness;let a,r;return s(o)?(a=e.min*i.categoryPercentage,r=i.barPercentage):(a=o*n,r=1),{chunk:a/n,ratio:r,start:e.pixels[t]-a/2}}(t,e,n,i),c=this._getStackIndex(this.index,this._cachedMeta.stack,o?t:void 0);r=l.start+l.chunk*c+l.chunk/2,h=Math.min(a,l.chunk*l.ratio)}else r=i.getPixelForValue(this.getParsed(t)[i.axis],t),h=Math.min(a,e.min*e.ratio);return{base:r-h/2,head:r+h/2,center:r,size:h}}draw(){const t=this._cachedMeta,e=t.vScale,i=t.data,s=i.length;let n=0;for(;n<s;++n)null===this.getParsed(n)[e.axis]||i[n].hidden||i[n].draw(this._ctx)}},BubbleController:class extends Ns{static id="bubble";static defaults={datasetElementType:!1,dataElementType:"point",animations:{numbers:{type:"number",properties:["x","y","borderWidth","radius"]}}};static overrides={scales:{x:{type:"linear"},y:{type:"linear"}}};initialize(){this.enableOptionSharing=!0,super.initialize()}parsePrimitiveData(t,e,i,s){const n=super.parsePrimitiveData(t,e,i,s);for(let t=0;t<n.length;t++)n[t]._custom=this.resolveDataElementOptions(t+i).radius;return n}parseArrayData(t,e,i,s){const n=super.parseArrayData(t,e,i,s);for(let t=0;t<n.length;t++){const s=e[i+t];n[t]._custom=l(s[2],this.resolveDataElementOptions(t+i).radius)}return n}parseObjectData(t,e,i,s){const n=super.parseObjectData(t,e,i,s);for(let t=0;t<n.length;t++){const s=e[i+t];n[t]._custom=l(s&&s.r&&+s.r,this.resolveDataElementOptions(t+i).radius)}return n}getMaxOverflow(){const t=this._cachedMeta.data;let e=0;for(let i=t.length-1;i>=0;--i)e=Math.max(e,t[i].size(this.resolveDataElementOptions(i))/2);return e>0&&e}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart.data.labels||[],{xScale:s,yScale:n}=e,o=this.getParsed(t),a=s.getLabelForValue(o.x),r=n.getLabelForValue(o.y),l=o._custom;return{label:i[t]||"",value:"("+a+", "+r+(l?", "+l:"")+")"}}update(t){const e=this._cachedMeta.data;this.updateElements(e,0,e.length,t)}updateElements(t,e,i,s){const n="reset"===s,{iScale:o,vScale:a}=this._cachedMeta,{sharedOptions:r,includeOptions:l}=this._getSharedOptions(e,s),h=o.axis,c=a.axis;for(let d=e;d<e+i;d++){const e=t[d],i=!n&&this.getParsed(d),u={},f=u[h]=n?o.getPixelForDecimal(.5):o.getPixelForValue(i[h]),g=u[c]=n?a.getBasePixel():a.getPixelForValue(i[c]);u.skip=isNaN(f)||isNaN(g),l&&(u.options=r||this.resolveDataElementOptions(d,e.active?"active":s),n&&(u.options.radius=0)),this.updateElement(e,d,u,s)}}resolveDataElementOptions(t,e){const i=this.getParsed(t);let s=super.resolveDataElementOptions(t,e);s.$shared&&(s=Object.assign({},s,{$shared:!1}));const n=s.radius;return"active"!==e&&(s.radius=0),s.radius+=l(i&&i._custom,n),s}},DoughnutController:jn,LineController:class extends Ns{static id="line";static defaults={datasetElementType:"line",dataElementType:"point",showLine:!0,spanGaps:!1};static overrides={scales:{_index_:{type:"category"},_value_:{type:"linear"}}};initialize(){this.enableOptionSharing=!0,this.supportsDecimation=!0,super.initialize()}update(t){const e=this._cachedMeta,{dataset:i,data:s=[],_dataset:n}=e,o=this.chart._animationsDisabled;let{start:a,count:r}=pt(e,s,o);this._drawStart=a,this._drawCount=r,mt(e)&&(a=0,r=s.length),i._chart=this.chart,i._datasetIndex=this.index,i._decimated=!!n._decimated,i.points=s;const l=this.resolveDatasetElementOptions(t);this.options.showLine||(l.borderWidth=0),l.segment=this.options.segment,this.updateElement(i,void 0,{animated:!o,options:l},t),this.updateElements(s,a,r,t)}updateElements(t,e,i,n){const o="reset"===n,{iScale:a,vScale:r,_stacked:l,_dataset:h}=this._cachedMeta,{sharedOptions:c,includeOptions:d}=this._getSharedOptions(e,n),u=a.axis,f=r.axis,{spanGaps:g,segment:p}=this.options,m=N(g)?g:Number.POSITIVE_INFINITY,x=this.chart._animationsDisabled||o||"none"===n,b=e+i,_=t.length;let y=e>0&&this.getParsed(e-1);for(let i=0;i<_;++i){const g=t[i],_=x?g:{};if(i<e||i>=b){_.skip=!0;continue}const v=this.getParsed(i),M=s(v[f]),w=_[u]=a.getPixelForValue(v[u],i),k=_[f]=o||M?r.getBasePixel():r.getPixelForValue(l?this.applyStack(r,v,l):v[f],i);_.skip=isNaN(w)||isNaN(k)||M,_.stop=i>0&&Math.abs(v[u]-y[u])>m,p&&(_.parsed=v,_.raw=h.data[i]),d&&(_.options=c||this.resolveDataElementOptions(i,g.active?"active":n)),x||this.updateElement(g,i,_,n),y=v}}getMaxOverflow(){const t=this._cachedMeta,e=t.dataset,i=e.options&&e.options.borderWidth||0,s=t.data||[];if(!s.length)return i;const n=s[0].size(this.resolveDataElementOptions(0)),o=s[s.length-1].size(this.resolveDataElementOptions(s.length-1));return Math.max(i,n,o)/2}draw(){const t=this._cachedMeta;t.dataset.updateControlPoints(this.chart.chartArea,t.iScale.axis),super.draw()}},PieController:class extends jn{static id="pie";static defaults={cutout:0,rotation:0,circumference:360,radius:"100%"}},PolarAreaController:$n,RadarController:class extends Ns{static id="radar";static defaults={datasetElementType:"line",dataElementType:"point",indexAxis:"r",showLine:!0,elements:{line:{fill:"start"}}};static overrides={aspectRatio:1,scales:{r:{type:"radialLinear"}}};getLabelAndValue(t){const e=this._cachedMeta.vScale,i=this.getParsed(t);return{label:e.getLabels()[t],value:""+e.getLabelForValue(i[e.axis])}}parseObjectData(t,e,i,s){return ii.bind(this)(t,e,i,s)}update(t){const e=this._cachedMeta,i=e.dataset,s=e.data||[],n=e.iScale.getLabels();if(i.points=s,"resize"!==t){const e=this.resolveDatasetElementOptions(t);this.options.showLine||(e.borderWidth=0);const o={_loop:!0,_fullLoop:n.length===s.length,options:e};this.updateElement(i,void 0,o,t)}this.updateElements(s,0,s.length,t)}updateElements(t,e,i,s){const n=this._cachedMeta.rScale,o="reset"===s;for(let a=e;a<e+i;a++){const e=t[a],i=this.resolveDataElementOptions(a,e.active?"active":s),r=n.getPointPositionForValue(a,this.getParsed(a).r),l=o?n.xCenter:r.x,h=o?n.yCenter:r.y,c={x:l,y:h,angle:r.angle,skip:isNaN(l)||isNaN(h),options:i};this.updateElement(e,a,c,s)}}},ScatterController:class extends Ns{static id="scatter";static defaults={datasetElementType:!1,dataElementType:"point",showLine:!1,fill:!1};static overrides={interaction:{mode:"point"},scales:{x:{type:"linear"},y:{type:"linear"}}};getLabelAndValue(t){const e=this._cachedMeta,i=this.chart.data.labels||[],{xScale:s,yScale:n}=e,o=this.getParsed(t),a=s.getLabelForValue(o.x),r=n.getLabelForValue(o.y);return{label:i[t]||"",value:"("+a+", "+r+")"}}update(t){const e=this._cachedMeta,{data:i=[]}=e,s=this.chart._animationsDisabled;let{start:n,count:o}=pt(e,i,s);if(this._drawStart=n,this._drawCount=o,mt(e)&&(n=0,o=i.length),this.options.showLine){this.datasetElementType||this.addElements();const{dataset:n,_dataset:o}=e;n._chart=this.chart,n._datasetIndex=this.index,n._decimated=!!o._decimated,n.points=i;const a=this.resolveDatasetElementOptions(t);a.segment=this.options.segment,this.updateElement(n,void 0,{animated:!s,options:a},t)}else this.datasetElementType&&(delete e.dataset,this.datasetElementType=!1);this.updateElements(i,n,o,t)}addElements(){const{showLine:t}=this.options;!this.datasetElementType&&t&&(this.datasetElementType=this.chart.registry.getElement("line")),super.addElements()}updateElements(t,e,i,n){const o="reset"===n,{iScale:a,vScale:r,_stacked:l,_dataset:h}=this._cachedMeta,c=this.resolveDataElementOptions(e,n),d=this.getSharedOptions(c),u=this.includeOptions(n,d),f=a.axis,g=r.axis,{spanGaps:p,segment:m}=this.options,x=N(p)?p:Number.POSITIVE_INFINITY,b=this.chart._animationsDisabled||o||"none"===n;let _=e>0&&this.getParsed(e-1);for(let c=e;c<e+i;++c){const e=t[c],i=this.getParsed(c),p=b?e:{},y=s(i[g]),v=p[f]=a.getPixelForValue(i[f],c),M=p[g]=o||y?r.getBasePixel():r.getPixelForValue(l?this.applyStack(r,i,l):i[g],c);p.skip=isNaN(v)||isNaN(M)||y,p.stop=c>0&&Math.abs(i[f]-_[f])>x,m&&(p.parsed=i,p.raw=h.data[c]),u&&(p.options=d||this.resolveDataElementOptions(c,e.active?"active":n)),b||this.updateElement(e,c,p,n),_=i}this.updateSharedOptions(d,n,c)}getMaxOverflow(){const t=this._cachedMeta,e=t.data||[];if(!this.options.showLine){let t=0;for(let i=e.length-1;i>=0;--i)t=Math.max(t,e[i].size(this.resolveDataElementOptions(i))/2);return t>0&&t}const i=t.dataset,s=i.options&&i.options.borderWidth||0;if(!e.length)return s;const n=e[0].size(this.resolveDataElementOptions(0)),o=e[e.length-1].size(this.resolveDataElementOptions(e.length-1));return Math.max(s,n,o)/2}}});function Un(t,e,i,s){const n=vi(t.options.borderRadius,["outerStart","outerEnd","innerStart","innerEnd"]);const o=(i-e)/2,a=Math.min(o,s*e/2),r=t=>{const e=(i-Math.min(o,t))*s/2;return J(t,0,Math.min(o,e))};return{outerStart:r(n.outerStart),outerEnd:r(n.outerEnd),innerStart:J(n.innerStart,0,a),innerEnd:J(n.innerEnd,0,a)}}function Xn(t,e,i,s){return{x:i+t*Math.cos(e),y:s+t*Math.sin(e)}}function qn(t,e,i,s,n,o){const{x:a,y:r,startAngle:l,pixelMargin:h,innerRadius:c}=e,d=Math.max(e.outerRadius+s+i-h,0),u=c>0?c+s+i+h:0;let f=0;const g=n-l;if(s){const t=((c>0?c-s:0)+(d>0?d-s:0))/2;f=(g-(0!==t?g*t/(t+s):g))/2}const p=(g-Math.max(.001,g*d-i/C)/d)/2,m=l+p+f,x=n-p-f,{outerStart:b,outerEnd:_,innerStart:y,innerEnd:v}=Un(e,u,d,x-m),M=d-b,w=d-_,k=m+b/M,S=x-_/w,P=u+y,D=u+v,O=m+y/P,A=x-v/D;if(t.beginPath(),o){const e=(k+S)/2;if(t.arc(a,r,d,k,e),t.arc(a,r,d,e,S),_>0){const e=Xn(w,S,a,r);t.arc(e.x,e.y,_,S,x+E)}const i=Xn(D,x,a,r);if(t.lineTo(i.x,i.y),v>0){const e=Xn(D,A,a,r);t.arc(e.x,e.y,v,x+E,A+Math.PI)}const s=(x-v/u+(m+y/u))/2;if(t.arc(a,r,u,x-v/u,s,!0),t.arc(a,r,u,s,m+y/u,!0),y>0){const e=Xn(P,O,a,r);t.arc(e.x,e.y,y,O+Math.PI,m-E)}const n=Xn(M,m,a,r);if(t.lineTo(n.x,n.y),b>0){const e=Xn(M,k,a,r);t.arc(e.x,e.y,b,m-E,k)}}else{t.moveTo(a,r);const e=Math.cos(k)*d+a,i=Math.sin(k)*d+r;t.lineTo(e,i);const s=Math.cos(S)*d+a,n=Math.sin(S)*d+r;t.lineTo(s,n)}t.closePath()}function Kn(t,e,i,s,n){const{fullCircles:o,startAngle:a,circumference:r,options:l}=e,{borderWidth:h,borderJoinStyle:c,borderDash:d,borderDashOffset:u}=l,f="inner"===l.borderAlign;if(!h)return;t.setLineDash(d||[]),t.lineDashOffset=u,f?(t.lineWidth=2*h,t.lineJoin=c||"round"):(t.lineWidth=h,t.lineJoin=c||"bevel");let g=e.endAngle;if(o){qn(t,e,i,s,g,n);for(let e=0;e<o;++e)t.stroke();isNaN(r)||(g=a+(r%O||O))}f&&function(t,e,i){const{startAngle:s,pixelMargin:n,x:o,y:a,outerRadius:r,innerRadius:l}=e;let h=n/r;t.beginPath(),t.arc(o,a,r,s-h,i+h),l>n?(h=n/l,t.arc(o,a,l,i+h,s-h,!0)):t.arc(o,a,n,i+E,s-E),t.closePath(),t.clip()}(t,e,g),o||(qn(t,e,i,s,g,n),t.stroke())}function Gn(t,e,i=e){t.lineCap=l(i.borderCapStyle,e.borderCapStyle),t.setLineDash(l(i.borderDash,e.borderDash)),t.lineDashOffset=l(i.borderDashOffset,e.borderDashOffset),t.lineJoin=l(i.borderJoinStyle,e.borderJoinStyle),t.lineWidth=l(i.borderWidth,e.borderWidth),t.strokeStyle=l(i.borderColor,e.borderColor)}function Zn(t,e,i){t.lineTo(i.x,i.y)}function Jn(t,e,i={}){const s=t.length,{start:n=0,end:o=s-1}=i,{start:a,end:r}=e,l=Math.max(n,a),h=Math.min(o,r),c=n<a&&o<a||n>r&&o>r;return{count:s,start:l,loop:e.loop,ilen:h<l&&!c?s+h-l:h-l}}function Qn(t,e,i,s){const{points:n,options:o}=e,{count:a,start:r,loop:l,ilen:h}=Jn(n,i,s),c=function(t){return t.stepped?Fe:t.tension||"monotone"===t.cubicInterpolationMode?Ve:Zn}(o);let d,u,f,{move:g=!0,reverse:p}=s||{};for(d=0;d<=h;++d)u=n[(r+(p?h-d:d))%a],u.skip||(g?(t.moveTo(u.x,u.y),g=!1):c(t,f,u,p,o.stepped),f=u);return l&&(u=n[(r+(p?h:0))%a],c(t,f,u,p,o.stepped)),!!l}function to(t,e,i,s){const n=e.points,{count:o,start:a,ilen:r}=Jn(n,i,s),{move:l=!0,reverse:h}=s||{};let c,d,u,f,g,p,m=0,x=0;const b=t=>(a+(h?r-t:t))%o,_=()=>{f!==g&&(t.lineTo(m,g),t.lineTo(m,f),t.lineTo(m,p))};for(l&&(d=n[b(0)],t.moveTo(d.x,d.y)),c=0;c<=r;++c){if(d=n[b(c)],d.skip)continue;const e=d.x,i=d.y,s=0|e;s===u?(i<f?f=i:i>g&&(g=i),m=(x*m+e)/++x):(_(),t.lineTo(e,i),u=s,x=0,f=g=i),p=i}_()}function eo(t){const e=t.options,i=e.borderDash&&e.borderDash.length;return!(t._decimated||t._loop||e.tension||"monotone"===e.cubicInterpolationMode||e.stepped||i)?to:Qn}const io="function"==typeof Path2D;function so(t,e,i,s){io&&!e.options.segment?function(t,e,i,s){let n=e._path;n||(n=e._path=new Path2D,e.path(n,i,s)&&n.closePath()),Gn(t,e.options),t.stroke(n)}(t,e,i,s):function(t,e,i,s){const{segments:n,options:o}=e,a=eo(e);for(const r of n)Gn(t,o,r.style),t.beginPath(),a(t,e,r,{start:i,end:i+s-1})&&t.closePath(),t.stroke()}(t,e,i,s)}class no extends Hs{static id="line";static defaults={borderCapStyle:"butt",borderDash:[],borderDashOffset:0,borderJoinStyle:"miter",borderWidth:3,capBezierPoints:!0,cubicInterpolationMode:"default",fill:!1,spanGaps:!1,stepped:!1,tension:0};static defaultRoutes={backgroundColor:"backgroundColor",borderColor:"borderColor"};static descriptors={_scriptable:!0,_indexable:t=>"borderDash"!==t&&"fill"!==t};constructor(t){super(),this.animated=!0,this.options=void 0,this._chart=void 0,this._loop=void 0,this._fullLoop=void 0,this._path=void 0,this._points=void 0,this._segments=void 0,this._decimated=!1,this._pointsUpdated=!1,this._datasetIndex=void 0,t&&Object.assign(this,t)}updateControlPoints(t,e){const i=this.options;if((i.tension||"monotone"===i.cubicInterpolationMode)&&!i.stepped&&!this._pointsUpdated){const s=i.spanGaps?this._loop:this._fullLoop;hi(this._points,i,t,s,e),this._pointsUpdated=!0}}set points(t){this._points=t,delete this._segments,delete this._path,this._pointsUpdated=!1}get points(){return this._points}get segments(){return this._segments||(this._segments=zi(this,this.options.segment))}first(){const t=this.segments,e=this.points;return t.length&&e[t[0].start]}last(){const t=this.segments,e=this.points,i=t.length;return i&&e[t[i-1].end]}interpolate(t,e){const i=this.options,s=t[e],n=this.points,o=Ii(this,{property:e,start:s,end:s});if(!o.length)return;const a=[],r=function(t){return t.stepped?pi:t.tension||"monotone"===t.cubicInterpolationMode?mi:gi}(i);let l,h;for(l=0,h=o.length;l<h;++l){const{start:h,end:c}=o[l],d=n[h],u=n[c];if(d===u){a.push(d);continue}const f=r(d,u,Math.abs((s-d[e])/(u[e]-d[e])),i.stepped);f[e]=t[e],a.push(f)}return 1===a.length?a[0]:a}pathSegment(t,e,i){return eo(this)(t,this,e,i)}path(t,e,i){const s=this.segments,n=eo(this);let o=this._loop;e=e||0,i=i||this.points.length-e;for(const a of s)o&=n(t,this,a,{start:e,end:e+i-1});return!!o}draw(t,e,i,s){const n=this.options||{};(this.points||[]).length&&n.borderWidth&&(t.save(),so(t,this,i,s),t.restore()),this.animated&&(this._pointsUpdated=!1,this._path=void 0)}}function oo(t,e,i,s){const n=t.options,{[i]:o}=t.getProps([i],s);return Math.abs(e-o)<n.radius+n.hitRadius}function ao(t,e){const{x:i,y:s,base:n,width:o,height:a}=t.getProps(["x","y","base","width","height"],e);let r,l,h,c,d;return t.horizontal?(d=a/2,r=Math.min(i,n),l=Math.max(i,n),h=s-d,c=s+d):(d=o/2,r=i-d,l=i+d,h=Math.min(s,n),c=Math.max(s,n)),{left:r,top:h,right:l,bottom:c}}function ro(t,e,i,s){return t?0:J(e,i,s)}function lo(t){const e=ao(t),i=e.right-e.left,s=e.bottom-e.top,n=function(t,e,i){const s=t.options.borderWidth,n=t.borderSkipped,o=Mi(s);return{t:ro(n.top,o.top,0,i),r:ro(n.right,o.right,0,e),b:ro(n.bottom,o.bottom,0,i),l:ro(n.left,o.left,0,e)}}(t,i/2,s/2),a=function(t,e,i){const{enableBorderRadius:s}=t.getProps(["enableBorderRadius"]),n=t.options.borderRadius,a=wi(n),r=Math.min(e,i),l=t.borderSkipped,h=s||o(n);return{topLeft:ro(!h||l.top||l.left,a.topLeft,0,r),topRight:ro(!h||l.top||l.right,a.topRight,0,r),bottomLeft:ro(!h||l.bottom||l.left,a.bottomLeft,0,r),bottomRight:ro(!h||l.bottom||l.right,a.bottomRight,0,r)}}(t,i/2,s/2);return{outer:{x:e.left,y:e.top,w:i,h:s,radius:a},inner:{x:e.left+n.l,y:e.top+n.t,w:i-n.l-n.r,h:s-n.t-n.b,radius:{topLeft:Math.max(0,a.topLeft-Math.max(n.t,n.l)),topRight:Math.max(0,a.topRight-Math.max(n.t,n.r)),bottomLeft:Math.max(0,a.bottomLeft-Math.max(n.b,n.l)),bottomRight:Math.max(0,a.bottomRight-Math.max(n.b,n.r))}}}}function ho(t,e,i,s){const n=null===e,o=null===i,a=t&&!(n&&o)&&ao(t,s);return a&&(n||tt(e,a.left,a.right))&&(o||tt(i,a.top,a.bottom))}function co(t,e){t.rect(e.x,e.y,e.w,e.h)}function uo(t,e,i={}){const s=t.x!==i.x?-e:0,n=t.y!==i.y?-e:0,o=(t.x+t.w!==i.x+i.w?e:0)-s,a=(t.y+t.h!==i.y+i.h?e:0)-n;return{x:t.x+s,y:t.y+n,w:t.w+o,h:t.h+a,radius:t.radius}}var fo=Object.freeze({__proto__:null,ArcElement:class extends Hs{static id="arc";static defaults={borderAlign:"center",borderColor:"#fff",borderDash:[],borderDashOffset:0,borderJoinStyle:void 0,borderRadius:0,borderWidth:2,offset:0,spacing:0,angle:void 0,circular:!0};static defaultRoutes={backgroundColor:"backgroundColor"};static descriptors={_scriptable:!0,_indexable:t=>"borderDash"!==t};circumference;endAngle;fullCircles;innerRadius;outerRadius;pixelMargin;startAngle;constructor(t){super(),this.options=void 0,this.circumference=void 0,this.startAngle=void 0,this.endAngle=void 0,this.innerRadius=void 0,this.outerRadius=void 0,this.pixelMargin=0,this.fullCircles=0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.getProps(["x","y"],i),{angle:n,distance:o}=X(s,{x:t,y:e}),{startAngle:a,endAngle:r,innerRadius:h,outerRadius:c,circumference:d}=this.getProps(["startAngle","endAngle","innerRadius","outerRadius","circumference"],i),u=(this.options.spacing+this.options.borderWidth)/2,f=l(d,r-a)>=O||Z(n,a,r),g=tt(o,h+u,c+u);return f&&g}getCenterPoint(t){const{x:e,y:i,startAngle:s,endAngle:n,innerRadius:o,outerRadius:a}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius"],t),{offset:r,spacing:l}=this.options,h=(s+n)/2,c=(o+a+l+r)/2;return{x:e+Math.cos(h)*c,y:i+Math.sin(h)*c}}tooltipPosition(t){return this.getCenterPoint(t)}draw(t){const{options:e,circumference:i}=this,s=(e.offset||0)/4,n=(e.spacing||0)/2,o=e.circular;if(this.pixelMargin="inner"===e.borderAlign?.33:0,this.fullCircles=i>O?Math.floor(i/O):0,0===i||this.innerRadius<0||this.outerRadius<0)return;t.save();const a=(this.startAngle+this.endAngle)/2;t.translate(Math.cos(a)*s,Math.sin(a)*s);const r=s*(1-Math.sin(Math.min(C,i||0)));t.fillStyle=e.backgroundColor,t.strokeStyle=e.borderColor,function(t,e,i,s,n){const{fullCircles:o,startAngle:a,circumference:r}=e;let l=e.endAngle;if(o){qn(t,e,i,s,l,n);for(let e=0;e<o;++e)t.fill();isNaN(r)||(l=a+(r%O||O))}qn(t,e,i,s,l,n),t.fill()}(t,this,r,n,o),Kn(t,this,r,n,o),t.restore()}},BarElement:class extends Hs{static id="bar";static defaults={borderSkipped:"start",borderWidth:0,borderRadius:0,inflateAmount:"auto",pointStyle:void 0};static defaultRoutes={backgroundColor:"backgroundColor",borderColor:"borderColor"};constructor(t){super(),this.options=void 0,this.horizontal=void 0,this.base=void 0,this.width=void 0,this.height=void 0,this.inflateAmount=void 0,t&&Object.assign(this,t)}draw(t){const{inflateAmount:e,options:{borderColor:i,backgroundColor:s}}=this,{inner:n,outer:o}=lo(this),a=(r=o.radius).topLeft||r.topRight||r.bottomLeft||r.bottomRight?He:co;var r;t.save(),o.w===n.w&&o.h===n.h||(t.beginPath(),a(t,uo(o,e,n)),t.clip(),a(t,uo(n,-e,o)),t.fillStyle=i,t.fill("evenodd")),t.beginPath(),a(t,uo(n,e)),t.fillStyle=s,t.fill(),t.restore()}inRange(t,e,i){return ho(this,t,e,i)}inXRange(t,e){return ho(this,t,null,e)}inYRange(t,e){return ho(this,null,t,e)}getCenterPoint(t){const{x:e,y:i,base:s,horizontal:n}=this.getProps(["x","y","base","horizontal"],t);return{x:n?(e+s)/2:e,y:n?i:(i+s)/2}}getRange(t){return"x"===t?this.width/2:this.height/2}},LineElement:no,PointElement:class extends Hs{static id="point";parsed;skip;stop;static defaults={borderWidth:1,hitRadius:1,hoverBorderWidth:1,hoverRadius:4,pointStyle:"circle",radius:3,rotation:0};static defaultRoutes={backgroundColor:"backgroundColor",borderColor:"borderColor"};constructor(t){super(),this.options=void 0,this.parsed=void 0,this.skip=void 0,this.stop=void 0,t&&Object.assign(this,t)}inRange(t,e,i){const s=this.options,{x:n,y:o}=this.getProps(["x","y"],i);return Math.pow(t-n,2)+Math.pow(e-o,2)<Math.pow(s.hitRadius+s.radius,2)}inXRange(t,e){return oo(this,t,"x",e)}inYRange(t,e){return oo(this,t,"y",e)}getCenterPoint(t){const{x:e,y:i}=this.getProps(["x","y"],t);return{x:e,y:i}}size(t){let e=(t=t||this.options||{}).radius||0;e=Math.max(e,e&&t.hoverRadius||0);return 2*(e+(e&&t.borderWidth||0))}draw(t,e){const i=this.options;this.skip||i.radius<.1||!Re(this,e,this.size(i)/2)||(t.strokeStyle=i.borderColor,t.lineWidth=i.borderWidth,t.fillStyle=i.backgroundColor,Le(t,i,this.x,this.y))}getRange(){const t=this.options||{};return t.radius+t.hitRadius}}});function go(t,e,i,s){const n=t.indexOf(e);if(-1===n)return((t,e,i,s)=>("string"==typeof e?(i=t.push(e)-1,s.unshift({index:i,label:e})):isNaN(e)&&(i=null),i))(t,e,i,s);return n!==t.lastIndexOf(e)?i:n}function po(t){const e=this.getLabels();return t>=0&&t<e.length?e[t]:t}function mo(t,e,{horizontal:i,minRotation:s}){const n=$(s),o=(i?Math.sin(n):Math.cos(n))||.001,a=.75*e*(""+t).length;return Math.min(e/o,a)}class xo extends Js{constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._endValue=void 0,this._valueRange=0}parse(t,e){return s(t)||("number"==typeof t||t instanceof Number)&&!isFinite(+t)?null:+t}handleTickRangeOptions(){const{beginAtZero:t}=this.options,{minDefined:e,maxDefined:i}=this.getUserBounds();let{min:s,max:n}=this;const o=t=>s=e?s:t,a=t=>n=i?n:t;if(t){const t=F(s),e=F(n);t<0&&e<0?a(0):t>0&&e>0&&o(0)}if(s===n){let e=0===n?1:Math.abs(.05*n);a(n+e),t||o(s-e)}this.min=s,this.max=n}getTickLimit(){const t=this.options.ticks;let e,{maxTicksLimit:i,stepSize:s}=t;return s?(e=Math.ceil(this.max/s)-Math.floor(this.min/s)+1,e>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${s} would result generating up to ${e} ticks. Limiting to 1000.`),e=1e3)):(e=this.computeTickLimit(),i=i||11),i&&(e=Math.min(i,e)),e}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const t=this.options,e=t.ticks;let i=this.getTickLimit();i=Math.max(2,i);const n=function(t,e){const i=[],{bounds:n,step:o,min:a,max:r,precision:l,count:h,maxTicks:c,maxDigits:d,includeBounds:u}=t,f=o||1,g=c-1,{min:p,max:m}=e,x=!s(a),b=!s(r),_=!s(h),y=(m-p)/(d+1);let v,M,w,k,S=B((m-p)/g/f)*f;if(S<1e-14&&!x&&!b)return[{value:p},{value:m}];k=Math.ceil(m/S)-Math.floor(p/S),k>g&&(S=B(k*S/g/f)*f),s(l)||(v=Math.pow(10,l),S=Math.ceil(S*v)/v),"ticks"===n?(M=Math.floor(p/S)*S,w=Math.ceil(m/S)*S):(M=p,w=m),x&&b&&o&&H((r-a)/o,S/1e3)?(k=Math.round(Math.min((r-a)/S,c)),S=(r-a)/k,M=a,w=r):_?(M=x?a:M,w=b?r:w,k=h-1,S=(w-M)/k):(k=(w-M)/S,k=V(k,Math.round(k),S/1e3)?Math.round(k):Math.ceil(k));const P=Math.max(U(S),U(M));v=Math.pow(10,s(l)?P:l),M=Math.round(M*v)/v,w=Math.round(w*v)/v;let D=0;for(x&&(u&&M!==a?(i.push({value:a}),M<a&&D++,V(Math.round((M+D*S)*v)/v,a,mo(a,y,t))&&D++):M<a&&D++);D<k;++D){const t=Math.round((M+D*S)*v)/v;if(b&&t>r)break;i.push({value:t})}return b&&u&&w!==r?i.length&&V(i[i.length-1].value,r,mo(r,y,t))?i[i.length-1].value=r:i.push({value:r}):b&&w!==r||i.push({value:w}),i}({maxTicks:i,bounds:t.bounds,min:t.min,max:t.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:!1!==e.includeBounds},this._range||this);return"ticks"===t.bounds&&j(n,this,"value"),t.reverse?(n.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),n}configure(){const t=this.ticks;let e=this.min,i=this.max;if(super.configure(),this.options.offset&&t.length){const s=(i-e)/Math.max(t.length-1,1)/2;e-=s,i+=s}this._startValue=e,this._endValue=i,this._valueRange=i-e}getLabelForValue(t){return ne(t,this.chart.options.locale,this.options.ticks.format)}}class bo extends xo{static id="linear";static defaults={ticks:{callback:ae.formatters.numeric}};determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=a(t)?t:0,this.max=a(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const t=this.isHorizontal(),e=t?this.width:this.height,i=$(this.options.ticks.minRotation),s=(t?Math.sin(i):Math.cos(i))||.001,n=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,n.lineHeight/s))}getPixelForValue(t){return null===t?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getValueForPixel(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange}}const _o=t=>Math.floor(z(t)),yo=(t,e)=>Math.pow(10,_o(t)+e);function vo(t){return 1===t/Math.pow(10,_o(t))}function Mo(t,e,i){const s=Math.pow(10,i),n=Math.floor(t/s);return Math.ceil(e/s)-n}function wo(t,{min:e,max:i}){e=r(t.min,e);const s=[],n=_o(e);let o=function(t,e){let i=_o(e-t);for(;Mo(t,e,i)>10;)i++;for(;Mo(t,e,i)<10;)i--;return Math.min(i,_o(t))}(e,i),a=o<0?Math.pow(10,Math.abs(o)):1;const l=Math.pow(10,o),h=n>o?Math.pow(10,n):0,c=Math.round((e-h)*a)/a,d=Math.floor((e-h)/l/10)*l*10;let u=Math.floor((c-d)/Math.pow(10,o)),f=r(t.min,Math.round((h+d+u*Math.pow(10,o))*a)/a);for(;f<i;)s.push({value:f,major:vo(f),significand:u}),u>=10?u=u<15?15:20:u++,u>=20&&(o++,u=2,a=o>=0?1:a),f=Math.round((h+d+u*Math.pow(10,o))*a)/a;const g=r(t.max,f);return s.push({value:g,major:vo(g),significand:u}),s}class ko extends Js{static id="logarithmic";static defaults={ticks:{callback:ae.formatters.logarithmic,major:{enabled:!0}}};constructor(t){super(t),this.start=void 0,this.end=void 0,this._startValue=void 0,this._valueRange=0}parse(t,e){const i=xo.prototype.parse.apply(this,[t,e]);if(0!==i)return a(i)&&i>0?i:null;this._zero=!0}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=a(t)?Math.max(0,t):null,this.max=a(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this._zero&&this.min!==this._suggestedMin&&!a(this._userMin)&&(this.min=t===yo(this.min,0)?yo(this.min,-1):yo(this.min,0)),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let i=this.min,s=this.max;const n=e=>i=t?i:e,o=t=>s=e?s:t;i===s&&(i<=0?(n(1),o(10)):(n(yo(i,-1)),o(yo(s,1)))),i<=0&&n(yo(s,-1)),s<=0&&o(yo(i,1)),this.min=i,this.max=s}buildTicks(){const t=this.options,e=wo({min:this._userMin,max:this._userMax},this);return"ticks"===t.bounds&&j(e,this,"value"),t.reverse?(e.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),e}getLabelForValue(t){return void 0===t?"0":ne(t,this.chart.options.locale,this.options.ticks.format)}configure(){const t=this.min;super.configure(),this._startValue=z(t),this._valueRange=z(this.max)-z(t)}getPixelForValue(t){return void 0!==t&&0!==t||(t=this.min),null===t||isNaN(t)?NaN:this.getPixelForDecimal(t===this.min?0:(z(t)-this._startValue)/this._valueRange)}getValueForPixel(t){const e=this.getDecimalForPixel(t);return Math.pow(10,this._startValue+e*this._valueRange)}}function So(t){const e=t.ticks;if(e.display&&t.display){const t=ki(e.backdropPadding);return l(e.font&&e.font.size,ue.font.size)+t.height}return 0}function Po(t,e,i,s,n){return t===s||t===n?{start:e-i/2,end:e+i/2}:t<s||t>n?{start:e-i,end:e}:{start:e,end:e+i}}function Do(t){const e={l:t.left+t._padding.left,r:t.right-t._padding.right,t:t.top+t._padding.top,b:t.bottom-t._padding.bottom},i=Object.assign({},e),s=[],o=[],a=t._pointLabels.length,r=t.options.pointLabels,l=r.centerPointLabels?C/a:0;for(let u=0;u<a;u++){const a=r.setContext(t.getPointLabelContext(u));o[u]=a.padding;const f=t.getPointPosition(u,t.drawingArea+o[u],l),g=Si(a.font),p=(h=t.ctx,c=g,d=n(d=t._pointLabels[u])?d:[d],{w:Oe(h,c.string,d),h:d.length*c.lineHeight});s[u]=p;const m=G(t.getIndexAngle(u)+l),x=Math.round(Y(m));Co(i,e,m,Po(x,f.x,p.w,0,180),Po(x,f.y,p.h,90,270))}var h,c,d;t.setCenterPoint(e.l-i.l,i.r-e.r,e.t-i.t,i.b-e.b),t._pointLabelItems=function(t,e,i){const s=[],n=t._pointLabels.length,o=t.options,{centerPointLabels:a,display:r}=o.pointLabels,l={extra:So(o)/2,additionalAngle:a?C/n:0};let h;for(let o=0;o<n;o++){l.padding=i[o],l.size=e[o];const n=Oo(t,o,l);s.push(n),"auto"===r&&(n.visible=Ao(n,h),n.visible&&(h=n))}return s}(t,s,o)}function Co(t,e,i,s,n){const o=Math.abs(Math.sin(i)),a=Math.abs(Math.cos(i));let r=0,l=0;s.start<e.l?(r=(e.l-s.start)/o,t.l=Math.min(t.l,e.l-r)):s.end>e.r&&(r=(s.end-e.r)/o,t.r=Math.max(t.r,e.r+r)),n.start<e.t?(l=(e.t-n.start)/a,t.t=Math.min(t.t,e.t-l)):n.end>e.b&&(l=(n.end-e.b)/a,t.b=Math.max(t.b,e.b+l))}function Oo(t,e,i){const s=t.drawingArea,{extra:n,additionalAngle:o,padding:a,size:r}=i,l=t.getPointPosition(e,s+n+a,o),h=Math.round(Y(G(l.angle+E))),c=function(t,e,i){90===i||270===i?t-=e/2:(i>270||i<90)&&(t-=e);return t}(l.y,r.h,h),d=function(t){if(0===t||180===t)return"center";if(t<180)return"left";return"right"}(h),u=function(t,e,i){"right"===i?t-=e:"center"===i&&(t-=e/2);return t}(l.x,r.w,d);return{visible:!0,x:l.x,y:c,textAlign:d,left:u,top:c,right:u+r.w,bottom:c+r.h}}function Ao(t,e){if(!e)return!0;const{left:i,top:s,right:n,bottom:o}=t;return!(Re({x:i,y:s},e)||Re({x:i,y:o},e)||Re({x:n,y:s},e)||Re({x:n,y:o},e))}function To(t,e,i){const{left:n,top:o,right:a,bottom:r}=i,{backdropColor:l}=e;if(!s(l)){const i=wi(e.borderRadius),s=ki(e.backdropPadding);t.fillStyle=l;const h=n-s.left,c=o-s.top,d=a-n+s.width,u=r-o+s.height;Object.values(i).some((t=>0!==t))?(t.beginPath(),He(t,{x:h,y:c,w:d,h:u,radius:i}),t.fill()):t.fillRect(h,c,d,u)}}function Lo(t,e,i,s){const{ctx:n}=t;if(i)n.arc(t.xCenter,t.yCenter,e,0,O);else{let i=t.getPointPosition(0,e);n.moveTo(i.x,i.y);for(let o=1;o<s;o++)i=t.getPointPosition(o,e),n.lineTo(i.x,i.y)}}class Eo extends xo{static id="radialLinear";static defaults={display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,lineWidth:1,borderDash:[],borderDashOffset:0},grid:{circular:!1},startAngle:0,ticks:{showLabelBackdrop:!0,callback:ae.formatters.numeric},pointLabels:{backdropColor:void 0,backdropPadding:2,display:!0,font:{size:10},callback:t=>t,padding:5,centerPointLabels:!1}};static defaultRoutes={"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"};static descriptors={angleLines:{_fallback:"grid"}};constructor(t){super(t),this.xCenter=void 0,this.yCenter=void 0,this.drawingArea=void 0,this._pointLabels=[],this._pointLabelItems=[]}setDimensions(){const t=this._padding=ki(So(this.options)/2),e=this.width=this.maxWidth-t.width,i=this.height=this.maxHeight-t.height;this.xCenter=Math.floor(this.left+e/2+t.left),this.yCenter=Math.floor(this.top+i/2+t.top),this.drawingArea=Math.floor(Math.min(e,i)/2)}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!1);this.min=a(t)&&!isNaN(t)?t:0,this.max=a(e)&&!isNaN(e)?e:0,this.handleTickRangeOptions()}computeTickLimit(){return Math.ceil(this.drawingArea/So(this.options))}generateTickLabels(t){xo.prototype.generateTickLabels.call(this,t),this._pointLabels=this.getLabels().map(((t,e)=>{const i=d(this.options.pointLabels.callback,[t,e],this);return i||0===i?i:""})).filter(((t,e)=>this.chart.getDataVisibility(e)))}fit(){const t=this.options;t.display&&t.pointLabels.display?Do(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(t,e,i,s){this.xCenter+=Math.floor((t-e)/2),this.yCenter+=Math.floor((i-s)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(t,e,i,s))}getIndexAngle(t){return G(t*(O/(this._pointLabels.length||1))+$(this.options.startAngle||0))}getDistanceFromCenterForValue(t){if(s(t))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-t)*e:(t-this.min)*e}getValueForDistanceFromCenter(t){if(s(t))return NaN;const e=t/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(t){const e=this._pointLabels||[];if(t>=0&&t<e.length){const i=e[t];return function(t,e,i){return Ci(t,{label:i,index:e,type:"pointLabel"})}(this.getContext(),t,i)}}getPointPosition(t,e,i=0){const s=this.getIndexAngle(t)-E+i;return{x:Math.cos(s)*e+this.xCenter,y:Math.sin(s)*e+this.yCenter,angle:s}}getPointPositionForValue(t,e){return this.getPointPosition(t,this.getDistanceFromCenterForValue(e))}getBasePosition(t){return this.getPointPositionForValue(t||0,this.getBaseValue())}getPointLabelPosition(t){const{left:e,top:i,right:s,bottom:n}=this._pointLabelItems[t];return{left:e,top:i,right:s,bottom:n}}drawBackground(){const{backgroundColor:t,grid:{circular:e}}=this.options;if(t){const i=this.ctx;i.save(),i.beginPath(),Lo(this,this.getDistanceFromCenterForValue(this._endValue),e,this._pointLabels.length),i.closePath(),i.fillStyle=t,i.fill(),i.restore()}}drawGrid(){const t=this.ctx,e=this.options,{angleLines:i,grid:s,border:n}=e,o=this._pointLabels.length;let a,r,l;if(e.pointLabels.display&&function(t,e){const{ctx:i,options:{pointLabels:s}}=t;for(let n=e-1;n>=0;n--){const e=t._pointLabelItems[n];if(!e.visible)continue;const o=s.setContext(t.getPointLabelContext(n));To(i,o,e);const a=Si(o.font),{x:r,y:l,textAlign:h}=e;Ne(i,t._pointLabels[n],r,l+a.lineHeight/2,a,{color:o.color,textAlign:h,textBaseline:"middle"})}}(this,o),s.display&&this.ticks.forEach(((t,e)=>{if(0!==e||0===e&&this.min<0){r=this.getDistanceFromCenterForValue(t.value);const i=this.getContext(e),a=s.setContext(i),l=n.setContext(i);!function(t,e,i,s,n){const o=t.ctx,a=e.circular,{color:r,lineWidth:l}=e;!a&&!s||!r||!l||i<0||(o.save(),o.strokeStyle=r,o.lineWidth=l,o.setLineDash(n.dash),o.lineDashOffset=n.dashOffset,o.beginPath(),Lo(t,i,a,s),o.closePath(),o.stroke(),o.restore())}(this,a,r,o,l)}})),i.display){for(t.save(),a=o-1;a>=0;a--){const s=i.setContext(this.getPointLabelContext(a)),{color:n,lineWidth:o}=s;o&&n&&(t.lineWidth=o,t.strokeStyle=n,t.setLineDash(s.borderDash),t.lineDashOffset=s.borderDashOffset,r=this.getDistanceFromCenterForValue(e.ticks.reverse?this.min:this.max),l=this.getPointPosition(a,r),t.beginPath(),t.moveTo(this.xCenter,this.yCenter),t.lineTo(l.x,l.y),t.stroke())}t.restore()}}drawBorder(){}drawLabels(){const t=this.ctx,e=this.options,i=e.ticks;if(!i.display)return;const s=this.getIndexAngle(0);let n,o;t.save(),t.translate(this.xCenter,this.yCenter),t.rotate(s),t.textAlign="center",t.textBaseline="middle",this.ticks.forEach(((s,a)=>{if(0===a&&this.min>=0&&!e.reverse)return;const r=i.setContext(this.getContext(a)),l=Si(r.font);if(n=this.getDistanceFromCenterForValue(this.ticks[a].value),r.showLabelBackdrop){t.font=l.string,o=t.measureText(s.label).width,t.fillStyle=r.backdropColor;const e=ki(r.backdropPadding);t.fillRect(-o/2-e.left,-n-l.size/2-e.top,o+e.width,l.size+e.height)}Ne(t,s.label,0,-n,l,{color:r.color,strokeColor:r.textStrokeColor,strokeWidth:r.textStrokeWidth})})),t.restore()}drawTitle(){}}const Ro={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},Io=Object.keys(Ro);function zo(t,e){return t-e}function Fo(t,e){if(s(e))return null;const i=t._adapter,{parser:n,round:o,isoWeekday:r}=t._parseOpts;let l=e;return"function"==typeof n&&(l=n(l)),a(l)||(l="string"==typeof n?i.parse(l,n):i.parse(l)),null===l?null:(o&&(l="week"!==o||!N(r)&&!0!==r?i.startOf(l,o):i.startOf(l,"isoWeek",r)),+l)}function Vo(t,e,i,s){const n=Io.length;for(let o=Io.indexOf(t);o<n-1;++o){const t=Ro[Io[o]],n=t.steps?t.steps:Number.MAX_SAFE_INTEGER;if(t.common&&Math.ceil((i-e)/(n*t.size))<=s)return Io[o]}return Io[n-1]}function Bo(t,e,i){if(i){if(i.length){const{lo:s,hi:n}=et(i,e);t[i[s]>=e?i[s]:i[n]]=!0}}else t[e]=!0}function Wo(t,e,i){const s=[],n={},o=e.length;let a,r;for(a=0;a<o;++a)r=e[a],n[r]=a,s.push({value:r,major:!1});return 0!==o&&i?function(t,e,i,s){const n=t._adapter,o=+n.startOf(e[0].value,s),a=e[e.length-1].value;let r,l;for(r=o;r<=a;r=+n.add(r,1,s))l=i[r],l>=0&&(e[l].major=!0);return e}(t,s,n,i):s}class No extends Js{static id="time";static defaults={bounds:"data",adapters:{},time:{parser:!1,unit:!1,round:!1,isoWeekday:!1,minUnit:"millisecond",displayFormats:{}},ticks:{source:"auto",callback:!1,major:{enabled:!1}}};constructor(t){super(t),this._cache={data:[],labels:[],all:[]},this._unit="day",this._majorUnit=void 0,this._offsets={},this._normalized=!1,this._parseOpts=void 0}init(t,e={}){const i=t.time||(t.time={}),s=this._adapter=new Rn._date(t.adapters.date);s.init(e),b(i.displayFormats,s.formats()),this._parseOpts={parser:i.parser,round:i.round,isoWeekday:i.isoWeekday},super.init(t),this._normalized=e.normalized}parse(t,e){return void 0===t?null:Fo(this,t)}beforeLayout(){super.beforeLayout(),this._cache={data:[],labels:[],all:[]}}determineDataLimits(){const t=this.options,e=this._adapter,i=t.time.unit||"day";let{min:s,max:n,minDefined:o,maxDefined:r}=this.getUserBounds();function l(t){o||isNaN(t.min)||(s=Math.min(s,t.min)),r||isNaN(t.max)||(n=Math.max(n,t.max))}o&&r||(l(this._getLabelBounds()),"ticks"===t.bounds&&"labels"===t.ticks.source||l(this.getMinMax(!1))),s=a(s)&&!isNaN(s)?s:+e.startOf(Date.now(),i),n=a(n)&&!isNaN(n)?n:+e.endOf(Date.now(),i)+1,this.min=Math.min(s,n-1),this.max=Math.max(s+1,n)}_getLabelBounds(){const t=this.getLabelTimestamps();let e=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY;return t.length&&(e=t[0],i=t[t.length-1]),{min:e,max:i}}buildTicks(){const t=this.options,e=t.time,i=t.ticks,s="labels"===i.source?this.getLabelTimestamps():this._generate();"ticks"===t.bounds&&s.length&&(this.min=this._userMin||s[0],this.max=this._userMax||s[s.length-1]);const n=this.min,o=nt(s,n,this.max);return this._unit=e.unit||(i.autoSkip?Vo(e.minUnit,this.min,this.max,this._getLabelCapacity(n)):function(t,e,i,s,n){for(let o=Io.length-1;o>=Io.indexOf(i);o--){const i=Io[o];if(Ro[i].common&&t._adapter.diff(n,s,i)>=e-1)return i}return Io[i?Io.indexOf(i):0]}(this,o.length,e.minUnit,this.min,this.max)),this._majorUnit=i.major.enabled&&"year"!==this._unit?function(t){for(let e=Io.indexOf(t)+1,i=Io.length;e<i;++e)if(Ro[Io[e]].common)return Io[e]}(this._unit):void 0,this.initOffsets(s),t.reverse&&o.reverse(),Wo(this,o,this._majorUnit)}afterAutoSkip(){this.options.offsetAfterAutoskip&&this.initOffsets(this.ticks.map((t=>+t.value)))}initOffsets(t=[]){let e,i,s=0,n=0;this.options.offset&&t.length&&(e=this.getDecimalForValue(t[0]),s=1===t.length?1-e:(this.getDecimalForValue(t[1])-e)/2,i=this.getDecimalForValue(t[t.length-1]),n=1===t.length?i:(i-this.getDecimalForValue(t[t.length-2]))/2);const o=t.length<3?.5:.25;s=J(s,0,o),n=J(n,0,o),this._offsets={start:s,end:n,factor:1/(s+1+n)}}_generate(){const t=this._adapter,e=this.min,i=this.max,s=this.options,n=s.time,o=n.unit||Vo(n.minUnit,e,i,this._getLabelCapacity(e)),a=l(s.ticks.stepSize,1),r="week"===o&&n.isoWeekday,h=N(r)||!0===r,c={};let d,u,f=e;if(h&&(f=+t.startOf(f,"isoWeek",r)),f=+t.startOf(f,h?"day":o),t.diff(i,e,o)>1e5*a)throw new Error(e+" and "+i+" are too far apart with stepSize of "+a+" "+o);const g="data"===s.ticks.source&&this.getDataTimestamps();for(d=f,u=0;d<i;d=+t.add(d,a,o),u++)Bo(c,d,g);return d!==i&&"ticks"!==s.bounds&&1!==u||Bo(c,d,g),Object.keys(c).sort(zo).map((t=>+t))}getLabelForValue(t){const e=this._adapter,i=this.options.time;return i.tooltipFormat?e.format(t,i.tooltipFormat):e.format(t,i.displayFormats.datetime)}format(t,e){const i=this.options.time.displayFormats,s=this._unit,n=e||i[s];return this._adapter.format(t,n)}_tickFormatFunction(t,e,i,s){const n=this.options,o=n.ticks.callback;if(o)return d(o,[t,e,i],this);const a=n.time.displayFormats,r=this._unit,l=this._majorUnit,h=r&&a[r],c=l&&a[l],u=i[e],f=l&&c&&u&&u.major;return this._adapter.format(t,s||(f?c:h))}generateTickLabels(t){let e,i,s;for(e=0,i=t.length;e<i;++e)s=t[e],s.label=this._tickFormatFunction(s.value,e,t)}getDecimalForValue(t){return null===t?NaN:(t-this.min)/(this.max-this.min)}getPixelForValue(t){const e=this._offsets,i=this.getDecimalForValue(t);return this.getPixelForDecimal((e.start+i)*e.factor)}getValueForPixel(t){const e=this._offsets,i=this.getDecimalForPixel(t)/e.factor-e.end;return this.min+i*(this.max-this.min)}_getLabelSize(t){const e=this.options.ticks,i=this.ctx.measureText(t).width,s=$(this.isHorizontal()?e.maxRotation:e.minRotation),n=Math.cos(s),o=Math.sin(s),a=this._resolveTickFontOptions(0).size;return{w:i*n+a*o,h:i*o+a*n}}_getLabelCapacity(t){const e=this.options.time,i=e.displayFormats,s=i[e.unit]||i.millisecond,n=this._tickFormatFunction(t,0,Wo(this,[t],this._majorUnit),s),o=this._getLabelSize(n),a=Math.floor(this.isHorizontal()?this.width/o.w:this.height/o.h)-1;return a>0?a:1}getDataTimestamps(){let t,e,i=this._cache.data||[];if(i.length)return i;const s=this.getMatchingVisibleMetas();if(this._normalized&&s.length)return this._cache.data=s[0].controller.getAllParsedValues(this);for(t=0,e=s.length;t<e;++t)i=i.concat(s[t].controller.getAllParsedValues(this));return this._cache.data=this.normalize(i)}getLabelTimestamps(){const t=this._cache.labels||[];let e,i;if(t.length)return t;const s=this.getLabels();for(e=0,i=s.length;e<i;++e)t.push(Fo(this,s[e]));return this._cache.labels=this._normalized?t:this.normalize(t)}normalize(t){return lt(t.sort(zo))}}function Ho(t,e,i){let s,n,o,a,r=0,l=t.length-1;i?(e>=t[r].pos&&e<=t[l].pos&&({lo:r,hi:l}=it(t,"pos",e)),({pos:s,time:o}=t[r]),({pos:n,time:a}=t[l])):(e>=t[r].time&&e<=t[l].time&&({lo:r,hi:l}=it(t,"time",e)),({time:s,pos:o}=t[r]),({time:n,pos:a}=t[l]));const h=n-s;return h?o+(a-o)*(e-s)/h:o}var jo=Object.freeze({__proto__:null,CategoryScale:class extends Js{static id="category";static defaults={ticks:{callback:po}};constructor(t){super(t),this._startValue=void 0,this._valueRange=0,this._addedLabels=[]}init(t){const e=this._addedLabels;if(e.length){const t=this.getLabels();for(const{index:i,label:s}of e)t[i]===s&&t.splice(i,1);this._addedLabels=[]}super.init(t)}parse(t,e){if(s(t))return null;const i=this.getLabels();return((t,e)=>null===t?null:J(Math.round(t),0,e))(e=isFinite(e)&&i[e]===t?e:go(i,t,l(e,t),this._addedLabels),i.length-1)}determineDataLimits(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let{min:i,max:s}=this.getMinMax(!0);"ticks"===this.options.bounds&&(t||(i=0),e||(s=this.getLabels().length-1)),this.min=i,this.max=s}buildTicks(){const t=this.min,e=this.max,i=this.options.offset,s=[];let n=this.getLabels();n=0===t&&e===n.length-1?n:n.slice(t,e+1),this._valueRange=Math.max(n.length-(i?0:1),1),this._startValue=this.min-(i?.5:0);for(let i=t;i<=e;i++)s.push({value:i});return s}getLabelForValue(t){return po.call(this,t)}configure(){super.configure(),this.isHorizontal()||(this._reversePixels=!this._reversePixels)}getPixelForValue(t){return"number"!=typeof t&&(t=this.parse(t)),null===t?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getPixelForTick(t){const e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t].value)}getValueForPixel(t){return Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange)}getBasePixel(){return this.bottom}},LinearScale:bo,LogarithmicScale:ko,RadialLinearScale:Eo,TimeScale:No,TimeSeriesScale:class extends No{static id="timeseries";static defaults=No.defaults;constructor(t){super(t),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const t=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(t);this._minPos=Ho(e,this.min),this._tableRange=Ho(e,this.max)-this._minPos,super.initOffsets(t)}buildLookupTable(t){const{min:e,max:i}=this,s=[],n=[];let o,a,r,l,h;for(o=0,a=t.length;o<a;++o)l=t[o],l>=e&&l<=i&&s.push(l);if(s.length<2)return[{time:e,pos:0},{time:i,pos:1}];for(o=0,a=s.length;o<a;++o)h=s[o+1],r=s[o-1],l=s[o],Math.round((h+r)/2)!==l&&n.push({time:l,pos:o/(a-1)});return n}_generate(){const t=this.min,e=this.max;let i=super.getDataTimestamps();return i.includes(t)&&i.length||i.splice(0,0,t),i.includes(e)&&1!==i.length||i.push(e),i.sort(((t,e)=>t-e))}_getTimestampsForTable(){let t=this._cache.all||[];if(t.length)return t;const e=this.getDataTimestamps(),i=this.getLabelTimestamps();return t=e.length&&i.length?this.normalize(e.concat(i)):e.length?e:i,t=this._cache.all=t,t}getDecimalForValue(t){return(Ho(this._table,t)-this._minPos)/this._tableRange}getValueForPixel(t){const e=this._offsets,i=this.getDecimalForPixel(t)/e.factor-e.end;return Ho(this._table,i*this._tableRange+this._minPos,!0)}}});const $o=["rgb(54, 162, 235)","rgb(255, 99, 132)","rgb(255, 159, 64)","rgb(255, 205, 86)","rgb(75, 192, 192)","rgb(153, 102, 255)","rgb(201, 203, 207)"],Yo=$o.map((t=>t.replace("rgb(","rgba(").replace(")",", 0.5)")));function Uo(t){return $o[t%$o.length]}function Xo(t){return Yo[t%Yo.length]}function qo(t){let e=0;return(i,s)=>{const n=t.getDatasetMeta(s).controller;n instanceof jn?e=function(t,e){return t.backgroundColor=t.data.map((()=>Uo(e++))),e}(i,e):n instanceof $n?e=function(t,e){return t.backgroundColor=t.data.map((()=>Xo(e++))),e}(i,e):n&&(e=function(t,e){return t.borderColor=Uo(e),t.backgroundColor=Xo(e),++e}(i,e))}}function Ko(t){let e;for(e in t)if(t[e].borderColor||t[e].backgroundColor)return!0;return!1}var Go={id:"colors",defaults:{enabled:!0,forceOverride:!1},beforeLayout(t,e,i){if(!i.enabled)return;const{data:{datasets:s},options:n}=t.config,{elements:o}=n;if(!i.forceOverride&&(Ko(s)||(a=n)&&(a.borderColor||a.backgroundColor)||o&&Ko(o)))return;var a;const r=qo(t);s.forEach(r)}};function Zo(t){if(t._decimated){const e=t._data;delete t._decimated,delete t._data,Object.defineProperty(t,"data",{configurable:!0,enumerable:!0,writable:!0,value:e})}}function Jo(t){t.data.datasets.forEach((t=>{Zo(t)}))}var Qo={id:"decimation",defaults:{algorithm:"min-max",enabled:!1},beforeElementsUpdate:(t,e,i)=>{if(!i.enabled)return void Jo(t);const n=t.width;t.data.datasets.forEach(((e,o)=>{const{_data:a,indexAxis:r}=e,l=t.getDatasetMeta(o),h=a||e.data;if("y"===Pi([r,t.options.indexAxis]))return;if(!l.controller.supportsDecimation)return;const c=t.scales[l.xAxisID];if("linear"!==c.type&&"time"!==c.type)return;if(t.options.parsing)return;let{start:d,count:u}=function(t,e){const i=e.length;let s,n=0;const{iScale:o}=t,{min:a,max:r,minDefined:l,maxDefined:h}=o.getUserBounds();return l&&(n=J(it(e,o.axis,a).lo,0,i-1)),s=h?J(it(e,o.axis,r).hi+1,n,i)-n:i-n,{start:n,count:s}}(l,h);if(u<=(i.threshold||4*n))return void Zo(e);let f;switch(s(a)&&(e._data=h,delete e.data,Object.defineProperty(e,"data",{configurable:!0,enumerable:!0,get:function(){return this._decimated},set:function(t){this._data=t}})),i.algorithm){case"lttb":f=function(t,e,i,s,n){const o=n.samples||s;if(o>=i)return t.slice(e,e+i);const a=[],r=(i-2)/(o-2);let l=0;const h=e+i-1;let c,d,u,f,g,p=e;for(a[l++]=t[p],c=0;c<o-2;c++){let s,n=0,o=0;const h=Math.floor((c+1)*r)+1+e,m=Math.min(Math.floor((c+2)*r)+1,i)+e,x=m-h;for(s=h;s<m;s++)n+=t[s].x,o+=t[s].y;n/=x,o/=x;const b=Math.floor(c*r)+1+e,_=Math.min(Math.floor((c+1)*r)+1,i)+e,{x:y,y:v}=t[p];for(u=f=-1,s=b;s<_;s++)f=.5*Math.abs((y-n)*(t[s].y-v)-(y-t[s].x)*(o-v)),f>u&&(u=f,d=t[s],g=s);a[l++]=d,p=g}return a[l++]=t[h],a}(h,d,u,n,i);break;case"min-max":f=function(t,e,i,n){let o,a,r,l,h,c,d,u,f,g,p=0,m=0;const x=[],b=e+i-1,_=t[e].x,y=t[b].x-_;for(o=e;o<e+i;++o){a=t[o],r=(a.x-_)/y*n,l=a.y;const e=0|r;if(e===h)l<f?(f=l,c=o):l>g&&(g=l,d=o),p=(m*p+a.x)/++m;else{const i=o-1;if(!s(c)&&!s(d)){const e=Math.min(c,d),s=Math.max(c,d);e!==u&&e!==i&&x.push({...t[e],x:p}),s!==u&&s!==i&&x.push({...t[s],x:p})}o>0&&i!==u&&x.push(t[i]),x.push(a),h=e,m=0,f=g=l,c=d=u=o}}return x}(h,d,u,n);break;default:throw new Error(`Unsupported decimation algorithm '${i.algorithm}'`)}e._decimated=f}))},destroy(t){Jo(t)}};function ta(t,e,i,s){if(s)return;let n=e[t],o=i[t];return"angle"===t&&(n=G(n),o=G(o)),{property:t,start:n,end:o}}function ea(t,e,i){for(;e>t;e--){const t=i[e];if(!isNaN(t.x)&&!isNaN(t.y))break}return e}function ia(t,e,i,s){return t&&e?s(t[i],e[i]):t?t[i]:e?e[i]:0}function sa(t,e){let i=[],s=!1;return n(t)?(s=!0,i=t):i=function(t,e){const{x:i=null,y:s=null}=t||{},n=e.points,o=[];return e.segments.forEach((({start:t,end:e})=>{e=ea(t,e,n);const a=n[t],r=n[e];null!==s?(o.push({x:a.x,y:s}),o.push({x:r.x,y:s})):null!==i&&(o.push({x:i,y:a.y}),o.push({x:i,y:r.y}))})),o}(t,e),i.length?new no({points:i,options:{tension:0},_loop:s,_fullLoop:s}):null}function na(t){return t&&!1!==t.fill}function oa(t,e,i){let s=t[e].fill;const n=[e];let o;if(!i)return s;for(;!1!==s&&-1===n.indexOf(s);){if(!a(s))return s;if(o=t[s],!o)return!1;if(o.visible)return s;n.push(s),s=o.fill}return!1}function aa(t,e,i){const s=function(t){const e=t.options,i=e.fill;let s=l(i&&i.target,i);void 0===s&&(s=!!e.backgroundColor);if(!1===s||null===s)return!1;if(!0===s)return"origin";return s}(t);if(o(s))return!isNaN(s.value)&&s;let n=parseFloat(s);return a(n)&&Math.floor(n)===n?function(t,e,i,s){"-"!==t&&"+"!==t||(i=e+i);if(i===e||i<0||i>=s)return!1;return i}(s[0],e,n,i):["origin","start","end","stack","shape"].indexOf(s)>=0&&s}function ra(t,e,i){const s=[];for(let n=0;n<i.length;n++){const o=i[n],{first:a,last:r,point:l}=la(o,e,"x");if(!(!l||a&&r))if(a)s.unshift(l);else if(t.push(l),!r)break}t.push(...s)}function la(t,e,i){const s=t.interpolate(e,i);if(!s)return{};const n=s[i],o=t.segments,a=t.points;let r=!1,l=!1;for(let t=0;t<o.length;t++){const e=o[t],s=a[e.start][i],h=a[e.end][i];if(tt(n,s,h)){r=n===s,l=n===h;break}}return{first:r,last:l,point:s}}class ha{constructor(t){this.x=t.x,this.y=t.y,this.radius=t.radius}pathSegment(t,e,i){const{x:s,y:n,radius:o}=this;return e=e||{start:0,end:O},t.arc(s,n,o,e.end,e.start,!0),!i.bounds}interpolate(t){const{x:e,y:i,radius:s}=this,n=t.angle;return{x:e+Math.cos(n)*s,y:i+Math.sin(n)*s,angle:n}}}function ca(t){const{chart:e,fill:i,line:s}=t;if(a(i))return function(t,e){const i=t.getDatasetMeta(e),s=i&&t.isDatasetVisible(e);return s?i.dataset:null}(e,i);if("stack"===i)return function(t){const{scale:e,index:i,line:s}=t,n=[],o=s.segments,a=s.points,r=function(t,e){const i=[],s=t.getMatchingVisibleMetas("line");for(let t=0;t<s.length;t++){const n=s[t];if(n.index===e)break;n.hidden||i.unshift(n.dataset)}return i}(e,i);r.push(sa({x:null,y:e.bottom},s));for(let t=0;t<o.length;t++){const e=o[t];for(let t=e.start;t<=e.end;t++)ra(n,a[t],r)}return new no({points:n,options:{}})}(t);if("shape"===i)return!0;const n=function(t){const e=t.scale||{};if(e.getPointPositionForValue)return function(t){const{scale:e,fill:i}=t,s=e.options,n=e.getLabels().length,a=s.reverse?e.max:e.min,r=function(t,e,i){let s;return s="start"===t?i:"end"===t?e.options.reverse?e.min:e.max:o(t)?t.value:e.getBaseValue(),s}(i,e,a),l=[];if(s.grid.circular){const t=e.getPointPositionForValue(0,a);return new ha({x:t.x,y:t.y,radius:e.getDistanceFromCenterForValue(r)})}for(let t=0;t<n;++t)l.push(e.getPointPositionForValue(t,r));return l}(t);return function(t){const{scale:e={},fill:i}=t,s=function(t,e){let i=null;return"start"===t?i=e.bottom:"end"===t?i=e.top:o(t)?i=e.getPixelForValue(t.value):e.getBasePixel&&(i=e.getBasePixel()),i}(i,e);if(a(s)){const t=e.isHorizontal();return{x:t?s:null,y:t?null:s}}return null}(t)}(t);return n instanceof ha?n:sa(n,s)}function da(t,e,i){const s=ca(e),{line:n,scale:o,axis:a}=e,r=n.options,l=r.fill,h=r.backgroundColor,{above:c=h,below:d=h}=l||{};s&&n.points.length&&(Ie(t,i),function(t,e){const{line:i,target:s,above:n,below:o,area:a,scale:r}=e,l=i._loop?"angle":e.axis;t.save(),"x"===l&&o!==n&&(ua(t,s,a.top),fa(t,{line:i,target:s,color:n,scale:r,property:l}),t.restore(),t.save(),ua(t,s,a.bottom));fa(t,{line:i,target:s,color:o,scale:r,property:l}),t.restore()}(t,{line:n,target:s,above:c,below:d,area:i,scale:o,axis:a}),ze(t))}function ua(t,e,i){const{segments:s,points:n}=e;let o=!0,a=!1;t.beginPath();for(const r of s){const{start:s,end:l}=r,h=n[s],c=n[ea(s,l,n)];o?(t.moveTo(h.x,h.y),o=!1):(t.lineTo(h.x,i),t.lineTo(h.x,h.y)),a=!!e.pathSegment(t,r,{move:a}),a?t.closePath():t.lineTo(c.x,i)}t.lineTo(e.first().x,i),t.closePath(),t.clip()}function fa(t,e){const{line:i,target:s,property:n,color:o,scale:a}=e,r=function(t,e,i){const s=t.segments,n=t.points,o=e.points,a=[];for(const t of s){let{start:s,end:r}=t;r=ea(s,r,n);const l=ta(i,n[s],n[r],t.loop);if(!e.segments){a.push({source:t,target:l,start:n[s],end:n[r]});continue}const h=Ii(e,l);for(const e of h){const s=ta(i,o[e.start],o[e.end],e.loop),r=Ri(t,n,s);for(const t of r)a.push({source:t,target:e,start:{[i]:ia(l,s,"start",Math.max)},end:{[i]:ia(l,s,"end",Math.min)}})}}return a}(i,s,n);for(const{source:e,target:l,start:h,end:c}of r){const{style:{backgroundColor:r=o}={}}=e,d=!0!==s;t.save(),t.fillStyle=r,ga(t,a,d&&ta(n,h,c)),t.beginPath();const u=!!i.pathSegment(t,e);let f;if(d){u?t.closePath():pa(t,s,c,n);const e=!!s.pathSegment(t,l,{move:u,reverse:!0});f=u&&e,f||pa(t,s,h,n)}t.closePath(),t.fill(f?"evenodd":"nonzero"),t.restore()}}function ga(t,e,i){const{top:s,bottom:n}=e.chart.chartArea,{property:o,start:a,end:r}=i||{};"x"===o&&(t.beginPath(),t.rect(a,s,r-a,n-s),t.clip())}function pa(t,e,i,s){const n=e.interpolate(i,s);n&&t.lineTo(n.x,n.y)}var ma={id:"filler",afterDatasetsUpdate(t,e,i){const s=(t.data.datasets||[]).length,n=[];let o,a,r,l;for(a=0;a<s;++a)o=t.getDatasetMeta(a),r=o.dataset,l=null,r&&r.options&&r instanceof no&&(l={visible:t.isDatasetVisible(a),index:a,fill:aa(r,a,s),chart:t,axis:o.controller.options.indexAxis,scale:o.vScale,line:r}),o.$filler=l,n.push(l);for(a=0;a<s;++a)l=n[a],l&&!1!==l.fill&&(l.fill=oa(n,a,i.propagate))},beforeDraw(t,e,i){const s="beforeDraw"===i.drawTime,n=t.getSortedVisibleDatasetMetas(),o=t.chartArea;for(let e=n.length-1;e>=0;--e){const i=n[e].$filler;i&&(i.line.updateControlPoints(o,i.axis),s&&i.fill&&da(t.ctx,i,o))}},beforeDatasetsDraw(t,e,i){if("beforeDatasetsDraw"!==i.drawTime)return;const s=t.getSortedVisibleDatasetMetas();for(let e=s.length-1;e>=0;--e){const i=s[e].$filler;na(i)&&da(t.ctx,i,t.chartArea)}},beforeDatasetDraw(t,e,i){const s=e.meta.$filler;na(s)&&"beforeDatasetDraw"===i.drawTime&&da(t.ctx,s,t.chartArea)},defaults:{propagate:!0,drawTime:"beforeDatasetDraw"}};const xa=(t,e)=>{let{boxHeight:i=e,boxWidth:s=e}=t;return t.usePointStyle&&(i=Math.min(i,e),s=t.pointStyleWidth||Math.min(s,e)),{boxWidth:s,boxHeight:i,itemHeight:Math.max(e,i)}};class ba extends Hs{constructor(t){super(),this._added=!1,this.legendHitBoxes=[],this._hoveredItem=null,this.doughnutMode=!1,this.chart=t.chart,this.options=t.options,this.ctx=t.ctx,this.legendItems=void 0,this.columnSizes=void 0,this.lineWidths=void 0,this.maxHeight=void 0,this.maxWidth=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.height=void 0,this.width=void 0,this._margins=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(t,e,i){this.maxWidth=t,this.maxHeight=e,this._margins=i,this.setDimensions(),this.buildLabels(),this.fit()}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=this._margins.left,this.right=this.width):(this.height=this.maxHeight,this.top=this._margins.top,this.bottom=this.height)}buildLabels(){const t=this.options.labels||{};let e=d(t.generateLabels,[this.chart],this)||[];t.filter&&(e=e.filter((e=>t.filter(e,this.chart.data)))),t.sort&&(e=e.sort(((e,i)=>t.sort(e,i,this.chart.data)))),this.options.reverse&&e.reverse(),this.legendItems=e}fit(){const{options:t,ctx:e}=this;if(!t.display)return void(this.width=this.height=0);const i=t.labels,s=Si(i.font),n=s.size,o=this._computeTitleHeight(),{boxWidth:a,itemHeight:r}=xa(i,n);let l,h;e.font=s.string,this.isHorizontal()?(l=this.maxWidth,h=this._fitRows(o,n,a,r)+10):(h=this.maxHeight,l=this._fitCols(o,s,a,r)+10),this.width=Math.min(l,t.maxWidth||this.maxWidth),this.height=Math.min(h,t.maxHeight||this.maxHeight)}_fitRows(t,e,i,s){const{ctx:n,maxWidth:o,options:{labels:{padding:a}}}=this,r=this.legendHitBoxes=[],l=this.lineWidths=[0],h=s+a;let c=t;n.textAlign="left",n.textBaseline="middle";let d=-1,u=-h;return this.legendItems.forEach(((t,f)=>{const g=i+e/2+n.measureText(t.text).width;(0===f||l[l.length-1]+g+2*a>o)&&(c+=h,l[l.length-(f>0?0:1)]=0,u+=h,d++),r[f]={left:0,top:u,row:d,width:g,height:s},l[l.length-1]+=g+a})),c}_fitCols(t,e,i,s){const{ctx:n,maxHeight:o,options:{labels:{padding:a}}}=this,r=this.legendHitBoxes=[],l=this.columnSizes=[],h=o-t;let c=a,d=0,u=0,f=0,g=0;return this.legendItems.forEach(((t,o)=>{const{itemWidth:p,itemHeight:m}=function(t,e,i,s,n){const o=function(t,e,i,s){let n=t.text;n&&"string"!=typeof n&&(n=n.reduce(((t,e)=>t.length>e.length?t:e)));return e+i.size/2+s.measureText(n).width}(s,t,e,i),a=function(t,e,i){let s=t;"string"!=typeof e.text&&(s=_a(e,i));return s}(n,s,e.lineHeight);return{itemWidth:o,itemHeight:a}}(i,e,n,t,s);o>0&&u+m+2*a>h&&(c+=d+a,l.push({width:d,height:u}),f+=d+a,g++,d=u=0),r[o]={left:f,top:u,col:g,width:p,height:m},d=Math.max(d,p),u+=m+a})),c+=d,l.push({width:d,height:u}),c}adjustHitBoxes(){if(!this.options.display)return;const t=this._computeTitleHeight(),{legendHitBoxes:e,options:{align:i,labels:{padding:s},rtl:n}}=this,o=Oi(n,this.left,this.width);if(this.isHorizontal()){let n=0,a=ft(i,this.left+s,this.right-this.lineWidths[n]);for(const r of e)n!==r.row&&(n=r.row,a=ft(i,this.left+s,this.right-this.lineWidths[n])),r.top+=this.top+t+s,r.left=o.leftForLtr(o.x(a),r.width),a+=r.width+s}else{let n=0,a=ft(i,this.top+t+s,this.bottom-this.columnSizes[n].height);for(const r of e)r.col!==n&&(n=r.col,a=ft(i,this.top+t+s,this.bottom-this.columnSizes[n].height)),r.top=a,r.left+=this.left+s,r.left=o.leftForLtr(o.x(r.left),r.width),a+=r.height+s}}isHorizontal(){return"top"===this.options.position||"bottom"===this.options.position}draw(){if(this.options.display){const t=this.ctx;Ie(t,this),this._draw(),ze(t)}}_draw(){const{options:t,columnSizes:e,lineWidths:i,ctx:s}=this,{align:n,labels:o}=t,a=ue.color,r=Oi(t.rtl,this.left,this.width),h=Si(o.font),{padding:c}=o,d=h.size,u=d/2;let f;this.drawTitle(),s.textAlign=r.textAlign("left"),s.textBaseline="middle",s.lineWidth=.5,s.font=h.string;const{boxWidth:g,boxHeight:p,itemHeight:m}=xa(o,d),x=this.isHorizontal(),b=this._computeTitleHeight();f=x?{x:ft(n,this.left+c,this.right-i[0]),y:this.top+c+b,line:0}:{x:this.left+c,y:ft(n,this.top+b+c,this.bottom-e[0].height),line:0},Ai(this.ctx,t.textDirection);const _=m+c;this.legendItems.forEach(((y,v)=>{s.strokeStyle=y.fontColor,s.fillStyle=y.fontColor;const M=s.measureText(y.text).width,w=r.textAlign(y.textAlign||(y.textAlign=o.textAlign)),k=g+u+M;let S=f.x,P=f.y;r.setWidth(this.width),x?v>0&&S+k+c>this.right&&(P=f.y+=_,f.line++,S=f.x=ft(n,this.left+c,this.right-i[f.line])):v>0&&P+_>this.bottom&&(S=f.x=S+e[f.line].width+c,f.line++,P=f.y=ft(n,this.top+b+c,this.bottom-e[f.line].height));if(function(t,e,i){if(isNaN(g)||g<=0||isNaN(p)||p<0)return;s.save();const n=l(i.lineWidth,1);if(s.fillStyle=l(i.fillStyle,a),s.lineCap=l(i.lineCap,"butt"),s.lineDashOffset=l(i.lineDashOffset,0),s.lineJoin=l(i.lineJoin,"miter"),s.lineWidth=n,s.strokeStyle=l(i.strokeStyle,a),s.setLineDash(l(i.lineDash,[])),o.usePointStyle){const a={radius:p*Math.SQRT2/2,pointStyle:i.pointStyle,rotation:i.rotation,borderWidth:n},l=r.xPlus(t,g/2);Ee(s,a,l,e+u,o.pointStyleWidth&&g)}else{const o=e+Math.max((d-p)/2,0),a=r.leftForLtr(t,g),l=wi(i.borderRadius);s.beginPath(),Object.values(l).some((t=>0!==t))?He(s,{x:a,y:o,w:g,h:p,radius:l}):s.rect(a,o,g,p),s.fill(),0!==n&&s.stroke()}s.restore()}(r.x(S),P,y),S=gt(w,S+g+u,x?S+k:this.right,t.rtl),function(t,e,i){Ne(s,i.text,t,e+m/2,h,{strikethrough:i.hidden,textAlign:r.textAlign(i.textAlign)})}(r.x(S),P,y),x)f.x+=k+c;else if("string"!=typeof y.text){const t=h.lineHeight;f.y+=_a(y,t)+c}else f.y+=_})),Ti(this.ctx,t.textDirection)}drawTitle(){const t=this.options,e=t.title,i=Si(e.font),s=ki(e.padding);if(!e.display)return;const n=Oi(t.rtl,this.left,this.width),o=this.ctx,a=e.position,r=i.size/2,l=s.top+r;let h,c=this.left,d=this.width;if(this.isHorizontal())d=Math.max(...this.lineWidths),h=this.top+l,c=ft(t.align,c,this.right-d);else{const e=this.columnSizes.reduce(((t,e)=>Math.max(t,e.height)),0);h=l+ft(t.align,this.top,this.bottom-e-t.labels.padding-this._computeTitleHeight())}const u=ft(a,c,c+d);o.textAlign=n.textAlign(ut(a)),o.textBaseline="middle",o.strokeStyle=e.color,o.fillStyle=e.color,o.font=i.string,Ne(o,e.text,u,h,i)}_computeTitleHeight(){const t=this.options.title,e=Si(t.font),i=ki(t.padding);return t.display?e.lineHeight+i.height:0}_getLegendItemAt(t,e){let i,s,n;if(tt(t,this.left,this.right)&&tt(e,this.top,this.bottom))for(n=this.legendHitBoxes,i=0;i<n.length;++i)if(s=n[i],tt(t,s.left,s.left+s.width)&&tt(e,s.top,s.top+s.height))return this.legendItems[i];return null}handleEvent(t){const e=this.options;if(!function(t,e){if(("mousemove"===t||"mouseout"===t)&&(e.onHover||e.onLeave))return!0;if(e.onClick&&("click"===t||"mouseup"===t))return!0;return!1}(t.type,e))return;const i=this._getLegendItemAt(t.x,t.y);if("mousemove"===t.type||"mouseout"===t.type){const o=this._hoveredItem,a=(n=i,null!==(s=o)&&null!==n&&s.datasetIndex===n.datasetIndex&&s.index===n.index);o&&!a&&d(e.onLeave,[t,o,this],this),this._hoveredItem=i,i&&!a&&d(e.onHover,[t,i,this],this)}else i&&d(e.onClick,[t,i,this],this);var s,n}}function _a(t,e){return e*(t.text?t.text.length:0)}var ya={id:"legend",_element:ba,start(t,e,i){const s=t.legend=new ba({ctx:t.ctx,options:i,chart:t});as.configure(t,s,i),as.addBox(t,s)},stop(t){as.removeBox(t,t.legend),delete t.legend},beforeUpdate(t,e,i){const s=t.legend;as.configure(t,s,i),s.options=i},afterUpdate(t){const e=t.legend;e.buildLabels(),e.adjustHitBoxes()},afterEvent(t,e){e.replay||t.legend.handleEvent(e.event)},defaults:{display:!0,position:"top",align:"center",fullSize:!0,reverse:!1,weight:1e3,onClick(t,e,i){const s=e.datasetIndex,n=i.chart;n.isDatasetVisible(s)?(n.hide(s),e.hidden=!0):(n.show(s),e.hidden=!1)},onHover:null,onLeave:null,labels:{color:t=>t.chart.options.color,boxWidth:40,padding:10,generateLabels(t){const e=t.data.datasets,{labels:{usePointStyle:i,pointStyle:s,textAlign:n,color:o,useBorderRadius:a,borderRadius:r}}=t.legend.options;return t._getSortedDatasetMetas().map((t=>{const l=t.controller.getStyle(i?0:void 0),h=ki(l.borderWidth);return{text:e[t.index].label,fillStyle:l.backgroundColor,fontColor:o,hidden:!t.visible,lineCap:l.borderCapStyle,lineDash:l.borderDash,lineDashOffset:l.borderDashOffset,lineJoin:l.borderJoinStyle,lineWidth:(h.width+h.height)/4,strokeStyle:l.borderColor,pointStyle:s||l.pointStyle,rotation:l.rotation,textAlign:n||l.textAlign,borderRadius:a&&(r||l.borderRadius),datasetIndex:t.index}}),this)}},title:{color:t=>t.chart.options.color,display:!1,position:"center",text:""}},descriptors:{_scriptable:t=>!t.startsWith("on"),labels:{_scriptable:t=>!["generateLabels","filter","sort"].includes(t)}}};class va extends Hs{constructor(t){super(),this.chart=t.chart,this.options=t.options,this.ctx=t.ctx,this._padding=void 0,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.width=void 0,this.height=void 0,this.position=void 0,this.weight=void 0,this.fullSize=void 0}update(t,e){const i=this.options;if(this.left=0,this.top=0,!i.display)return void(this.width=this.height=this.right=this.bottom=0);this.width=this.right=t,this.height=this.bottom=e;const s=n(i.text)?i.text.length:1;this._padding=ki(i.padding);const o=s*Si(i.font).lineHeight+this._padding.height;this.isHorizontal()?this.height=o:this.width=o}isHorizontal(){const t=this.options.position;return"top"===t||"bottom"===t}_drawArgs(t){const{top:e,left:i,bottom:s,right:n,options:o}=this,a=o.align;let r,l,h,c=0;return this.isHorizontal()?(l=ft(a,i,n),h=e+t,r=n-i):("left"===o.position?(l=i+t,h=ft(a,s,e),c=-.5*C):(l=n-t,h=ft(a,e,s),c=.5*C),r=s-e),{titleX:l,titleY:h,maxWidth:r,rotation:c}}draw(){const t=this.ctx,e=this.options;if(!e.display)return;const i=Si(e.font),s=i.lineHeight/2+this._padding.top,{titleX:n,titleY:o,maxWidth:a,rotation:r}=this._drawArgs(s);Ne(t,e.text,0,0,i,{color:e.color,maxWidth:a,rotation:r,textAlign:ut(e.align),textBaseline:"middle",translation:[n,o]})}}var Ma={id:"title",_element:va,start(t,e,i){!function(t,e){const i=new va({ctx:t.ctx,options:e,chart:t});as.configure(t,i,e),as.addBox(t,i),t.titleBlock=i}(t,i)},stop(t){const e=t.titleBlock;as.removeBox(t,e),delete t.titleBlock},beforeUpdate(t,e,i){const s=t.titleBlock;as.configure(t,s,i),s.options=i},defaults:{align:"center",display:!1,font:{weight:"bold"},fullSize:!0,padding:10,position:"top",text:"",weight:2e3},defaultRoutes:{color:"color"},descriptors:{_scriptable:!0,_indexable:!1}};const wa=new WeakMap;var ka={id:"subtitle",start(t,e,i){const s=new va({ctx:t.ctx,options:i,chart:t});as.configure(t,s,i),as.addBox(t,s),wa.set(t,s)},stop(t){as.removeBox(t,wa.get(t)),wa.delete(t)},beforeUpdate(t,e,i){const s=wa.get(t);as.configure(t,s,i),s.options=i},defaults:{align:"center",display:!1,font:{weight:"normal"},fullSize:!0,padding:0,position:"top",text:"",weight:1500},defaultRoutes:{color:"color"},descriptors:{_scriptable:!0,_indexable:!1}};const Sa={average(t){if(!t.length)return!1;let e,i,s=new Set,n=0,o=0;for(e=0,i=t.length;e<i;++e){const i=t[e].element;if(i&&i.hasValue()){const t=i.tooltipPosition();s.add(t.x),n+=t.y,++o}}return{x:[...s].reduce(((t,e)=>t+e))/s.size,y:n/o}},nearest(t,e){if(!t.length)return!1;let i,s,n,o=e.x,a=e.y,r=Number.POSITIVE_INFINITY;for(i=0,s=t.length;i<s;++i){const s=t[i].element;if(s&&s.hasValue()){const t=q(e,s.getCenterPoint());t<r&&(r=t,n=s)}}if(n){const t=n.tooltipPosition();o=t.x,a=t.y}return{x:o,y:a}}};function Pa(t,e){return e&&(n(e)?Array.prototype.push.apply(t,e):t.push(e)),t}function Da(t){return("string"==typeof t||t instanceof String)&&t.indexOf("\n")>-1?t.split("\n"):t}function Ca(t,e){const{element:i,datasetIndex:s,index:n}=e,o=t.getDatasetMeta(s).controller,{label:a,value:r}=o.getLabelAndValue(n);return{chart:t,label:a,parsed:o.getParsed(n),raw:t.data.datasets[s].data[n],formattedValue:r,dataset:o.getDataset(),dataIndex:n,datasetIndex:s,element:i}}function Oa(t,e){const i=t.chart.ctx,{body:s,footer:n,title:o}=t,{boxWidth:a,boxHeight:r}=e,l=Si(e.bodyFont),h=Si(e.titleFont),c=Si(e.footerFont),d=o.length,f=n.length,g=s.length,p=ki(e.padding);let m=p.height,x=0,b=s.reduce(((t,e)=>t+e.before.length+e.lines.length+e.after.length),0);if(b+=t.beforeBody.length+t.afterBody.length,d&&(m+=d*h.lineHeight+(d-1)*e.titleSpacing+e.titleMarginBottom),b){m+=g*(e.displayColors?Math.max(r,l.lineHeight):l.lineHeight)+(b-g)*l.lineHeight+(b-1)*e.bodySpacing}f&&(m+=e.footerMarginTop+f*c.lineHeight+(f-1)*e.footerSpacing);let _=0;const y=function(t){x=Math.max(x,i.measureText(t).width+_)};return i.save(),i.font=h.string,u(t.title,y),i.font=l.string,u(t.beforeBody.concat(t.afterBody),y),_=e.displayColors?a+2+e.boxPadding:0,u(s,(t=>{u(t.before,y),u(t.lines,y),u(t.after,y)})),_=0,i.font=c.string,u(t.footer,y),i.restore(),x+=p.width,{width:x,height:m}}function Aa(t,e,i,s){const{x:n,width:o}=i,{width:a,chartArea:{left:r,right:l}}=t;let h="center";return"center"===s?h=n<=(r+l)/2?"left":"right":n<=o/2?h="left":n>=a-o/2&&(h="right"),function(t,e,i,s){const{x:n,width:o}=s,a=i.caretSize+i.caretPadding;return"left"===t&&n+o+a>e.width||"right"===t&&n-o-a<0||void 0}(h,t,e,i)&&(h="center"),h}function Ta(t,e,i){const s=i.yAlign||e.yAlign||function(t,e){const{y:i,height:s}=e;return i<s/2?"top":i>t.height-s/2?"bottom":"center"}(t,i);return{xAlign:i.xAlign||e.xAlign||Aa(t,e,i,s),yAlign:s}}function La(t,e,i,s){const{caretSize:n,caretPadding:o,cornerRadius:a}=t,{xAlign:r,yAlign:l}=i,h=n+o,{topLeft:c,topRight:d,bottomLeft:u,bottomRight:f}=wi(a);let g=function(t,e){let{x:i,width:s}=t;return"right"===e?i-=s:"center"===e&&(i-=s/2),i}(e,r);const p=function(t,e,i){let{y:s,height:n}=t;return"top"===e?s+=i:s-="bottom"===e?n+i:n/2,s}(e,l,h);return"center"===l?"left"===r?g+=h:"right"===r&&(g-=h):"left"===r?g-=Math.max(c,u)+n:"right"===r&&(g+=Math.max(d,f)+n),{x:J(g,0,s.width-e.width),y:J(p,0,s.height-e.height)}}function Ea(t,e,i){const s=ki(i.padding);return"center"===e?t.x+t.width/2:"right"===e?t.x+t.width-s.right:t.x+s.left}function Ra(t){return Pa([],Da(t))}function Ia(t,e){const i=e&&e.dataset&&e.dataset.tooltip&&e.dataset.tooltip.callbacks;return i?t.override(i):t}const za={beforeTitle:e,title(t){if(t.length>0){const e=t[0],i=e.chart.data.labels,s=i?i.length:0;if(this&&this.options&&"dataset"===this.options.mode)return e.dataset.label||"";if(e.label)return e.label;if(s>0&&e.dataIndex<s)return i[e.dataIndex]}return""},afterTitle:e,beforeBody:e,beforeLabel:e,label(t){if(this&&this.options&&"dataset"===this.options.mode)return t.label+": "+t.formattedValue||t.formattedValue;let e=t.dataset.label||"";e&&(e+=": ");const i=t.formattedValue;return s(i)||(e+=i),e},labelColor(t){const e=t.chart.getDatasetMeta(t.datasetIndex).controller.getStyle(t.dataIndex);return{borderColor:e.borderColor,backgroundColor:e.backgroundColor,borderWidth:e.borderWidth,borderDash:e.borderDash,borderDashOffset:e.borderDashOffset,borderRadius:0}},labelTextColor(){return this.options.bodyColor},labelPointStyle(t){const e=t.chart.getDatasetMeta(t.datasetIndex).controller.getStyle(t.dataIndex);return{pointStyle:e.pointStyle,rotation:e.rotation}},afterLabel:e,afterBody:e,beforeFooter:e,footer:e,afterFooter:e};function Fa(t,e,i,s){const n=t[e].call(i,s);return void 0===n?za[e].call(i,s):n}class Va extends Hs{static positioners=Sa;constructor(t){super(),this.opacity=0,this._active=[],this._eventPosition=void 0,this._size=void 0,this._cachedAnimations=void 0,this._tooltipItems=[],this.$animations=void 0,this.$context=void 0,this.chart=t.chart,this.options=t.options,this.dataPoints=void 0,this.title=void 0,this.beforeBody=void 0,this.body=void 0,this.afterBody=void 0,this.footer=void 0,this.xAlign=void 0,this.yAlign=void 0,this.x=void 0,this.y=void 0,this.height=void 0,this.width=void 0,this.caretX=void 0,this.caretY=void 0,this.labelColors=void 0,this.labelPointStyles=void 0,this.labelTextColors=void 0}initialize(t){this.options=t,this._cachedAnimations=void 0,this.$context=void 0}_resolveAnimations(){const t=this._cachedAnimations;if(t)return t;const e=this.chart,i=this.options.setContext(this.getContext()),s=i.enabled&&e.options.animation&&i.animations,n=new Os(this.chart,s);return s._cacheable&&(this._cachedAnimations=Object.freeze(n)),n}getContext(){return this.$context||(this.$context=(t=this.chart.getContext(),e=this,i=this._tooltipItems,Ci(t,{tooltip:e,tooltipItems:i,type:"tooltip"})));var t,e,i}getTitle(t,e){const{callbacks:i}=e,s=Fa(i,"beforeTitle",this,t),n=Fa(i,"title",this,t),o=Fa(i,"afterTitle",this,t);let a=[];return a=Pa(a,Da(s)),a=Pa(a,Da(n)),a=Pa(a,Da(o)),a}getBeforeBody(t,e){return Ra(Fa(e.callbacks,"beforeBody",this,t))}getBody(t,e){const{callbacks:i}=e,s=[];return u(t,(t=>{const e={before:[],lines:[],after:[]},n=Ia(i,t);Pa(e.before,Da(Fa(n,"beforeLabel",this,t))),Pa(e.lines,Fa(n,"label",this,t)),Pa(e.after,Da(Fa(n,"afterLabel",this,t))),s.push(e)})),s}getAfterBody(t,e){return Ra(Fa(e.callbacks,"afterBody",this,t))}getFooter(t,e){const{callbacks:i}=e,s=Fa(i,"beforeFooter",this,t),n=Fa(i,"footer",this,t),o=Fa(i,"afterFooter",this,t);let a=[];return a=Pa(a,Da(s)),a=Pa(a,Da(n)),a=Pa(a,Da(o)),a}_createItems(t){const e=this._active,i=this.chart.data,s=[],n=[],o=[];let a,r,l=[];for(a=0,r=e.length;a<r;++a)l.push(Ca(this.chart,e[a]));return t.filter&&(l=l.filter(((e,s,n)=>t.filter(e,s,n,i)))),t.itemSort&&(l=l.sort(((e,s)=>t.itemSort(e,s,i)))),u(l,(e=>{const i=Ia(t.callbacks,e);s.push(Fa(i,"labelColor",this,e)),n.push(Fa(i,"labelPointStyle",this,e)),o.push(Fa(i,"labelTextColor",this,e))})),this.labelColors=s,this.labelPointStyles=n,this.labelTextColors=o,this.dataPoints=l,l}update(t,e){const i=this.options.setContext(this.getContext()),s=this._active;let n,o=[];if(s.length){const t=Sa[i.position].call(this,s,this._eventPosition);o=this._createItems(i),this.title=this.getTitle(o,i),this.beforeBody=this.getBeforeBody(o,i),this.body=this.getBody(o,i),this.afterBody=this.getAfterBody(o,i),this.footer=this.getFooter(o,i);const e=this._size=Oa(this,i),a=Object.assign({},t,e),r=Ta(this.chart,i,a),l=La(i,a,r,this.chart);this.xAlign=r.xAlign,this.yAlign=r.yAlign,n={opacity:1,x:l.x,y:l.y,width:e.width,height:e.height,caretX:t.x,caretY:t.y}}else 0!==this.opacity&&(n={opacity:0});this._tooltipItems=o,this.$context=void 0,n&&this._resolveAnimations().update(this,n),t&&i.external&&i.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,i,s){const n=this.getCaretPosition(t,i,s);e.lineTo(n.x1,n.y1),e.lineTo(n.x2,n.y2),e.lineTo(n.x3,n.y3)}getCaretPosition(t,e,i){const{xAlign:s,yAlign:n}=this,{caretSize:o,cornerRadius:a}=i,{topLeft:r,topRight:l,bottomLeft:h,bottomRight:c}=wi(a),{x:d,y:u}=t,{width:f,height:g}=e;let p,m,x,b,_,y;return"center"===n?(_=u+g/2,"left"===s?(p=d,m=p-o,b=_+o,y=_-o):(p=d+f,m=p+o,b=_-o,y=_+o),x=p):(m="left"===s?d+Math.max(r,h)+o:"right"===s?d+f-Math.max(l,c)-o:this.caretX,"top"===n?(b=u,_=b-o,p=m-o,x=m+o):(b=u+g,_=b+o,p=m+o,x=m-o),y=b),{x1:p,x2:m,x3:x,y1:b,y2:_,y3:y}}drawTitle(t,e,i){const s=this.title,n=s.length;let o,a,r;if(n){const l=Oi(i.rtl,this.x,this.width);for(t.x=Ea(this,i.titleAlign,i),e.textAlign=l.textAlign(i.titleAlign),e.textBaseline="middle",o=Si(i.titleFont),a=i.titleSpacing,e.fillStyle=i.titleColor,e.font=o.string,r=0;r<n;++r)e.fillText(s[r],l.x(t.x),t.y+o.lineHeight/2),t.y+=o.lineHeight+a,r+1===n&&(t.y+=i.titleMarginBottom-a)}}_drawColorBox(t,e,i,s,n){const a=this.labelColors[i],r=this.labelPointStyles[i],{boxHeight:l,boxWidth:h}=n,c=Si(n.bodyFont),d=Ea(this,"left",n),u=s.x(d),f=l<c.lineHeight?(c.lineHeight-l)/2:0,g=e.y+f;if(n.usePointStyle){const e={radius:Math.min(h,l)/2,pointStyle:r.pointStyle,rotation:r.rotation,borderWidth:1},i=s.leftForLtr(u,h)+h/2,o=g+l/2;t.strokeStyle=n.multiKeyBackground,t.fillStyle=n.multiKeyBackground,Le(t,e,i,o),t.strokeStyle=a.borderColor,t.fillStyle=a.backgroundColor,Le(t,e,i,o)}else{t.lineWidth=o(a.borderWidth)?Math.max(...Object.values(a.borderWidth)):a.borderWidth||1,t.strokeStyle=a.borderColor,t.setLineDash(a.borderDash||[]),t.lineDashOffset=a.borderDashOffset||0;const e=s.leftForLtr(u,h),i=s.leftForLtr(s.xPlus(u,1),h-2),r=wi(a.borderRadius);Object.values(r).some((t=>0!==t))?(t.beginPath(),t.fillStyle=n.multiKeyBackground,He(t,{x:e,y:g,w:h,h:l,radius:r}),t.fill(),t.stroke(),t.fillStyle=a.backgroundColor,t.beginPath(),He(t,{x:i,y:g+1,w:h-2,h:l-2,radius:r}),t.fill()):(t.fillStyle=n.multiKeyBackground,t.fillRect(e,g,h,l),t.strokeRect(e,g,h,l),t.fillStyle=a.backgroundColor,t.fillRect(i,g+1,h-2,l-2))}t.fillStyle=this.labelTextColors[i]}drawBody(t,e,i){const{body:s}=this,{bodySpacing:n,bodyAlign:o,displayColors:a,boxHeight:r,boxWidth:l,boxPadding:h}=i,c=Si(i.bodyFont);let d=c.lineHeight,f=0;const g=Oi(i.rtl,this.x,this.width),p=function(i){e.fillText(i,g.x(t.x+f),t.y+d/2),t.y+=d+n},m=g.textAlign(o);let x,b,_,y,v,M,w;for(e.textAlign=o,e.textBaseline="middle",e.font=c.string,t.x=Ea(this,m,i),e.fillStyle=i.bodyColor,u(this.beforeBody,p),f=a&&"right"!==m?"center"===o?l/2+h:l+2+h:0,y=0,M=s.length;y<M;++y){for(x=s[y],b=this.labelTextColors[y],e.fillStyle=b,u(x.before,p),_=x.lines,a&&_.length&&(this._drawColorBox(e,t,y,g,i),d=Math.max(c.lineHeight,r)),v=0,w=_.length;v<w;++v)p(_[v]),d=c.lineHeight;u(x.after,p)}f=0,d=c.lineHeight,u(this.afterBody,p),t.y-=n}drawFooter(t,e,i){const s=this.footer,n=s.length;let o,a;if(n){const r=Oi(i.rtl,this.x,this.width);for(t.x=Ea(this,i.footerAlign,i),t.y+=i.footerMarginTop,e.textAlign=r.textAlign(i.footerAlign),e.textBaseline="middle",o=Si(i.footerFont),e.fillStyle=i.footerColor,e.font=o.string,a=0;a<n;++a)e.fillText(s[a],r.x(t.x),t.y+o.lineHeight/2),t.y+=o.lineHeight+i.footerSpacing}}drawBackground(t,e,i,s){const{xAlign:n,yAlign:o}=this,{x:a,y:r}=t,{width:l,height:h}=i,{topLeft:c,topRight:d,bottomLeft:u,bottomRight:f}=wi(s.cornerRadius);e.fillStyle=s.backgroundColor,e.strokeStyle=s.borderColor,e.lineWidth=s.borderWidth,e.beginPath(),e.moveTo(a+c,r),"top"===o&&this.drawCaret(t,e,i,s),e.lineTo(a+l-d,r),e.quadraticCurveTo(a+l,r,a+l,r+d),"center"===o&&"right"===n&&this.drawCaret(t,e,i,s),e.lineTo(a+l,r+h-f),e.quadraticCurveTo(a+l,r+h,a+l-f,r+h),"bottom"===o&&this.drawCaret(t,e,i,s),e.lineTo(a+u,r+h),e.quadraticCurveTo(a,r+h,a,r+h-u),"center"===o&&"left"===n&&this.drawCaret(t,e,i,s),e.lineTo(a,r+c),e.quadraticCurveTo(a,r,a+c,r),e.closePath(),e.fill(),s.borderWidth>0&&e.stroke()}_updateAnimationTarget(t){const e=this.chart,i=this.$animations,s=i&&i.x,n=i&&i.y;if(s||n){const i=Sa[t.position].call(this,this._active,this._eventPosition);if(!i)return;const o=this._size=Oa(this,t),a=Object.assign({},i,this._size),r=Ta(e,t,a),l=La(t,a,r,e);s._to===l.x&&n._to===l.y||(this.xAlign=r.xAlign,this.yAlign=r.yAlign,this.width=o.width,this.height=o.height,this.caretX=i.x,this.caretY=i.y,this._resolveAnimations().update(this,l))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let i=this.opacity;if(!i)return;this._updateAnimationTarget(e);const s={width:this.width,height:this.height},n={x:this.x,y:this.y};i=Math.abs(i)<.001?0:i;const o=ki(e.padding),a=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&a&&(t.save(),t.globalAlpha=i,this.drawBackground(n,t,s,e),Ai(t,e.textDirection),n.y+=o.top,this.drawTitle(n,t,e),this.drawBody(n,t,e),this.drawFooter(n,t,e),Ti(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const i=this._active,s=t.map((({datasetIndex:t,index:e})=>{const i=this.chart.getDatasetMeta(t);if(!i)throw new Error("Cannot find a dataset at index "+t);return{datasetIndex:t,element:i.data[e],index:e}})),n=!f(i,s),o=this._positionChanged(s,e);(n||o)&&(this._active=s,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,i=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const s=this.options,n=this._active||[],o=this._getActiveElements(t,n,e,i),a=this._positionChanged(o,t),r=e||!f(o,n)||a;return r&&(this._active=o,(s.enabled||s.external)&&(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),r}_getActiveElements(t,e,i,s){const n=this.options;if("mouseout"===t.type)return[];if(!s)return e.filter((t=>this.chart.data.datasets[t.datasetIndex]&&void 0!==this.chart.getDatasetMeta(t.datasetIndex).controller.getParsed(t.index)));const o=this.chart.getElementsAtEventForMode(t,n.mode,n,i);return n.reverse&&o.reverse(),o}_positionChanged(t,e){const{caretX:i,caretY:s,options:n}=this,o=Sa[n.position].call(this,t,e);return!1!==o&&(i!==o.x||s!==o.y)}}var Ba={id:"tooltip",_element:Va,positioners:Sa,afterInit(t,e,i){i&&(t.tooltip=new Va({chart:t,options:i}))},beforeUpdate(t,e,i){t.tooltip&&t.tooltip.initialize(i)},reset(t,e,i){t.tooltip&&t.tooltip.initialize(i)},afterDraw(t){const e=t.tooltip;if(e&&e._willRender()){const i={tooltip:e};if(!1===t.notifyPlugins("beforeTooltipDraw",{...i,cancelable:!0}))return;e.draw(t.ctx),t.notifyPlugins("afterTooltipDraw",i)}},afterEvent(t,e){if(t.tooltip){const i=e.replay;t.tooltip.handleEvent(e.event,i,e.inChartArea)&&(e.changed=!0)}},defaults:{enabled:!0,external:null,position:"average",backgroundColor:"rgba(0,0,0,0.8)",titleColor:"#fff",titleFont:{weight:"bold"},titleSpacing:2,titleMarginBottom:6,titleAlign:"left",bodyColor:"#fff",bodySpacing:2,bodyFont:{},bodyAlign:"left",footerColor:"#fff",footerSpacing:2,footerMarginTop:6,footerFont:{weight:"bold"},footerAlign:"left",padding:6,caretPadding:2,caretSize:5,cornerRadius:6,boxHeight:(t,e)=>e.bodyFont.size,boxWidth:(t,e)=>e.bodyFont.size,multiKeyBackground:"#fff",displayColors:!0,boxPadding:0,borderColor:"rgba(0,0,0,0)",borderWidth:0,animation:{duration:400,easing:"easeOutQuart"},animations:{numbers:{type:"number",properties:["x","y","width","height","caretX","caretY"]},opacity:{easing:"linear",duration:200}},callbacks:za},defaultRoutes:{bodyFont:"font",footerFont:"font",titleFont:"font"},descriptors:{_scriptable:t=>"filter"!==t&&"itemSort"!==t&&"external"!==t,_indexable:!1,callbacks:{_scriptable:!1,_indexable:!1},animation:{_fallback:!1},animations:{_fallback:"animation"}},additionalOptionScopes:["interaction"]};return An.register(Yn,jo,fo,t),An.helpers={...Wi},An._adapters=Rn,An.Animation=Cs,An.Animations=Os,An.animator=bt,An.controllers=en.controllers.items,An.DatasetController=Ns,An.Element=Hs,An.elements=fo,An.Interaction=Xi,An.layouts=as,An.platforms=Ss,An.Scale=Js,An.Ticks=ae,Object.assign(An,Yn,jo,fo,t,Ss),An.Chart=An,"undefined"!=typeof window&&(window.Chart=An),An}));
-//# sourceMappingURL=chart.umd.js.map
diff --git a/src/imports/code-input.css b/src/imports/code-input.css
deleted file mode 100644 (file)
index 89df115..0000000
+++ /dev/null
@@ -1,185 +0,0 @@
-/* Code-Input Compatibility */
-/* By WebCoder49 */
-/* First Published on CSS-Tricks.com */
-
-
-code-input {
-  /* Allow other elements to be inside */
-  display: block;
-  overflow-y: auto;
-  overflow-x: auto;
-  position: relative;
-  top: 0;
-  left: 0;
-
-  /* Normal inline styles */
-  margin: 8px;
-  --padding: 16px;
-  height: 250px;
-  font-size: inherit;
-  font-family: monospace;
-  line-height: 1.5; /* Inherited to child elements */
-  tab-size: 2;
-  caret-color: darkgrey;
-  white-space: pre;
-  padding: 0!important; /* Use --padding to set the code-input element's padding */
-  display: grid;
-  grid-template-columns: 100%;
-  grid-template-rows: 100%;
-}
-
-
-code-input:not(.code-input_loaded) {
-  padding: var(--padding, 16px)!important;
-}
-
-code-input textarea, code-input:not(.code-input_pre-element-styled) pre code, code-input.code-input_pre-element-styled pre {
-  /* Both elements need the same text and space styling so they are directly on top of each other */
-  margin: 0px!important;
-  padding: var(--padding, 16px)!important;
-  border: 0;
-  min-width: calc(100% - var(--padding) * 2);
-  min-height: calc(100% - var(--padding) * 2);
-  overflow: hidden;
-  resize: none;
-  grid-row: 1;
-  grid-column: 1;
-  display: block;
-}
-
-code-input:not(.code-input_pre-element-styled) pre code, code-input.code-input_pre-element-styled pre {
-  height: max-content;
-  width: max-content;
-}
-
-code-input:not(.code-input_pre-element-styled) pre, code-input.code-input_pre-element-styled pre code {
-  /* Remove all margin and padding from others */
-  margin: 0px!important;
-  padding: 0px!important;
-  width: 100%;
-  height: 100%;
-}
-
-code-input textarea, code-input pre, code-input pre * {
-  /* Also add text styles to highlighing tokens */
-  font-size: inherit!important;
-  font-family: inherit!important;
-  line-height: inherit!important;
-  tab-size: inherit!important;
-}
-
-code-input textarea, code-input pre {
-  /* In the same place */
-  grid-column: 1;
-  grid-row: 1;
-}
-
-/* Move the textarea in front of the result */
-
-code-input textarea {
-  z-index: 1;
-}
-code-input pre {
-  z-index: 0;
-}
-
-/* Make textarea almost completely transparent, except for caret and placeholder */
-
-code-input textarea {
-  color: transparent;
-  background: transparent;
-  caret-color: inherit!important; /* Or choose your favourite color */
-}
-code-input textarea::placeholder {
-  color: lightgrey;
-}
-
-/* Can be scrolled */
-code-input textarea, code-input pre {
-  white-space: inherit;
-  word-spacing: normal;
-  word-break: normal;
-  word-wrap: normal;
-}
-
-/* No resize on textarea; transfer outline on focus to code-input element */
-code-input textarea {
-  resize: none;
-  outline: none!important;
-}
-code-input:has(textarea:focus):not(.code-input_mouse-focused) {
-  outline: 2px solid black;
-}
-
-/* Before registering give a hint about how to register. */
-code-input:not(.code-input_registered) {
-  overflow: hidden;
-  display: block;
-  box-sizing: border-box; /* Include padding in width/height */
-}
-
-code-input:not(.code-input_registered)::after {
-  /* Display message to register */
-  content: "Use codeInput.registerTemplate to set up.";
-  display: block;
-  position: absolute;
-  bottom: var(--padding);
-  left: var(--padding);
-  width: calc(100% - 2 * var(--padding));
-
-  border-top: 1px solid grey;
-  outline: var(--padding) solid white;
-  background-color: white;
-}
-
-code-input:not(.code-input_loaded) pre, code-input:not(.code-input_loaded) textarea {
-  opacity: 0;
-}
-
-/* Contains dialog boxes that might appear as the result of a plugin.
-Sticks to the top of the code-input element */
-code-input .code-input_dialog-container {
-  z-index: 2;
-  
-  position: sticky;
-  grid-row: 1;
-  grid-column: 1;
-  
-  top: 0px;
-  left: 0;
-  width: 100%;
-  height: 0;
-
-  /* Dialog boxes' text is left-aligned */
-  text-align: left;
-}
-/* Instructions specific to keyboard navigation set by plugins that override Tab functionality. */
-code-input .code-input_dialog-container .code-input_keyboard-navigation-instructions {
-  top: 0;
-  right: 0;
-  display: block;
-  position: absolute;
-  background-color: black;
-  color: white;
-  padding: 2px;
-  padding-left: 10px;
-  text-wrap: pretty;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  width: calc(100% - 12px);
-  max-height: 3em;
-}
-
-code-input:not(:has(textarea:focus)) .code-input_dialog-container .code-input_keyboard-navigation-instructions,
-code-input.code-input_mouse-focused .code-input_dialog-container .code-input_keyboard-navigation-instructions,
-code-input .code-input_dialog-container .code-input_keyboard-navigation-instructions:empty {
-  /* When not keyboard-focused / no instructions don't show instructions */
-  display: none;
-}
-
-/* Things with padding when instructions are present */
-code-input:not(:has(.code-input_keyboard-navigation-instructions:empty)):has(textarea:focus):not(.code-input_mouse-focused) textarea,
-code-input:not(:has(.code-input_keyboard-navigation-instructions:empty)):has(textarea:focus):not(.code-input_mouse-focused):not(.code-input_pre-element-styled) pre code,
-code-input:not(:has(.code-input_keyboard-navigation-instructions:empty)):has(textarea:focus):not(.code-input_mouse-focused).code-input_pre-element-styled pre {
-  padding-top: calc(var(--padding) + 3em)!important;
-}
\ No newline at end of file
diff --git a/src/imports/code-input.js b/src/imports/code-input.js
deleted file mode 100644 (file)
index b0458bc..0000000
+++ /dev/null
@@ -1,1050 +0,0 @@
-/**
- * **code-input** is a library which lets you create custom HTML `<code-input>`
- * elements that act like `<textarea>` elements but support syntax-highlighted
- * code, implemented using any typical syntax highlighting library. [MIT-Licensed]
- * 
- * **<https://github.com/WebCoder49/code-input>**
- */
-
-
-var codeInput = {
-    /**
-     * A list of attributes that will trigger the 
-     * `codeInput.CodeInput.attributeChangedCallback` 
-     * when modified in a code-input element. This
-     * does not include events, which are handled in
-     * `codeInput.CodeInput.addEventListener` and
-     * `codeInput.CodeInput.removeEventListener`.
-     */
-    observedAttributes: [
-        "value",
-        "placeholder",
-        "language",
-        "lang",
-        "template"
-    ],
-
-    /**
-     * A list of attributes that will be moved to 
-     * the textarea after they are applied on the 
-     * code-input element.
-     */
-    textareaSyncAttributes: [
-        "value",
-        // Form validation - https://developer.mozilla.org/en-US/docs/Learn/Forms/Form_validation#using_built-in_form_validation
-        "min", "max",
-        "type",
-        "pattern",
-
-        // Source: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea
-        "autocomplete", 
-        "autocorrect", 
-        "autofocus",
-        "cols",
-        "dirname",
-        "disabled",
-        "form",
-        "maxlength",
-        "minlength",
-        "name",
-        "placeholder",
-        "readonly",
-        "required",
-        "rows",
-        "spellcheck",
-        "wrap"
-    ],
-
-    /**
-     * A list of events whose listeners will be moved to 
-     * the textarea after they are added to the 
-     * code-input element.
-     */
-    textareaSyncEvents: [
-        "change",
-        "selectionchange",
-        "invalid",
-        "input"
-    ],
-
-    /* ------------------------------------
-    *  ------------Templates---------------
-    *  ------------------------------------ */
-
-    /**
-     * The templates currently available for any code-input elements
-     * to use. Registered using `codeInput.registerTemplate`.
-     * Key - Template Name
-     * Value - A Template Object
-     * @type {Object}
-     */
-    usedTemplates: {
-    },
-    /**
-     * The name of the default template that a code-input element that
-     * does not specify the template attribute uses. 
-     * @type {string}
-     */
-    defaultTemplate: undefined,
-    /**
-     * A queue of elements waiting for a template to be registered,
-     * allowing elements to be created in HTML with a template before
-     * the template is registered in JS, for ease of use.
-     * Key - Template Name
-     * Value - An array of code-input elements
-     * @type {Object}
-     */
-    templateNotYetRegisteredQueue: {},
-
-    /**
-     * Register a template so code-input elements with a template attribute that equals the templateName will use the template.
-     * See `codeInput.templates` for constructors to create templates.
-     * @param {string} templateName - the name to register the template under
-     * @param {Object} template - a Template object instance - see `codeInput.templates`  
-     */
-    registerTemplate: function (templateName, template) {
-        if(!(typeof templateName == "string" || templateName instanceof String)) throw TypeError(`code-input: Name of template "${templateName}" must be a string.`);
-        if(!(typeof template.highlight == "function" || template.highlight instanceof Function)) throw TypeError(`code-input: Template for "${templateName}" invalid, because the highlight function provided is not a function; it is "${template.highlight}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-        if(!(typeof template.includeCodeInputInHighlightFunc == "boolean" || template.includeCodeInputInHighlightFunc instanceof Boolean)) throw TypeError(`code-input: Template for "${templateName}" invalid, because the includeCodeInputInHighlightFunc value provided is not a true or false; it is "${template.includeCodeInputInHighlightFunc}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-        if(!(typeof template.preElementStyled == "boolean" || template.preElementStyled instanceof Boolean)) throw TypeError(`code-input: Template for "${templateName}" invalid, because the preElementStyled value provided is not a true or false; it is "${template.preElementStyled}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-        if(!(typeof template.isCode == "boolean" || template.isCode instanceof Boolean)) throw TypeError(`code-input: Template for "${templateName}" invalid, because the isCode value provided is not a true or false; it is "${template.isCode}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-        if(!Array.isArray(template.plugins)) throw TypeError(`code-input: Template for "${templateName}" invalid, because the plugin array provided is not an array; it is "${template.plugins}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-        
-        template.plugins.forEach((plugin, i) => {
-            if(!(plugin instanceof codeInput.Plugin)) {
-                throw TypeError(`code-input: Template for "${templateName}" invalid, because the plugin provided at index ${i} is not valid; it is "${template.plugins[i]}". Please make sure you use one of the constructors in codeInput.templates, and that you provide the correct arguments.`);
-            }
-        });
-
-        
-        codeInput.usedTemplates[templateName] = template;
-        // Add waiting code-input elements wanting this template from queue
-        if (templateName in codeInput.templateNotYetRegisteredQueue) {
-            for (let i in codeInput.templateNotYetRegisteredQueue[templateName]) {
-                elem = codeInput.templateNotYetRegisteredQueue[templateName][i];
-                elem.template = template;
-                codeInput.runOnceWindowLoaded((function(elem) { elem.connectedCallback(); }).bind(null, elem), elem);
-                // Bind sets elem as first parameter of function 
-                // So innerHTML can be read
-            }
-            console.log(`code-input: template: Added existing elements with template ${templateName}`);
-        }
-
-        if (codeInput.defaultTemplate == undefined) {
-            codeInput.defaultTemplate = templateName;
-            // Add elements with default template from queue
-            if (undefined in codeInput.templateNotYetRegisteredQueue) {
-                for (let i in codeInput.templateNotYetRegisteredQueue[undefined]) {
-                    elem = codeInput.templateNotYetRegisteredQueue[undefined][i];
-                    elem.template = template;
-                    codeInput.runOnceWindowLoaded((function(elem) { elem.connectedCallback(); }).bind(null, elem), elem);
-                    // Bind sets elem as first parameter of function
-                    // So innerHTML can be read
-                }
-            }
-            console.log(`code-input: template: Set template ${templateName} as default`);
-        }
-        console.log(`code-input: template: Created template ${templateName}`);
-    },
-
-    /**
-     * Please see `codeInput.templates.prism` or `codeInput.templates.hljs`.
-     * Templates are used in `<code-input>` elements and once registered with
-     * `codeInput.registerTemplate` will be in charge of the highlighting
-     * algorithm and settings for all code-inputs with a `template` attribute
-     * matching the registered name.
-     */
-    Template: class {
-        /**
-         * Constructor to create a custom template instance. Pass this into `codeInput.registerTemplate` to use it.
-         * I would strongly recommend using the built-in simpler template `codeInput.templates.prism` or `codeInput.templates.hljs`.
-         * @param {Function} highlight - a callback to highlight the code, that takes an HTML `<code>` element inside a `<pre>` element as a parameter
-         * @param {boolean} preElementStyled - is the `<pre>` element CSS-styled as well as the `<code>` element? If true, `<pre>` element's scrolling is synchronised; if false, `<code>` element's scrolling is synchronised.
-         * @param {boolean} isCode - is this for writing code? If true, the code-input's lang HTML attribute can be used, and the `<code>` element will be given the class name 'language-[lang attribute's value]'.
-         * @param {boolean} includeCodeInputInHighlightFunc - Setting this to true passes the `<code-input>` element as a second argument to the highlight function.
-         * @param {codeInput.Plugin[]} plugins - An array of plugin objects to add extra features - see `codeInput.Plugin`
-         * @returns {codeInput.Template} template object
-         */
-        constructor(highlight = function () { }, preElementStyled = true, isCode = true, includeCodeInputInHighlightFunc = false, plugins = []) {
-            this.highlight = highlight;
-            this.preElementStyled = preElementStyled;
-            this.isCode = isCode;
-            this.includeCodeInputInHighlightFunc = includeCodeInputInHighlightFunc;
-            this.plugins = plugins;
-        }
-
-        /**
-         * A callback to highlight the code, that takes an HTML `<code>` element 
-         * inside a `<pre>` element as a parameter, and an optional second
-         * `<code-input>` element parameter if `this.includeCodeInputInHighlightFunc` is
-         * `true`.
-         */
-        highlight = function(codeElement) {};
-
-        /**
-         * Is the <pre> element CSS-styled as well as the `<code>` element? 
-         * If `true`, `<pre>` element's scrolling is synchronised; if false, 
-         * <code> element's scrolling is synchronised.
-         */
-        preElementStyled = true;
-
-        /**
-         * Is this for writing code? 
-         * If true, the code-input's lang HTML attribute can be used, 
-         * and the `<code>` element will be given the class name 
-         * 'language-[lang attribute's value]'.
-         */
-        isCode = true;
-
-        /**
-         * Setting this to true passes the `<code-input>` element as a 
-         * second argument to the highlight function.
-         */
-        includeCodeInputInHighlightFunc = false;
-
-        /**
-         * An array of plugin objects to add extra features - 
-         * see `codeInput.Plugin`.
-         */
-        plugins = [];
-    },
-
-    /**
-     * For creating a custom template from scratch, please 
-     * use `new codeInput.Template(...)`
-     * 
-     * Shortcut functions for creating templates.
-     * Each code-input element has a template attribute that 
-     * tells it which template to use.
-     * Each template contains functions and preferences that 
-     * run the syntax-highlighting and let code-input control 
-     * the highlighting.
-     * For adding small pieces of functionality, please see `codeInput.plugins`.
-     */
-    templates: {
-        /**
-         * Constructor to create a template that uses Prism.js syntax highlighting (https://prismjs.com/)
-         * @param {Object} prism Import Prism.js, then after that import pass the `Prism` object as this parameter.
-         * @param {codeInput.Plugin[]} plugins - An array of plugin objects to add extra features - see `codeInput.plugins`
-         * @returns {codeInput.Template} template object
-         */
-        prism(prism, plugins = []) { // Dependency: Prism.js (https://prismjs.com/)
-            return new codeInput.Template(
-                prism.highlightElement, // highlight
-                true, // preElementStyled
-                true, // isCode
-                false, // includeCodeInputInHighlightFunc
-                plugins
-            );
-        },
-        /**
-         * Constructor to create a template that uses highlight.js syntax highlighting (https://highlightjs.org/)
-         * @param {Object} hljs Import highlight.js, then after that import pass the `hljs` object as this parameter.
-         * @param {codeInput.Plugin[]} plugins - An array of plugin objects to add extra features - see `codeInput.plugins`
-         * @returns {codeInput.Template} template object
-         */
-        hljs(hljs, plugins = []) { // Dependency: Highlight.js (https://highlightjs.org/)
-            return new codeInput.Template(
-                function(codeElement) {
-                    codeElement.removeAttribute("data-highlighted");
-                    hljs.highlightElement(codeElement);
-                }, // highlight
-                false, // preElementStyled
-                true, // isCode
-                false, // includeCodeInputInHighlightFunc
-                plugins
-            );
-        },
-
-        /**
-         * @deprecated Make your own version of this template if you need it - we think it isn't widely used so will remove it from the next version of code-input.
-         */
-        characterLimit(plugins) {
-            return {
-                highlight: function (resultElement, codeInput, plugins = []) {
-
-                    let characterLimit = Number(codeInput.getAttribute("data-character-limit"));
-
-                    let normalCharacters = codeInput.escapeHtml(codeInput.value.slice(0, characterLimit));
-                    let overflowCharacters = codeInput.escapeHtml(codeInput.value.slice(characterLimit));
-
-                    resultElement.innerHTML = `${normalCharacters}<mark class="overflow">${overflowCharacters}</mark>`;
-                    if (overflowCharacters.length > 0) {
-                        resultElement.innerHTML += ` <mark class="overflow-msg">${codeInput.getAttribute("data-overflow-msg") || "(Character limit reached)"}</mark>`;
-                    }
-                },
-                includeCodeInputInHighlightFunc: true,
-                preElementStyled: true,
-                isCode: false,
-                plugins: plugins,
-            }
-        },
-
-        /**
-         * @deprecated Make your own version of this template if you need it - we think it isn't widely used so will remove it from the next version of code-input.
-         */
-        rainbowText(rainbowColors = ["red", "orangered", "orange", "goldenrod", "gold", "green", "darkgreen", "navy", "blue", "magenta"], delimiter = "", plugins = []) {
-            return {
-                highlight: function (resultElement, codeInput) {
-                    let htmlResult = [];
-                    let sections = codeInput.value.split(codeInput.template.delimiter);
-                    for (let i = 0; i < sections.length; i++) {
-                        htmlResult.push(`<span style="color: ${codeInput.template.rainbowColors[i % codeInput.template.rainbowColors.length]}">${codeInput.escapeHtml(sections[i])}</span>`);
-                    }
-                    resultElement.innerHTML = htmlResult.join(codeInput.template.delimiter);
-                },
-                includeCodeInputInHighlightFunc: true,
-                preElementStyled: true,
-                isCode: false,
-
-                rainbowColors: rainbowColors,
-                delimiter: delimiter,
-
-                plugins: plugins,
-            }
-        },
-
-        /**
-         * @deprecated Make your own version of this template if you need it - we think it isn't widely used so will remove it from the next version of code-input.
-         */
-        character_limit() {
-            return this.characterLimit([]);
-        },
-        /**
-         * @deprecated Make your own version of this template if you need it - we think it isn't widely used so will remove it from the next version of code-input.
-         */
-        rainbow_text(rainbowColors = ["red", "orangered", "orange", "goldenrod", "gold", "green", "darkgreen", "navy", "blue", "magenta"], delimiter = "", plugins = []) {
-            return this.rainbowText(rainbowColors, delimiter, plugins);
-        },
-        
-        /**
-         * @deprecated Please use `new codeInput.Template()`
-         */
-        custom(highlight = function () { }, preElementStyled = true, isCode = true, includeCodeInputInHighlightFunc = false, plugins = []) {
-            return {
-                highlight: highlight,
-                includeCodeInputInHighlightFunc: includeCodeInputInHighlightFunc,
-                preElementStyled: preElementStyled,
-                isCode: isCode,
-                plugins: plugins,
-            };
-        },
-    },
-
-    /* ------------------------------------
-    *  ------------Plugins-----------------
-    *  ------------------------------------ */
-
-    /**
-     * Before using any plugin in this namespace, please ensure you import its JavaScript
-     * files (in the plugins folder), or continue to get a more detailed error in the developer
-     * console.
-     * 
-     * Where plugins are stored, after they are imported. The plugin
-     * file assigns them a space in this object.
-     * For adding completely new syntax-highlighting algorithms, please see `codeInput.templates`.
-     * 
-     * Key - plugin name
-     * 
-     * Value - plugin object
-     * @type {Object}
-     */
-    plugins: new Proxy({}, {
-        get(plugins, name) {
-            if(plugins[name] == undefined) {
-                throw ReferenceError(`code-input: Plugin '${name}' is not defined. Please ensure you import the necessary files from the plugins folder in the WebCoder49/code-input repository, in the <head> of your HTML, before the plugin is instatiated.`);
-            }
-            return plugins[name];
-        }
-    }),
-
-    /**
-     * Plugins are imported from the plugins folder. They will then
-     * provide custom extra functionality to code-input elements.
-     */
-    Plugin: class {
-        /**
-         * Create a Plugin
-         * 
-         * @param {Array<string>} observedAttributes - The HTML attributes to watch for this plugin, and report any 
-         * modifications to the `codeInput.Plugin.attributeChanged` method.
-         */
-        constructor(observedAttributes) {
-            console.log("code-input: plugin: Created plugin");
-
-            observedAttributes.forEach((attribute) => {
-                codeInput.observedAttributes.push(attribute);
-            });
-        }
-
-        /**
-         * Runs before code is highlighted.
-         * @param {codeInput.CodeInput} codeInput - The codeInput element
-         */
-        beforeHighlight(codeInput) { }
-        /**
-         * Runs after code is highlighted.
-         * @param {codeInput.CodeInput} codeInput - The codeInput element
-         */
-        afterHighlight(codeInput) { }
-        /**
-         * Runs before elements are added into a code-input element.
-         * @param {codeInput.CodeInput} codeInput - The codeInput element
-         */
-        beforeElementsAdded(codeInput) { }
-        /**
-         * Runs after elements are added into a code-input element (useful for adding events to the textarea).
-         * @param {codeInput.CodeInput} codeInput - The codeInput element
-         */
-        afterElementsAdded(codeInput) { }
-        /**
-         * Runs when an attribute of a code-input element is changed (you must add the attribute name to `codeInput.Plugin.observedAttributes` first).
-         * @param {codeInput.CodeInput} codeInput - The codeInput element
-         * @param {string} name - The name of the attribute
-         * @param {string} oldValue - The value of the attribute before it was changed
-         * @param {string} newValue - The value of the attribute after it is changed
-         */
-        attributeChanged(codeInput, name, oldValue, newValue) { }
-    },
-
-    /* ------------------------------------
-    *  -------------Main-------------------
-    *  ------------------------------------ */
-
-    /**
-     * A code-input element.
-     */
-    CodeInput: class extends HTMLElement {
-        constructor() {
-            super(); // Element
-        }
-
-        /**
-        * Exposed child textarea element for user to input code in
-        */
-        textareaElement = null;
-        /**
-        * Exposed child pre element where syntax-highlighted code is outputted.
-        * Contains this.codeElement as its only child.
-        */
-        preElement = null
-        /**
-        * Exposed child pre element's child code element where syntax-highlighted code is outputted.
-        * Has this.preElement as its parent.
-        */
-        codeElement = null;
-
-        /** 
-         * Exposed non-scrolling element designed to contain dialog boxes etc. that shouldn't scroll
-         * with the code-input element.
-         */
-        dialogContainerElement = null;
-
-        /**
-        * Form-Associated Custom Element Callbacks
-        * https://html.spec.whatwg.org/multipage/custom-elements.html#custom-elements-face-example
-        */
-        static formAssociated = true;
-
-        /**
-         * When events are transferred to the textarea element, callbacks
-         * are bound to set the this variable to the code-input element
-         * rather than the textarea. This allows the callback to be converted
-         * to a bound one:
-         * Key - Callback not bound
-         * Value - Callback that is bound, with this equalling the code-input element in the callback 
-         */
-        boundEventCallbacks = {};
-
-        /** Trigger this event in all plugins with a optional list of arguments 
-         * @param {string} eventName - the name of the event to trigger
-         * @param {Array} args - the arguments to pass into the event callback in the template after the code-input element. Normally left empty
-        */
-        pluginEvt(eventName, args) {
-            for (let i in this.template.plugins) {
-                let plugin = this.template.plugins[i];
-                if (eventName in plugin) {
-                    if (args === undefined) {
-                        plugin[eventName](this);
-                    } else {
-                        plugin[eventName](this, ...args);
-                    }
-                }
-            }
-        }
-
-        /* ------------------------------------
-        *  ----------Main Functionality--------
-        *  ------------------------------------ 
-        * The main function of a code-input element is to take 
-        * code written in its textarea element, copy this code into
-        * the result (pre code) element, then use the template object
-        * to syntax-highlight it. */
-
-        needsHighlight = false; // Just inputted
-        handleEventsFromTextarea = true; // Turn to false when unusual internal events are called on the textarea
-        originalAriaDescription;
-
-        /**
-         * Highlight the code as soon as possible
-         */
-        scheduleHighlight() {
-            this.needsHighlight = true;
-        }
-
-        /**
-         * Call an animation frame
-         */
-        animateFrame() {
-            // Synchronise the contents of the pre/code and textarea elements
-            if(this.needsHighlight) {
-                this.update();
-                this.needsHighlight = false;
-            }
-
-            window.requestAnimationFrame(this.animateFrame.bind(this));
-        }
-
-        /**
-         * Update the text value to the result element, after the textarea contents have changed.
-         */
-        update() {
-            let resultElement = this.codeElement;
-            let value = this.value;
-            value += "\n"; // Placeholder for next line
-
-            // Update code
-            resultElement.innerHTML = this.escapeHtml(value);
-            this.pluginEvt("beforeHighlight");
-
-            // Syntax Highlight
-            if (this.template.includeCodeInputInHighlightFunc) this.template.highlight(resultElement, this);
-            else this.template.highlight(resultElement);
-
-            this.syncSize();
-
-            // If editing here, scroll to the caret by focusing, though this shouldn't count as a focus event
-            if(this.textareaElement === document.activeElement) {
-                this.handleEventsFromTextarea = false;
-                this.textareaElement.blur();
-                this.textareaElement.focus();
-                this.handleEventsFromTextarea = true;
-            }
-
-            this.pluginEvt("afterHighlight");
-        }
-
-        /**
-         * Set the size of the textarea element to the size of the pre/code element.
-         */
-        syncSize() {
-            // Synchronise the size of the pre/code and textarea elements
-            if(this.template.preElementStyled) {
-                this.style.backgroundColor = getComputedStyle(this.preElement).backgroundColor;
-                this.textareaElement.style.height = getComputedStyle(this.preElement).height;
-                this.textareaElement.style.width = getComputedStyle(this.preElement).width;
-            } else {
-                this.style.backgroundColor = getComputedStyle(this.codeElement).backgroundColor;
-                this.textareaElement.style.height = getComputedStyle(this.codeElement).height;
-                this.textareaElement.style.width = getComputedStyle(this.codeElement).width;
-            }
-        }
-
-        /**
-         * Show some instructions to the user only if they are using keyboard navigation - for example, a prompt on how to navigate with the keyboard if Tab is repurposed.
-         * @param {string} instructions The instructions to display only if keyboard navigation is being used. If it's blank, no instructions will be shown.
-         * @param {boolean} includeAriaDescriptionFirst Whether to include the aria-description of the code-input element before the keyboard navigation instructions for a screenreader. Keep this as true when the textarea is first focused.
-         */
-        setKeyboardNavInstructions(instructions, includeAriaDescriptionFirst) {
-            this.dialogContainerElement.querySelector(".code-input_keyboard-navigation-instructions").innerText = instructions;
-            if(includeAriaDescriptionFirst) {
-                this.textareaElement.setAttribute("aria-description", this.originalAriaDescription + ". " + instructions);
-            } else {
-                this.textareaElement.setAttribute("aria-description", instructions);
-            }
-        }
-
-        /**
-         * HTML-escape an arbitrary string.
-         * @param {string} text - The original, unescaped text
-         * @returns {string} - The new, HTML-escaped text
-         */
-        escapeHtml(text) {
-            return text.replace(new RegExp("&", "g"), "&amp;").replace(new RegExp("<", "g"), "&lt;"); /* Global RegExp */
-        }
-
-        /**
-         * HTML-unescape an arbitrary string.
-         * @param {string} text - The original, HTML-escaped text
-         * @returns {string} - The new, unescaped text
-         */
-        unescapeHtml(text) {
-            return text.replace(new RegExp("&amp;", "g"), "&").replace(new RegExp("&lt;", "g"), "<").replace(new RegExp("&gt;", "g"), ">"); /* Global RegExp */
-        }
-
-        /**
-         * Get the template object this code-input element is using.
-         * @returns {Object} - Template object
-         */
-        getTemplate() {
-            let templateName;
-            if (this.getAttribute("template") == undefined) {
-                // Default
-                templateName = codeInput.defaultTemplate;
-            } else {
-                templateName = this.getAttribute("template");
-            }
-            if (templateName in codeInput.usedTemplates) {
-                return codeInput.usedTemplates[templateName];
-            } else {
-                // Doesn't exist - add to queue
-                if (!(templateName in codeInput.templateNotYetRegisteredQueue)) {
-                    codeInput.templateNotYetRegisteredQueue[templateName] = [];
-                }
-                codeInput.templateNotYetRegisteredQueue[templateName].push(this);
-                return undefined;
-            }
-        }
-
-        /**
-         * Set up and initialise the textarea.
-         * This will be called once the template has been added.
-         */
-        setup() {
-            if(this.textareaElement != null) return; // Already set up
-
-            this.classList.add("code-input_registered"); // Remove register message
-            if (this.template.preElementStyled) this.classList.add("code-input_pre-element-styled");
-
-            this.pluginEvt("beforeElementsAdded");
-
-            // First-time attribute sync
-            let lang = this.getAttribute("language") || this.getAttribute("lang");
-            let placeholder = this.getAttribute("placeholder") || this.getAttribute("language") || this.getAttribute("lang") || "";
-            let value = this.unescapeHtml(this.innerHTML) || this.getAttribute("value") || "";
-            // Value attribute deprecated, but included for compatibility
-
-            this.initialValue = value; // For form reset
-
-            // Create textarea
-            let textarea = document.createElement("textarea");
-            textarea.placeholder = placeholder;
-            if(value != "") {
-                textarea.value = value;
-            }
-            textarea.innerHTML = this.innerHTML;
-            textarea.setAttribute("spellcheck", "false");
-            
-            // Disable focusing on the code-input element - only allow the textarea to be focusable
-            textarea.setAttribute("tabindex", this.getAttribute("tabindex") || 0);
-            this.setAttribute("tabindex", -1);
-            // Save aria-description so keyboard navigation guidance can be added.
-            this.originalAriaDescription = this.getAttribute("aria-description") || "Code input field";
-
-            // Accessibility - detect when mouse focus to remove focus outline + keyboard navigation guidance that could irritate users.
-            this.addEventListener("mousedown", () => {
-                this.classList.add("code-input_mouse-focused");
-            });
-            textarea.addEventListener("blur", () => {
-                if(this.handleEventsFromTextarea) {
-                    this.classList.remove("code-input_mouse-focused");
-                }
-            });
-
-            this.innerHTML = ""; // Clear Content
-
-            // Synchronise attributes to textarea
-            for(let i = 0; i < this.attributes.length; i++) {
-                let attribute = this.attributes[i].name;
-                if (codeInput.textareaSyncAttributes.includes(attribute) || attribute.substring(0, 5) == "aria-") {
-                    textarea.setAttribute(attribute, this.getAttribute(attribute));
-                }
-            }
-
-            textarea.addEventListener('input', (evt) => { this.value = this.textareaElement.value; });
-
-            // Save element internally
-            this.textareaElement = textarea;
-            this.append(textarea);
-
-            // Create result element
-            let code = document.createElement("code");
-            let pre = document.createElement("pre");
-            pre.setAttribute("aria-hidden", "true"); // Hide for screen readers
-            pre.setAttribute("tabindex", "-1"); // Hide for keyboard navigation
-            pre.setAttribute("inert", true); // Hide for keyboard navigation
-
-            // Save elements internally
-            this.preElement = pre;
-            this.codeElement = code;
-            pre.append(code);
-            this.append(pre);
-
-            if (this.template.isCode) {
-                if (lang != undefined && lang != "") {
-                    code.classList.add("language-" + lang.toLowerCase());
-                }
-            }
-
-            // dialogContainerElement used to store non-scrolling dialog boxes, etc.
-            let dialogContainerElement = document.createElement("div");
-            dialogContainerElement.classList.add("code-input_dialog-container");
-            this.append(dialogContainerElement);
-            this.dialogContainerElement = dialogContainerElement;
-
-            let keyboardNavigationInstructions = document.createElement("div");
-            keyboardNavigationInstructions.classList.add("code-input_keyboard-navigation-instructions");
-            dialogContainerElement.append(keyboardNavigationInstructions);
-
-            this.pluginEvt("afterElementsAdded");
-
-            this.dispatchEvent(new CustomEvent("code-input_load"));
-
-            this.value = value;
-            this.animateFrame();
-
-            const resizeObserver = new ResizeObserver((elements) => {
-                // The only element that could be resized is this code-input element.
-                this.syncSize();
-            });
-            resizeObserver.observe(this);
-        }
-
-        /**
-         * @deprecated Please use `codeInput.CodeInput.escapeHtml`
-         */
-        escape_html(text) {
-            return this.escapeHtml(text);
-        }
-
-        /**
-         * @deprecated Please use `codeInput.CodeInput.getTemplate`
-         */
-        get_template() {
-            return this.getTemplate();
-        }
-
-
-        /* ------------------------------------
-        *  -----------Callbacks----------------
-        *  ------------------------------------
-        * Implement the `HTMLElement` callbacks
-        * to trigger the main functionality properly. */
-
-        /**
-         * When the code-input element has been added to the document,
-         * find its template and set up the element.
-         */
-        connectedCallback() {
-            this.template = this.getTemplate();
-            if (this.template != undefined) {
-                this.classList.add("code-input_registered");
-                codeInput.runOnceWindowLoaded(() => { 
-                    this.setup();
-                    this.classList.add("code-input_loaded");
-                }, this);
-            }
-            this.mutationObserver = new MutationObserver(this.mutationObserverCallback.bind(this));
-            this.mutationObserver.observe(this, {
-                attributes: true,
-                attributeOldValue: true
-            });
-        }
-
-        mutationObserverCallback(mutationList, observer) {
-            for (const mutation of mutationList) {
-                if (mutation.type !== 'attributes')
-                    continue;
-
-                /* Check regular attributes */
-                for(let i = 0; i < codeInput.observedAttributes.length; i++) {
-                    if (mutation.attributeName == codeInput.observedAttributes[i]) {
-                        return this.attributeChangedCallback(mutation.attributeName, mutation.oldValue, super.getAttribute(mutation.attributeName));
-                    }
-                }
-                if (mutation.attributeName.substring(0, 5) == "aria-") {
-                    return this.attributeChangedCallback(mutation.attributeName, mutation.oldValue, super.getAttribute(mutation.attributeName));
-                }
-            }
-        }
-
-        disconnectedCallback() {
-            this.mutationObserver.disconnect();
-        }
-
-        /**
-         * Triggered when an observed HTML attribute
-         * has been modified (called from `mutationObserverCallback`).
-         * @param {string} name - The name of the attribute
-         * @param {string} oldValue - The value of the attribute before it was changed
-         * @param {string} newValue - The value of the attribute after it is changed
-         */
-        attributeChangedCallback(name, oldValue, newValue) {
-            if (this.isConnected) {
-                this.pluginEvt("attributeChanged", [name, oldValue, newValue]);
-                switch (name) {
-
-                    case "value":
-                        this.value = newValue;
-                        break;
-                    case "template":
-                        this.template = codeInput.usedTemplates[newValue || codeInput.defaultTemplate];
-                        if (this.template.preElementStyled) this.classList.add("code-input_pre-element-styled");
-                        else this.classList.remove("code-input_pre-element-styled");
-                        // Syntax Highlight
-                        this.scheduleHighlight();
-
-                        break;
-
-                    case "lang":
-                    case "language":
-                        let code = this.codeElement;
-                        let mainTextarea = this.textareaElement;
-
-                        // Check not already updated
-                        if (newValue != null) {
-                            newValue = newValue.toLowerCase();
-
-                            if (code.classList.contains(`language-${newValue}`)) break; // Already updated
-                        }
-
-                        if(oldValue !== null) {
-                            // Case insensitive
-                            oldValue = oldValue.toLowerCase();
-
-                            // Remove old language class and add new
-                            code.classList.remove("language-" + oldValue); // From codeElement
-                            code.parentElement.classList.remove("language-" + oldValue); // From preElement
-                        }
-                        // Add new language class
-                        code.classList.remove("language-none"); // Prism
-                        code.parentElement.classList.remove("language-none"); // Prism
-
-                        if (newValue != undefined && newValue != "") {
-                            code.classList.add("language-" + newValue);
-                        }
-
-                        if (mainTextarea.placeholder == oldValue) mainTextarea.placeholder = newValue;
-
-                        this.scheduleHighlight();
-
-                        break;
-                    default:
-                        if (codeInput.textareaSyncAttributes.includes(name) || name.substring(0, 5) == "aria-") {
-                            if(newValue == null || newValue == undefined) {
-                                this.textareaElement.removeAttribute(name);
-                            } else {
-                                this.textareaElement.setAttribute(name, newValue);
-                            }
-                        } else {
-                            codeInput.textareaSyncAttributes.regexp.forEach((attribute) => {
-                                if (name.match(attribute)) {
-                                    if(newValue == null) {
-                                        this.textareaElement.removeAttribute(name);
-                                    } else {
-                                        this.textareaElement.setAttribute(name, newValue);
-                                    }
-                                }
-                            });
-                        }
-                        break;
-                }
-            }
-
-        }
-
-        /* ------------------------------------
-        *  -----------Overrides----------------
-        *  ------------------------------------
-        * Override/Implement ordinary HTML textarea functionality so that the <code-input>
-        * element acts just like a <textarea>. */
-
-        /**
-         * @override
-         */
-        addEventListener(type, listener, options = undefined) {
-            // Save a copy of the callback where `this` refers to the code-input element.
-            let boundCallback = function (evt) {
-                if (typeof listener === 'function') {
-                    listener(evt);
-                } else if (listener && listener.handleEvent) {
-                    listener.handleEvent(evt);
-                }
-            }.bind(this);
-            this.boundEventCallbacks[listener] = boundCallback;
-
-            if (codeInput.textareaSyncEvents.includes(type)) {
-                // Synchronise with textarea, only when handleEventsFromTextarea is true
-                // This callback is modified to only run when the handleEventsFromTextarea is set.
-                let conditionalBoundCallback = function(evt) { if(this.handleEventsFromTextarea) boundCallback(evt); }.bind(this);
-                this.boundEventCallbacks[listener] = conditionalBoundCallback;
-
-                if (options === undefined) {
-                    if(this.textareaElement == null) {
-                        this.addEventListener("code-input_load", () => { this.textareaElement.addEventListener(type, boundCallback); });
-                    } else {
-                        this.textareaElement.addEventListener(type, conditionalBoundCallback);
-                    }
-                } else {
-                    if(this.textareaElement == null) {
-                        this.addEventListener("code-input_load", () => { this.textareaElement.addEventListener(type, boundCallback, options); });
-                    } else {
-                        this.textareaElement.addEventListener(type, conditionalBoundCallback, options);
-                    }
-                }
-            } else {
-                // Synchronise with code-input element
-                if (options === undefined) {
-                    super.addEventListener(type, boundCallback);
-                } else {
-                    super.addEventListener(type, boundCallback, options);
-                }
-            }
-        }
-
-        /**
-         * @override
-         */
-        removeEventListener(type, listener, options = undefined) {
-            // Save a copy of the callback where `this` refers to the code-input element 
-            let boundCallback = this.boundEventCallbacks[listener];
-
-            if (codeInput.textareaSyncEvents.includes(type)) {
-                // Synchronise with textarea
-                if (options === undefined) {
-                    if(this.textareaElement == null) {
-                        this.addEventListener("code-input_load", () => { this.textareaElement.removeEventListener(type, boundCallback); });
-                    } else {
-                        this.textareaElement.removeEventListener(type, boundCallback);
-                    }
-                } else {
-                    if(this.textareaElement == null) {
-                        this.addEventListener("code-input_load", () => { this.textareaElement.removeEventListener(type, boundCallback, options); });
-                    } else {
-                        this.textareaElement.removeEventListener(type, boundCallback, options);
-                    }
-                }
-            } else {
-                // Synchronise with code-input element
-                if (options === undefined) {
-                    super.removeEventListener(type, boundCallback);
-                } else {
-                    super.removeEventListener(type, boundCallback, options);
-                }
-            }
-        }
-
-        /**
-         * Get the text contents of the code-input element.
-         */
-        get value() {
-            // Get from editable textarea element
-            return this.textareaElement.value;
-        }
-        /**
-         * Set the text contents of the code-input element.
-         * @param {string} val - New text contents
-         */
-        set value(val) {
-            if (val === null || val === undefined) {
-                val = "";
-            }
-            // Save in editable textarea element
-            this.textareaElement.value = val;
-            // Trigger highlight
-            this.scheduleHighlight();
-            return val;
-        }
-
-        /**
-         * Get the placeholder of the code-input element that appears
-         * when no code has been entered.
-         */
-        get placeholder() {
-            return this.getAttribute("placeholder");
-        }
-        /**
-         * Set the placeholder of the code-input element that appears
-         * when no code has been entered.
-         * @param {string} val - New placeholder
-         */
-        set placeholder(val) {
-            return this.setAttribute("placeholder", val);
-        }
-
-        /**
-         * Returns a  ValidityState object that represents the validity states of an element.
-         * 
-         * See `HTMLTextAreaElement.validity`
-         */
-        get validity() {
-            return this.textareaElement.validity;
-        }
-
-        /**
-         * Returns the error message that would be displayed if the user submits the form, or an empty string if no error message. 
-         * It also triggers the standard error message, such as "this is a required field". The result is that the user sees validation 
-         * messages without actually submitting.
-         * 
-         * See `HTMLTextAreaElement.validationMessage`
-         */
-        get validationMessage() {
-            return this.textareaElement.validationMessage;
-        }
-
-        /**
-         * Sets a custom error message that is displayed when a form is submitted.
-         * 
-         * See `HTMLTextAreaElement.setCustomValidity`
-         * @param error Sets a custom error message that is displayed when a form is submitted.
-         */
-        setCustomValidity(error) {
-            return this.textareaElement.setCustomValidity(error);
-        }
-
-        /**
-         * Returns whether a form will validate when it is submitted, 
-         * without having to submit it.
-         * 
-         * See `HTMLTextAreaElement.checkValidity`
-         */
-        checkValidity() {
-            return this.textareaElement.checkValidity();
-        }
-
-        /**
-         * See `HTMLTextAreaElement.reportValidity`
-         */
-        reportValidity() {
-            return this.textareaElement.reportValidity();
-        }
-
-        /**
-         * Allows plugins to store data in the scope of a single element.
-         * Key - name of the plugin
-         * Value - object of data to be stored; different plugins may use this differently.
-         */
-        pluginData = {};
-
-        /**
-        * Update value on form reset
-        */
-        formResetCallback() {
-            this.value = this.initialValue;
-        };
-    },
-
-    /** 
-     * To ensure the DOM is ready, run this callback after the window 
-     * has loaded (or now if it has already loaded)
-     */
-    runOnceWindowLoaded(callback, codeInputElem) {
-        if(document.readyState == "complete") {
-            callback(); // Fully loaded
-        } else {
-            window.addEventListener("load", callback);
-        }
-    }
-}
-
-customElements.define("code-input", codeInput.CodeInput);
diff --git a/src/imports/code.html b/src/imports/code.html
deleted file mode 100644 (file)
index 4d2ba5e..0000000
+++ /dev/null
@@ -1,242 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
-       <title>EstoulsAPI</title>
-       <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-       <link href="istina-editor.css" rel="stylesheet" />
-       <script src="estouls-api.js"></script>
-       <script src="istina-editor.js"></script>
-</head>
-<body>
-<style>
-body { background-color: #1f1f1f; }
-table { background-color: #1f1f1f; }
-
-table { width: 100%; }
-
-.response
-{
-       color: red;
-       font-weight: bold;
-       font-family: monospace;
-}
-
-.optionspanel
-{
-       text-align: right;
-       width: 100%;
-}
-.option
-{
-       font-size: 24px;
-       font-weight: bold;
-       font-family: monospace;
-       cursor: pointer;
-       background-color: rgba(0,0,0,0);
-       padding: 0;
-       margin: 0;
-       border: 0;
-       display: inline-block;
-}
-#run { color: green; }
-#setup { font-size: 28px; color: grey; }
-#save,#help { font-size: 20px; display: none; }
-#load,#copy,#clear,#apk { font-size: 20px; }
-#apkwrapper { display: none; }
-
-</style>
-
-<div id="horizontal">
-
-<div class="optionspanel">
-       <button class="option" id="load">&#128194;</button>&nbsp;&nbsp;
-       <button class="option" id="copy">&#128203;</button>&nbsp;&nbsp;
-       <button class="option" id="clear">&#129529;</button>&nbsp;&nbsp;
-       <button class="option" id="save">&#128190;</button><!--&nbsp;&nbsp;-->
-       <button class="option" id="run">&#9654;</button><!--&nbsp;&nbsp;-->
-       <button class="option" id="help">&#10067;</button>&nbsp;&nbsp;
-       <div id="apkwrapper"><button class="option" id="apk">&#x1F4F2;</button>&nbsp;&nbsp;</div>
-       <button class="option" id="setup">&#9881;</button>
-</div>
-<istina-editor></istina-editor>
-<hr style='border-color: #6e7681;' />
-<div class="response"></div>
-</div>
-
-<script>
-IstinaEditor.init();
-if (window.location.hash == "#mobile")
-{
-       $("#horizontal")[0].remove();
-       var iframe = document.createElement("iframe");
-       iframe.src = window.location.href.split("#")[0];
-       iframe.style.width = window.innerHeight + "px";
-       iframe.style.height = window.innerWidth + "px";
-       iframe.style.transformOrigin = "top left";
-       iframe.style.transform = "rotate(90deg)";
-       iframe.style.position = "fixed";
-       iframe.style.top = "0px";
-       iframe.style.left = window.innerWidth + "px";
-       iframe.frameBorder = "0";
-       document.body.appendChild(iframe);
-       
-}
-else
-{
-       window.addEventListener("DOMContentLoaded", () =>
-       {
-               if (window.location.href.includes(".com") || window.location.href.includes("192."))
-               {
-                       $("#apkwrapper")[0].style.display = "inline-block";
-               }
-               setTimeout(function()
-               {
-                       $(".response")[0].style.height = (window.innerHeight * 0.40) + "px";
-               }, 100);
-               
-               //$(".istina-basis")[0].style.top = Math.round($(".istina-overlay")[0].getBoundingClientRect().top) + "px";
-               //$(".istina-basis")[0].style.left = Math.round($(".istina-overlay")[0].getBoundingClientRect().left) + "px";
-       });
-
-       $("#clear")[0].addEventListener("click", () =>
-       {
-               IstinaEditor.setText("");
-       });
-
-       $("#apk")[0].addEventListener("click", () =>
-       {
-               var a = document.createElement("a");
-               a.href = "/apk";
-               a.download = "EstoulsAPI.apk";
-               a.style.display = "none";
-               document.body.appendChild(a);
-               a.click();
-               a.remove();
-       });
-
-       $("#save")[0].addEventListener("click", () =>
-       {
-               var txt = btoa($(".istina-basis")[0].innerText);
-               txt = "data:text/plain;base64," + txt;
-               var a = document.createElement("a");
-               a.href = txt;
-               a.download = "program.txt";
-               a.style.display = "none";
-               document.body.appendChild(a);
-               a.click();
-               a.remove();
-       });
-
-       $("#copy")[0].addEventListener("click", () =>
-       {
-               var tmp = document.createElement('textarea');
-               tmp.value = IstinaEditor.getText();
-               document.body.appendChild(tmp);
-               tmp.focus();
-               tmp.select();
-               document.execCommand('copy');
-               tmp.remove();
-       });
-
-
-       $("#help")[0].addEventListener("click", () =>
-       {
-               window.location.href = "https://doi.org/10.48550/arXiv.1707.03429";
-       });
-
-       $("#load")[0].addEventListener("click", () =>
-       {
-               var load = document.createElement("input");
-               load.type = "file";
-               load.style.display = "none";
-               /*while ($("input[type=file]").length > 0)
-               {
-                       $("input[type=file]")[0].remove();
-               }*/
-               window.pr = new Promise(r =>
-               {
-                       load.addEventListener("change", () =>
-                       {
-                               var reader = new FileReader();
-                               reader.addEventListener("load", (e) =>
-                               {
-                                       r(atob(e.target.result.split(",")[1]));
-                                       load.remove();          
-                               });
-                               reader.readAsDataURL(load.files[0]);
-                       });
-                       document.body.appendChild(load);
-                       load.click();
-               }).then(text =>
-               {
-                       var tmp = "!!!" + Math.random().toString().replace(".", "0") + "!!!";
-                       text = text.trim().replaceAll("\n", tmp).replaceAll("\r", "");
-                       tmp = text.replaceAll(tmp, "</div><div>");
-                       if (tmp.substring(0, 5) != "<div>")
-                       {
-                               tmp = "<div>" + tmp;
-                       }
-                       if (tmp.substring(tmp.length - 5, tmp.length) == "<div>")
-                       {
-                               tmp = tmp.substring(0, tmp.length - 5);
-                       }
-                       tmp = tmp.replaceAll("<div></div>", "<div><br></div>");
-                       $(".istina-basis")[0].innerHTML = tmp;
-               });
-       });
-
-       $("#setup")[0].addEventListener("click", () =>
-       {
-               var msg = "username:apikey:endpoint";
-               var dat = localStorage.getItem("api_info");
-               dat = dat == null ? prompt(msg) : prompt(msg, dat);
-               if (dat == null) return;
-               dat = dat.replace("http://", "").replace("https://", "");
-               localStorage.setItem("api_info", dat);
-       });
-
-       $("#run")[0].addEventListener("click", () =>
-       {
-               var dat = localStorage.getItem("api_info");
-               if (dat == null || dat == undefined)
-               {
-                       $(".response")[0].style.color = "red";
-                       $(".response")[0].innerText = "API info not set.\nPlease press the gear on the top-right.";
-                       return;
-               }
-               dat = dat.split(":");
-               if (dat.length != 3)
-               {
-                       $(".response")[0].style.color = "red";
-                       $(".response")[0].innerText = "API info not set correctly.\nPlease press the gear on the top-right.";
-                       return;
-               }
-               
-               EstoulsAPI.username = dat[0];
-               EstoulsAPI.apikey = dat[1];
-               EstoulsAPI.endpoint = "https://" + dat[2];
-               EstoulsAPI.request(IstinaEditor.getText()).then(x =>
-               {
-                       if (x.success && x.response.trim().length > 0)
-                       {
-                               $(".response")[0].style.color = "green";
-                               $(".response")[0].innerText = x.response;
-                       }
-                       else if (x.success && x.response.trim().length == 0)
-                       {
-                               $(".response")[0].style.color = "yellow";
-                               $(".response")[0].innerText = "Empty response.";
-                       }
-                       else
-                       {
-                               $(".response")[0].style.color = "red";
-                               $(".response")[0].innerText = x.response;
-                       }
-               }).catch(x => alert("ERR(2)" + x));
-       });
-
-}
-</script>
-</body>
-</html>
-
diff --git a/src/imports/dom-to-image.js b/src/imports/dom-to-image.js
deleted file mode 100644 (file)
index 27201ac..0000000
+++ /dev/null
@@ -1,769 +0,0 @@
-(function (global) {
-    'use strict';
-
-    var util = newUtil();
-    var inliner = newInliner();
-    var fontFaces = newFontFaces();
-    var images = newImages();
-
-    // Default impl options
-    var defaultOptions = {
-        // Default is to fail on error, no placeholder
-        imagePlaceholder: undefined,
-        // Default cache bust is false, it will use the cache
-        cacheBust: false
-    };
-
-    var domtoimage = {
-        toSvg: toSvg,
-        toPng: toPng,
-        toJpeg: toJpeg,
-        toBlob: toBlob,
-        toPixelData: toPixelData,
-        impl: {
-            fontFaces: fontFaces,
-            images: images,
-            util: util,
-            inliner: inliner,
-            options: {}
-        }
-    };
-
-    if (typeof module !== 'undefined')
-        module.exports = domtoimage;
-    else
-        global.domtoimage = domtoimage;
-
-
-    /**
-     * @param {Node} node - The DOM Node object to render
-     * @param {Object} options - Rendering options
-     * @param {Function} options.filter - Should return true if passed node should be included in the output
-     *          (excluding node means excluding it's children as well). Not called on the root node.
-     * @param {String} options.bgcolor - color for the background, any valid CSS color value.
-     * @param {Number} options.width - width to be applied to node before rendering.
-     * @param {Number} options.height - height to be applied to node before rendering.
-     * @param {Object} options.style - an object whose properties to be copied to node's style before rendering.
-     * @param {Number} options.quality - a Number between 0 and 1 indicating image quality (applicable to JPEG only),
-                defaults to 1.0.
-     * @param {String} options.imagePlaceholder - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch
-     * @param {Boolean} options.cacheBust - set to true to cache bust by appending the time to the request url
-     * @return {Promise} - A promise that is fulfilled with a SVG image data URL
-     * */
-    function toSvg(node, options) {
-        options = options || {};
-        copyOptions(options);
-        return Promise.resolve(node)
-            .then(function (node) {
-                return cloneNode(node, options.filter, true);
-            })
-            .then(embedFonts)
-            .then(inlineImages)
-            .then(applyOptions)
-            .then(function (clone) {
-                return makeSvgDataUri(clone,
-                    options.width || util.width(node),
-                    options.height || util.height(node)
-                );
-            });
-
-        function applyOptions(clone) {
-            if (options.bgcolor) clone.style.backgroundColor = options.bgcolor;
-
-            if (options.width) clone.style.width = options.width + 'px';
-            if (options.height) clone.style.height = options.height + 'px';
-
-            if (options.style)
-                Object.keys(options.style).forEach(function (property) {
-                    clone.style[property] = options.style[property];
-                });
-
-            return clone;
-        }
-    }
-
-    /**
-     * @param {Node} node - The DOM Node object to render
-     * @param {Object} options - Rendering options, @see {@link toSvg}
-     * @return {Promise} - A promise that is fulfilled with a Uint8Array containing RGBA pixel data.
-     * */
-    function toPixelData(node, options) {
-        return draw(node, options || {})
-            .then(function (canvas) {
-                return canvas.getContext('2d').getImageData(
-                    0,
-                    0,
-                    util.width(node),
-                    util.height(node)
-                ).data;
-            });
-    }
-
-    /**
-     * @param {Node} node - The DOM Node object to render
-     * @param {Object} options - Rendering options, @see {@link toSvg}
-     * @return {Promise} - A promise that is fulfilled with a PNG image data URL
-     * */
-    function toPng(node, options) {
-        return draw(node, options || {})
-            .then(function (canvas) {
-                return canvas.toDataURL();
-            });
-    }
-
-    /**
-     * @param {Node} node - The DOM Node object to render
-     * @param {Object} options - Rendering options, @see {@link toSvg}
-     * @return {Promise} - A promise that is fulfilled with a JPEG image data URL
-     * */
-    function toJpeg(node, options) {
-        options = options || {};
-        return draw(node, options)
-            .then(function (canvas) {
-                return canvas.toDataURL('image/jpeg', options.quality || 1.0);
-            });
-    }
-
-    /**
-     * @param {Node} node - The DOM Node object to render
-     * @param {Object} options - Rendering options, @see {@link toSvg}
-     * @return {Promise} - A promise that is fulfilled with a PNG image blob
-     * */
-    function toBlob(node, options) {
-        return draw(node, options || {})
-            .then(util.canvasToBlob);
-    }
-
-    function copyOptions(options) {
-        // Copy options to impl options for use in impl
-        if(typeof(options.imagePlaceholder) === 'undefined') {
-            domtoimage.impl.options.imagePlaceholder = defaultOptions.imagePlaceholder;
-        } else {
-            domtoimage.impl.options.imagePlaceholder = options.imagePlaceholder;
-        }
-
-        if(typeof(options.cacheBust) === 'undefined') {
-            domtoimage.impl.options.cacheBust = defaultOptions.cacheBust;
-        } else {
-            domtoimage.impl.options.cacheBust = options.cacheBust;
-        }
-    }
-
-    function draw(domNode, options) {
-        return toSvg(domNode, options)
-            .then(util.makeImage)
-            .then(util.delay(100))
-            .then(function (image) {
-                var canvas = newCanvas(domNode);
-                canvas.getContext('2d').drawImage(image, 0, 0);
-                return canvas;
-            });
-
-        function newCanvas(domNode) {
-            var canvas = document.createElement('canvas');
-            canvas.width = options.width || util.width(domNode);
-            canvas.height = options.height || util.height(domNode);
-
-            if (options.bgcolor) {
-                var ctx = canvas.getContext('2d');
-                ctx.fillStyle = options.bgcolor;
-                ctx.fillRect(0, 0, canvas.width, canvas.height);
-            }
-
-            return canvas;
-        }
-    }
-
-    function cloneNode(node, filter, root) {
-        if (!root && filter && !filter(node)) return Promise.resolve();
-
-        return Promise.resolve(node)
-            .then(makeNodeCopy)
-            .then(function (clone) {
-                return cloneChildren(node, clone, filter);
-            })
-            .then(function (clone) {
-                return processClone(node, clone);
-            });
-
-        function makeNodeCopy(node) {
-            if (node instanceof HTMLCanvasElement) return util.makeImage(node.toDataURL());
-            return node.cloneNode(false);
-        }
-
-        function cloneChildren(original, clone, filter) {
-            var children = original.childNodes;
-            if (children.length === 0) return Promise.resolve(clone);
-
-            return cloneChildrenInOrder(clone, util.asArray(children), filter)
-                .then(function () {
-                    return clone;
-                });
-
-            function cloneChildrenInOrder(parent, children, filter) {
-                var done = Promise.resolve();
-                children.forEach(function (child) {
-                    done = done
-                        .then(function () {
-                            return cloneNode(child, filter);
-                        })
-                        .then(function (childClone) {
-                            if (childClone) parent.appendChild(childClone);
-                        });
-                });
-                return done;
-            }
-        }
-
-        function processClone(original, clone) {
-            if (!(clone instanceof Element)) return clone;
-
-            return Promise.resolve()
-                .then(cloneStyle)
-                .then(clonePseudoElements)
-                .then(copyUserInput)
-                .then(fixSvg)
-                .then(function () {
-                    return clone;
-                });
-
-            function cloneStyle() {
-                copyStyle(window.getComputedStyle(original), clone.style);
-
-                function copyStyle(source, target) {
-                    if (source.cssText) target.cssText = source.cssText;
-                    else copyProperties(source, target);
-
-                    function copyProperties(source, target) {
-                        util.asArray(source).forEach(function (name) {
-                            target.setProperty(
-                                name,
-                                source.getPropertyValue(name),
-                                source.getPropertyPriority(name)
-                            );
-                        });
-                    }
-                }
-            }
-
-            function clonePseudoElements() {
-                [':before', ':after'].forEach(function (element) {
-                    clonePseudoElement(element);
-                });
-
-                function clonePseudoElement(element) {
-                    var style = window.getComputedStyle(original, element);
-                    var content = style.getPropertyValue('content');
-
-                    if (content === '' || content === 'none') return;
-
-                    var className = util.uid();
-                    clone.className = clone.className + ' ' + className;
-                    var styleElement = document.createElement('style');
-                    styleElement.appendChild(formatPseudoElementStyle(className, element, style));
-                    clone.appendChild(styleElement);
-
-                    function formatPseudoElementStyle(className, element, style) {
-                        var selector = '.' + className + ':' + element;
-                        var cssText = style.cssText ? formatCssText(style) : formatCssProperties(style);
-                        return document.createTextNode(selector + '{' + cssText + '}');
-
-                        function formatCssText(style) {
-                            var content = style.getPropertyValue('content');
-                            return style.cssText + ' content: ' + content + ';';
-                        }
-
-                        function formatCssProperties(style) {
-
-                            return util.asArray(style)
-                                .map(formatProperty)
-                                .join('; ') + ';';
-
-                            function formatProperty(name) {
-                                return name + ': ' +
-                                    style.getPropertyValue(name) +
-                                    (style.getPropertyPriority(name) ? ' !important' : '');
-                            }
-                        }
-                    }
-                }
-            }
-
-            function copyUserInput() {
-                if (original instanceof HTMLTextAreaElement) clone.innerHTML = original.value;
-                if (original instanceof HTMLInputElement) clone.setAttribute("value", original.value);
-            }
-
-            function fixSvg() {
-                if (!(clone instanceof SVGElement)) return;
-                clone.setAttribute('xmlns', 'http://www.w3.org/2000/svg');
-
-                if (!(clone instanceof SVGRectElement)) return;
-                ['width', 'height'].forEach(function (attribute) {
-                    var value = clone.getAttribute(attribute);
-                    if (!value) return;
-
-                    clone.style.setProperty(attribute, value);
-                });
-            }
-        }
-    }
-
-    function embedFonts(node) {
-        return fontFaces.resolveAll()
-            .then(function (cssText) {
-                var styleNode = document.createElement('style');
-                node.appendChild(styleNode);
-                styleNode.appendChild(document.createTextNode(cssText));
-                return node;
-            });
-    }
-
-    function inlineImages(node) {
-        return images.inlineAll(node)
-            .then(function () {
-                return node;
-            });
-    }
-
-    function makeSvgDataUri(node, width, height) {
-        return Promise.resolve(node)
-            .then(function (node) {
-                node.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
-                return new XMLSerializer().serializeToString(node);
-            })
-            .then(util.escapeXhtml)
-            .then(function (xhtml) {
-                return '<foreignObject x="0" y="0" width="100%" height="100%">' + xhtml + '</foreignObject>';
-            })
-            .then(function (foreignObject) {
-                return '<svg xmlns="http://www.w3.org/2000/svg" width="' + width + '" height="' + height + '">' +
-                    foreignObject + '</svg>';
-            })
-            .then(function (svg) {
-                return 'data:image/svg+xml;charset=utf-8,' + svg;
-            });
-    }
-
-    function newUtil() {
-        return {
-            escape: escape,
-            parseExtension: parseExtension,
-            mimeType: mimeType,
-            dataAsUrl: dataAsUrl,
-            isDataUrl: isDataUrl,
-            canvasToBlob: canvasToBlob,
-            resolveUrl: resolveUrl,
-            getAndEncode: getAndEncode,
-            uid: uid(),
-            delay: delay,
-            asArray: asArray,
-            escapeXhtml: escapeXhtml,
-            makeImage: makeImage,
-            width: width,
-            height: height
-        };
-
-        function mimes() {
-            /*
-             * Only WOFF and EOT mime types for fonts are 'real'
-             * see http://www.iana.org/assignments/media-types/media-types.xhtml
-             */
-            var WOFF = 'application/font-woff';
-            var JPEG = 'image/jpeg';
-
-            return {
-                'woff': WOFF,
-                'woff2': WOFF,
-                'ttf': 'application/font-truetype',
-                'eot': 'application/vnd.ms-fontobject',
-                'png': 'image/png',
-                'jpg': JPEG,
-                'jpeg': JPEG,
-                'gif': 'image/gif',
-                'tiff': 'image/tiff',
-                'svg': 'image/svg+xml'
-            };
-        }
-
-        function parseExtension(url) {
-            var match = /\.([^\.\/]*?)$/g.exec(url);
-            if (match) return match[1];
-            else return '';
-        }
-
-        function mimeType(url) {
-            var extension = parseExtension(url).toLowerCase();
-            return mimes()[extension] || '';
-        }
-
-        function isDataUrl(url) {
-            return url.search(/^(data:)/) !== -1;
-        }
-
-        function toBlob(canvas) {
-            return new Promise(function (resolve) {
-                var binaryString = window.atob(canvas.toDataURL().split(',')[1]);
-                var length = binaryString.length;
-                var binaryArray = new Uint8Array(length);
-
-                for (var i = 0; i < length; i++)
-                    binaryArray[i] = binaryString.charCodeAt(i);
-
-                resolve(new Blob([binaryArray], {
-                    type: 'image/png'
-                }));
-            });
-        }
-
-        function canvasToBlob(canvas) {
-            if (canvas.toBlob)
-                return new Promise(function (resolve) {
-                    canvas.toBlob(resolve);
-                });
-
-            return toBlob(canvas);
-        }
-
-        function resolveUrl(url, baseUrl) {
-            var doc = document.implementation.createHTMLDocument();
-            var base = doc.createElement('base');
-            doc.head.appendChild(base);
-            var a = doc.createElement('a');
-            doc.body.appendChild(a);
-            base.href = baseUrl;
-            a.href = url;
-            return a.href;
-        }
-
-        function uid() {
-            var index = 0;
-
-            return function () {
-                return 'u' + fourRandomChars() + index++;
-
-                function fourRandomChars() {
-                    /* see http://stackoverflow.com/a/6248722/2519373 */
-                    return ('0000' + (Math.random() * Math.pow(36, 4) << 0).toString(36)).slice(-4);
-                }
-            };
-        }
-
-        function makeImage(uri) {
-            return new Promise(function (resolve, reject) {
-                var image = new Image();
-                image.onload = function () {
-                    resolve(image);
-                };
-                image.onerror = reject;
-                image.src = uri;
-            });
-        }
-
-        function getAndEncode(url) {
-            var TIMEOUT = 30000;
-            if(domtoimage.impl.options.cacheBust) {
-                // Cache bypass so we dont have CORS issues with cached images
-                // Source: https://developer.mozilla.org/en/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest#Bypassing_the_cache
-                url += ((/\?/).test(url) ? "&" : "?") + (new Date()).getTime();
-            }
-
-            return new Promise(function (resolve) {
-                var request = new XMLHttpRequest();
-
-                request.onreadystatechange = done;
-                request.ontimeout = timeout;
-                request.responseType = 'blob';
-                request.timeout = TIMEOUT;
-                request.open('GET', url, true);
-                request.send();
-
-                var placeholder;
-                if(domtoimage.impl.options.imagePlaceholder) {
-                    var split = domtoimage.impl.options.imagePlaceholder.split(/,/);
-                    if(split && split[1]) {
-                        placeholder = split[1];
-                    }
-                }
-
-                function done() {
-                    if (request.readyState !== 4) return;
-
-                    if (request.status !== 200) {
-                        if(placeholder) {
-                            resolve(placeholder);
-                        } else {
-                            fail('cannot fetch resource: ' + url + ', status: ' + request.status);
-                        }
-
-                        return;
-                    }
-
-                    var encoder = new FileReader();
-                    encoder.onloadend = function () {
-                        var content = encoder.result.split(/,/)[1];
-                        resolve(content);
-                    };
-                    encoder.readAsDataURL(request.response);
-                }
-
-                function timeout() {
-                    if(placeholder) {
-                        resolve(placeholder);
-                    } else {
-                        fail('timeout of ' + TIMEOUT + 'ms occured while fetching resource: ' + url);
-                    }
-                }
-
-                function fail(message) {
-                    console.error(message);
-                    resolve('');
-                }
-            });
-        }
-
-        function dataAsUrl(content, type) {
-            return 'data:' + type + ';base64,' + content;
-        }
-
-        function escape(string) {
-            return string.replace(/([.*+?^${}()|\[\]\/\\])/g, '\\$1');
-        }
-
-        function delay(ms) {
-            return function (arg) {
-                return new Promise(function (resolve) {
-                    setTimeout(function () {
-                        resolve(arg);
-                    }, ms);
-                });
-            };
-        }
-
-        function asArray(arrayLike) {
-            var array = [];
-            var length = arrayLike.length;
-            for (var i = 0; i < length; i++) array.push(arrayLike[i]);
-            return array;
-        }
-
-        function escapeXhtml(string) {
-            return string.replace(/#/g, '%23').replace(/\n/g, '%0A');
-        }
-
-        function width(node) {
-            var leftBorder = px(node, 'border-left-width');
-            var rightBorder = px(node, 'border-right-width');
-            return node.scrollWidth + leftBorder + rightBorder;
-        }
-
-        function height(node) {
-            var topBorder = px(node, 'border-top-width');
-            var bottomBorder = px(node, 'border-bottom-width');
-            return node.scrollHeight + topBorder + bottomBorder;
-        }
-
-        function px(node, styleProperty) {
-            var value = window.getComputedStyle(node).getPropertyValue(styleProperty);
-            return parseFloat(value.replace('px', ''));
-        }
-    }
-
-    function newInliner() {
-        var URL_REGEX = /url\(['"]?([^'"]+?)['"]?\)/g;
-
-        return {
-            inlineAll: inlineAll,
-            shouldProcess: shouldProcess,
-            impl: {
-                readUrls: readUrls,
-                inline: inline
-            }
-        };
-
-        function shouldProcess(string) {
-            return string.search(URL_REGEX) !== -1;
-        }
-
-        function readUrls(string) {
-            var result = [];
-            var match;
-            while ((match = URL_REGEX.exec(string)) !== null) {
-                result.push(match[1]);
-            }
-            return result.filter(function (url) {
-                return !util.isDataUrl(url);
-            });
-        }
-
-        function inline(string, url, baseUrl, get) {
-            return Promise.resolve(url)
-                .then(function (url) {
-                    return baseUrl ? util.resolveUrl(url, baseUrl) : url;
-                })
-                .then(get || util.getAndEncode)
-                .then(function (data) {
-                    return util.dataAsUrl(data, util.mimeType(url));
-                })
-                .then(function (dataUrl) {
-                    return string.replace(urlAsRegex(url), '$1' + dataUrl + '$3');
-                });
-
-            function urlAsRegex(url) {
-                return new RegExp('(url\\([\'"]?)(' + util.escape(url) + ')([\'"]?\\))', 'g');
-            }
-        }
-
-        function inlineAll(string, baseUrl, get) {
-            if (nothingToInline()) return Promise.resolve(string);
-
-            return Promise.resolve(string)
-                .then(readUrls)
-                .then(function (urls) {
-                    var done = Promise.resolve(string);
-                    urls.forEach(function (url) {
-                        done = done.then(function (string) {
-                            return inline(string, url, baseUrl, get);
-                        });
-                    });
-                    return done;
-                });
-
-            function nothingToInline() {
-                return !shouldProcess(string);
-            }
-        }
-    }
-
-    function newFontFaces() {
-        return {
-            resolveAll: resolveAll,
-            impl: {
-                readAll: readAll
-            }
-        };
-
-        function resolveAll() {
-            return readAll(document)
-                .then(function (webFonts) {
-                    return Promise.all(
-                        webFonts.map(function (webFont) {
-                            return webFont.resolve();
-                        })
-                    );
-                })
-                .then(function (cssStrings) {
-                    return cssStrings.join('\n');
-                });
-        }
-
-        function readAll() {
-            return Promise.resolve(util.asArray(document.styleSheets))
-                .then(getCssRules)
-                .then(selectWebFontRules)
-                .then(function (rules) {
-                    return rules.map(newWebFont);
-                });
-
-            function selectWebFontRules(cssRules) {
-                return cssRules
-                    .filter(function (rule) {
-                        return rule.type === CSSRule.FONT_FACE_RULE;
-                    })
-                    .filter(function (rule) {
-                        return inliner.shouldProcess(rule.style.getPropertyValue('src'));
-                    });
-            }
-
-            function getCssRules(styleSheets) {
-                var cssRules = [];
-                styleSheets.forEach(function (sheet) {
-                    try {
-                        util.asArray(sheet.cssRules || []).forEach(cssRules.push.bind(cssRules));
-                    } catch (e) {
-                        console.log('Error while reading CSS rules from ' + sheet.href, e.toString());
-                    }
-                });
-                return cssRules;
-            }
-
-            function newWebFont(webFontRule) {
-                return {
-                    resolve: function resolve() {
-                        var baseUrl = (webFontRule.parentStyleSheet || {}).href;
-                        return inliner.inlineAll(webFontRule.cssText, baseUrl);
-                    },
-                    src: function () {
-                        return webFontRule.style.getPropertyValue('src');
-                    }
-                };
-            }
-        }
-    }
-
-    function newImages() {
-        return {
-            inlineAll: inlineAll,
-            impl: {
-                newImage: newImage
-            }
-        };
-
-        function newImage(element) {
-            return {
-                inline: inline
-            };
-
-            function inline(get) {
-                if (util.isDataUrl(element.src)) return Promise.resolve();
-
-                return Promise.resolve(element.src)
-                    .then(get || util.getAndEncode)
-                    .then(function (data) {
-                        return util.dataAsUrl(data, util.mimeType(element.src));
-                    })
-                    .then(function (dataUrl) {
-                        return new Promise(function (resolve, reject) {
-                            element.onload = resolve;
-                            element.onerror = reject;
-                            element.src = dataUrl;
-                        });
-                    });
-            }
-        }
-
-        function inlineAll(node) {
-            if (!(node instanceof Element)) return Promise.resolve(node);
-
-            return inlineBackground(node)
-                .then(function () {
-                    if (node instanceof HTMLImageElement)
-                        return newImage(node).inline();
-                    else
-                        return Promise.all(
-                            util.asArray(node.childNodes).map(function (child) {
-                                return inlineAll(child);
-                            })
-                        );
-                });
-
-            function inlineBackground(node) {
-                var background = node.style.getPropertyValue('background');
-
-                if (!background) return Promise.resolve(node);
-
-                return inliner.inlineAll(background)
-                    .then(function (inlined) {
-                        node.style.setProperty(
-                            'background',
-                            inlined,
-                            node.style.getPropertyPriority('background')
-                        );
-                    })
-                    .then(function () {
-                        return node;
-                    });
-            }
-        }
-    }
-})(this);
diff --git a/src/imports/estouls-api.js b/src/imports/estouls-api.js
deleted file mode 100644 (file)
index 73760d7..0000000
+++ /dev/null
@@ -1,357 +0,0 @@
-var EstoulsAPI =
-{
-       username: undefined,
-       apikey: undefined,
-       endpoint: undefined,
-       
-       Math32:
-       {
-               clamp: a =>
-               {
-                       while (a < 0 || a > 0xFFFFFFFF)
-                               a += a < 0 ? 0x100000000 : -0x100000000;
-                       return a;
-               },
-               shl: (a, b) => EstoulsAPI.Math32.clamp(a << b),
-               shr: (a, b) => EstoulsAPI.Math32.clamp(a >>> b),
-               rtl: (a, b) => EstoulsAPI.Math32.clamp((a << b) | (a >>> (32 - b))),
-               rtr: (a, b) => EstoulsAPI.Math32.clamp((a >>> b) | (a << (32 - b))),
-               add: (a, b) => EstoulsAPI.Math32.clamp(a + b),
-               sub: (a, b) => EstoulsAPI.Math32.clamp(a + b),
-               or: (a, b) => EstoulsAPI.Math32.clamp(a | b),
-               xor: (a, b) => EstoulsAPI.Math32.clamp(a ^ b)
-       },
-       HMACSHA256:
-       {
-               sign: async (key, msg) =>
-               {
-                       key = new Uint8Array(key);
-                       msg = new Uint8Array(msg);
-                       var ikey = await crypto.subtle.importKey
-                       (
-                               "raw",
-                               key,
-                               { name: "HMAC", hash: { name: "SHA-256" }},
-                               false,
-                               ["sign", "verify"]
-                       );
-                       return new Uint8Array(await window.crypto.subtle.sign({ name: "HMAC", }, ikey, msg));
-               }
-       },
-       ChaCha20:
-       {
-               QR: (cc, a, b, c, d) =>
-               {
-                       cc[a] = EstoulsAPI.Math32.add(cc[a], cc[b]);
-                       cc[d] = EstoulsAPI.Math32.xor(cc[d], cc[a]);
-                       cc[d] = EstoulsAPI.Math32.rtl(cc[d], 16);
-
-                       cc[c] = EstoulsAPI.Math32.add(cc[c], cc[d]);
-                       cc[b] = EstoulsAPI.Math32.xor(cc[b], cc[c]);
-                       cc[b] = EstoulsAPI.Math32.rtl(cc[b], 12);
-
-                       cc[a] = EstoulsAPI.Math32.add(cc[a], cc[b]);
-                       cc[d] = EstoulsAPI.Math32.xor(cc[d], cc[a]);
-                       cc[d] = EstoulsAPI.Math32.rtl(cc[d], 8);
-                       
-                       cc[c] = EstoulsAPI.Math32.add(cc[c], cc[d]);
-                       cc[b] = EstoulsAPI.Math32.xor(cc[b], cc[c]);
-                       cc[b] = EstoulsAPI.Math32.rtl(cc[b], 7);
-               },
-               DR: (cc) =>
-               {       
-                       EstoulsAPI.ChaCha20.QR(cc, 0, 4,  8, 12);
-                       EstoulsAPI.ChaCha20.QR(cc, 1, 5,  9, 13);
-                       EstoulsAPI.ChaCha20.QR(cc, 2, 6, 10, 14);
-                       EstoulsAPI.ChaCha20.QR(cc, 3, 7, 11, 15);
-                       EstoulsAPI.ChaCha20.QR(cc, 0, 5, 10, 15);
-                       EstoulsAPI.ChaCha20.QR(cc, 1, 6, 11, 12);
-                       EstoulsAPI.ChaCha20.QR(cc, 2, 7,  8, 13);
-                       EstoulsAPI.ChaCha20.QR(cc, 3, 4,  9, 14);                               
-               },
-               CB: (cc) =>
-               {
-                       var i;
-                       var x = new Array(16);
-                       for (i = 0; i < 16; i++)
-                       {
-                               x[i] = cc[i];
-                       }
-                       for (i = 0; i < 10; i++)
-                       {
-                               EstoulsAPI.ChaCha20.DR(cc);
-                       }
-                       for (i = 0; i < 16; i++)
-                       {
-                               cc[i] = EstoulsAPI.Math32.add(cc[i], x[i]);
-                       }
-               },
-               S: (cc, cs) =>
-               {
-                       for (var i = 0; i < 16; i++)
-                       {
-                               cs[4 * i] = (cc[i] & 0xFF);
-                               cs[4 * i + 1] = ((cc[i] >> 8) & 0xFF);
-                               cs[4 * i + 2] = ((cc[i] >> 16) & 0xFF);
-                               cs[4 * i + 3] = ((cc[i] >> 24) & 0xFF);
-                       }
-               },
-               B: (key, nonce, block, out) =>
-               {
-                       var cc =
-                       [
-                               0x61707865, 0x3320646e, 0x79622d32, 0x6b206574,
-
-                               key[0] | (key[1] << 8) | (key[2] << 16) | (key[3] << 24),
-                               key[4] | (key[5] << 8) | (key[6] << 16) | (key[7] << 24),
-                               key[8] | (key[9] << 8) | (key[10] << 16) | (key[11] << 24),
-                               key[12] | (key[13] << 8) | (key[14] << 16) | (key[15] << 24),
-
-                               key[16] | (key[17] << 8) | (key[18] << 16) | (key[19] << 24),
-                               key[20] | (key[21] << 8) | (key[22] << 16) | (key[23] << 24),
-                               key[24] | (key[25] << 8) | (key[26] << 16) | (key[27] << 24),
-                               key[28] | (key[29] << 8) | (key[30] << 16) | (key[31] << 24),
-
-                               block,
-
-                               nonce[0] | (nonce[1] << 8) | (nonce[2] << 16) | (nonce[3] << 24),
-                               nonce[4] | (nonce[5] << 8) | (nonce[6] << 16) | (nonce[7] << 24),
-                               nonce[8] | (nonce[9] << 8) | (nonce[10] << 16) | (nonce[11] << 24)
-                       ];
-
-                       EstoulsAPI.ChaCha20.CB(cc);
-                       EstoulsAPI.ChaCha20.S(cc, out);
-               },
-               encrypt: async (key, nonce, block, data) =>
-               {
-                       var count = data.length;
-                       if (count > (274877906944 - block * 64)) return null;
-                       var ret = new Array(0);
-                       var ccblock = new Array(64);
-                       var size = 0;
-                       while (count > 64)
-                       {
-                               ret.length = size + 64;
-                               EstoulsAPI.ChaCha20.B(key, nonce, block++, ccblock);
-                               for (var i = 0; i < 64; i++) ret[size + i] = ccblock[i];
-                               size += 64;
-                               count -= 64;
-                       }
-                       if (count > 0)
-                       {
-                               ret.length = size + count;
-                               EstoulsAPI.ChaCha20.B(key, nonce, block, ccblock);
-                               for (var i = 0; i < count; i++) ret[size + i] = ccblock[i];
-                       }
-                       for (var i = 0; i < data.length; i++) ret[i] ^= data[i];
-                       return new Uint8Array(ret);
-               }
-       },
-       
-       Base64:
-       {
-               encode: async (x) =>
-               {
-                       return await new Promise(r =>
-                       {
-                               const reader = new FileReader();
-                               reader.addEventListener("load", () => r(reader.result.split(",")[1]));
-                               reader.readAsDataURL(new Blob([new Uint8Array(x)]));                            
-                       });
-               },
-               
-               decode: (b64) =>
-               {
-                       var dec1 = (v) =>
-                       {
-                               switch (v)
-                               {
-                                       case 'A': return  0;
-                                       case 'B': return  1;
-                                       case 'C': return  2;
-                                       case 'D': return  3;
-                                       case 'E': return  4;
-                                       case 'F': return  5;
-                                       case 'G': return  6;
-                                       case 'H': return  7;
-                                       case 'I': return  8;
-                                       case 'J': return  9;
-                                       case 'K': return 10;
-                                       case 'L': return 11;
-                                       case 'M': return 12;
-                                       case 'N': return 13;
-                                       case 'O': return 14;
-                                       case 'P': return 15;
-                                       case 'Q': return 16;
-                                       case 'R': return 17;
-                                       case 'S': return 18;
-                                       case 'T': return 19;
-                                       case 'U': return 20;
-                                       case 'V': return 21;
-                                       case 'W': return 22;
-                                       case 'X': return 23;
-                                       case 'Y': return 24;
-                                       case 'Z': return 25;
-                                       case 'a': return 26;
-                                       case 'b': return 27;
-                                       case 'c': return 28;
-                                       case 'd': return 29;
-                                       case 'e': return 30;
-                                       case 'f': return 31;
-                                       case 'g': return 32;
-                                       case 'h': return 33;
-                                       case 'i': return 34;
-                                       case 'j': return 35;
-                                       case 'k': return 36;
-                                       case 'l': return 37;
-                                       case 'm': return 38;
-                                       case 'n': return 39;
-                                       case 'o': return 40;
-                                       case 'p': return 41;
-                                       case 'q': return 42;
-                                       case 'r': return 43;
-                                       case 's': return 44;
-                                       case 't': return 45;
-                                       case 'u': return 46;
-                                       case 'v': return 47;
-                                       case 'w': return 48;
-                                       case 'x': return 49;
-                                       case 'y': return 50;
-                                       case 'z': return 51;
-                                       case '0': return 52;
-                                       case '1': return 53;
-                                       case '2': return 54;
-                                       case '3': return 55;
-                                       case '4': return 56;
-                                       case '5': return 57;
-                                       case '6': return 58;
-                                       case '7': return 59;
-                                       case '8': return 60;
-                                       case '9': return 61;
-                                       case '+': return 62;
-                                       case '/': return 63;
-                               }
-                               return 255;
-                       };
-                       
-                       var ret = new Array(0);
-                       var buffer = 0;
-                       var bufferS = 0;
-                       for (var i = 0; i < b64.length; i++)
-                       {
-                               if (b64[i] == '=') { bufferS = 0; continue; };
-                               var val = dec1(b64[i]);
-                               if (val == 255) return null;
-                               buffer = ((buffer << 6) | val) & 0xFFFF;
-                               bufferS += 6;
-                               if (bufferS >= 8)
-                               {
-                                       var shift = (16 - bufferS) & 0xFF;
-                                       buffer = (buffer << shift) & 0xFFFF;
-                                       ret[ret.length] = (buffer >>> 8) & 0xFF;
-                                       buffer = buffer & 0x00FF;
-                                       buffer = (buffer >>> shift) & 0xFFFF;
-                                       bufferS -= 8;
-                               }
-                       }
-                       if (bufferS > 0)
-                       {
-                               buffer = (buffer << (16 - bufferS)) & 0xFFFF;
-                               ret[ret.length] = (buffer >>> 8) & 0xFF;
-                       }
-                       return new Uint8Array(ret);
-               }
-       },
-       
-       Hex:
-       {
-               encode: (x) =>
-               {
-                       var ret = "";
-                       x.forEach(y => { ret += y.toString(16).padStart(2, "0"); });
-                       return ret;
-               },
-               decode: (x) =>
-               {
-                       var arr = new Array(0);
-                       for (var i = 0; i < x.length; i += 2)
-                       {
-                               arr[arr.length] = parseInt(x.charAt(i) + x.charAt(i + 1), 16);
-                       }
-                       return new Uint8Array(arr);
-               }
-       },
-       
-       generateRequest: async (msg) =>
-       {
-               msg = new TextEncoder().encode(msg);
-               var key = EstoulsAPI.Hex.decode(EstoulsAPI.apikey);
-               //var sess = crypto.getRandomValues(new Uint8Array(12));
-               var r = () => { return Math.floor(Math.random() * 10000) % 256 };;
-               var sess = new Uint8Array([r(), r(), r(), r(), r(), r(), r(), r(), r(), r(), r(), r()]);
-               var rawdata = await EstoulsAPI.ChaCha20.encrypt(key, sess, 0, msg);
-               var dgst = await EstoulsAPI.Hex.encode(await EstoulsAPI.HMACSHA256.sign(key, rawdata));
-               var data = await EstoulsAPI.Base64.encode(rawdata);
-               var resp = "user=" + EstoulsAPI.username;
-               resp += "&sess=" + EstoulsAPI.Hex.encode(sess);
-               resp += "&dgst=" + dgst;
-               resp += "&data=" + data;
-               return resp;
-       },
-       
-       parseResponse: async (msg) =>
-       {
-               if (!msg.includes("user=") || !msg.includes("&sess=") || !msg.includes("&dgst=") || !msg.includes("&data="))
-               {
-                       return { success: false, response: "invalid response" };
-               }
-               var user = msg.split("user=")[1].split("&")[0].trim();
-               var sess = msg.split("&sess=")[1].split("&")[0].trim();
-               var dgst = msg.split("&dgst=")[1].split("&")[0].trim();
-               var data = msg.split("&data=")[1].split("&")[0].trim();
-               
-               if (user != EstoulsAPI.username)
-               {
-                       return { success: false, response: "invalid user in response" };
-               }
-               data = EstoulsAPI.Base64.decode(data);
-               sess = EstoulsAPI.Hex.decode(sess);
-               var key = EstoulsAPI.Hex.decode(EstoulsAPI.apikey);
-               var sig = await EstoulsAPI.Hex.encode(await EstoulsAPI.HMACSHA256.sign(key, data));
-               if (sig != dgst)
-               {
-                       return { success: false, response: "invalid signature" };
-               }
-               var resp = await EstoulsAPI.ChaCha20.encrypt(key, sess, 0, data);
-               return { success: true, response: new TextDecoder().decode(resp) };
-       },
-       
-       request: async (msg) =>
-       {
-               if (msg.trim().length == 0) return { success: true, response: "" };
-               var req = await EstoulsAPI.generateRequest(msg);
-               return await new Promise(r =>
-               {
-                       const xhr = new XMLHttpRequest();
-                       xhr.open("POST", EstoulsAPI.endpoint, true);
-                       xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
-                       xhr.onreadystatechange = (x) =>
-                       {
-                               if (xhr.readyState === XMLHttpRequest.DONE)
-                               {
-                                       if (xhr.status === 200)
-                                       {
-                                               EstoulsAPI.parseResponse(xhr.responseText).then(pr => { r(pr); }).catch(x => alert("ERR(3)"));
-                                       }
-                                       else
-                                       {
-                                               r({success: false, response: xhr.status});
-                                       }
-                               }
-                       }
-                       xhr.send(req);
-               }).catch(x => alert("ERR(1): " + x));
-       }
-       
-};
-
diff --git a/src/imports/guide.pdf b/src/imports/guide.pdf
deleted file mode 100644 (file)
index 1ecd851..0000000
Binary files a/src/imports/guide.pdf and /dev/null differ
diff --git a/src/imports/highlight.js b/src/imports/highlight.js
deleted file mode 100644 (file)
index 7974033..0000000
+++ /dev/null
@@ -1,1045 +0,0 @@
-/*
-Syntax highlighting with language autodetection.
-https://highlightjs.org/
-*/
-
-// @ts-ignore
-import deepFreeze from 'deep-freeze-es6';
-import Response from './lib/response.js';
-import TokenTreeEmitter from './lib/token_tree.js';
-import * as regex from './lib/regex.js';
-import * as utils from './lib/utils.js';
-import * as MODES from './lib/modes.js';
-import { compileLanguage } from './lib/mode_compiler.js';
-import * as packageJSON from '../package.json';
-import * as logger from "./lib/logger.js";
-import HTMLInjectionError from "./lib/html_injection_error.js";
-
-
-/**
-@typedef {import('highlight.js').Mode} Mode
-@typedef {import('highlight.js').CompiledMode} CompiledMode
-@typedef {import('highlight.js').CompiledScope} CompiledScope
-@typedef {import('highlight.js').Language} Language
-@typedef {import('highlight.js').HLJSApi} HLJSApi
-@typedef {import('highlight.js').HLJSPlugin} HLJSPlugin
-@typedef {import('highlight.js').PluginEvent} PluginEvent
-@typedef {import('highlight.js').HLJSOptions} HLJSOptions
-@typedef {import('highlight.js').LanguageFn} LanguageFn
-@typedef {import('highlight.js').HighlightedHTMLElement} HighlightedHTMLElement
-@typedef {import('highlight.js').BeforeHighlightContext} BeforeHighlightContext
-@typedef {import('highlight.js/private').MatchType} MatchType
-@typedef {import('highlight.js/private').KeywordData} KeywordData
-@typedef {import('highlight.js/private').EnhancedMatch} EnhancedMatch
-@typedef {import('highlight.js/private').AnnotatedError} AnnotatedError
-@typedef {import('highlight.js').AutoHighlightResult} AutoHighlightResult
-@typedef {import('highlight.js').HighlightOptions} HighlightOptions
-@typedef {import('highlight.js').HighlightResult} HighlightResult
-*/
-
-
-const escape = utils.escapeHTML;
-const inherit = utils.inherit;
-const NO_MATCH = Symbol("nomatch");
-const MAX_KEYWORD_HITS = 7;
-
-/**
- * @param {any} hljs - object that is extended (legacy)
- * @returns {HLJSApi}
- */
-const HLJS = function(hljs) {
-  // Global internal variables used within the highlight.js library.
-  /** @type {Record<string, Language>} */
-  const languages = Object.create(null);
-  /** @type {Record<string, string>} */
-  const aliases = Object.create(null);
-  /** @type {HLJSPlugin[]} */
-  const plugins = [];
-
-  // safe/production mode - swallows more errors, tries to keep running
-  // even if a single syntax or parse hits a fatal error
-  let SAFE_MODE = true;
-  const LANGUAGE_NOT_FOUND = "Could not find the language '{}', did you forget to load/include a language module?";
-  /** @type {Language} */
-  const PLAINTEXT_LANGUAGE = { disableAutodetect: true, name: 'Plain text', contains: [] };
-
-  // Global options used when within external APIs. This is modified when
-  // calling the `hljs.configure` function.
-  /** @type HLJSOptions */
-  let options = {
-    ignoreUnescapedHTML: false,
-    throwUnescapedHTML: false,
-    noHighlightRe: /^(no-?highlight)$/i,
-    languageDetectRe: /\blang(?:uage)?-([\w-]+)\b/i,
-    classPrefix: 'hljs-',
-    cssSelector: 'pre code',
-    languages: null,
-    // beta configuration options, subject to change, welcome to discuss
-    // https://github.com/highlightjs/highlight.js/issues/1086
-    __emitter: TokenTreeEmitter
-  };
-
-  /* Utility functions */
-
-  /**
-   * Tests a language name to see if highlighting should be skipped
-   * @param {string} languageName
-   */
-  function shouldNotHighlight(languageName) {
-    return options.noHighlightRe.test(languageName);
-  }
-
-  /**
-   * @param {HighlightedHTMLElement} block - the HTML element to determine language for
-   */
-  function blockLanguage(block) {
-    let classes = block.className + ' ';
-
-    classes += block.parentNode ? block.parentNode.className : '';
-
-    // language-* takes precedence over non-prefixed class names.
-    const match = options.languageDetectRe.exec(classes);
-    if (match) {
-      const language = getLanguage(match[1]);
-      if (!language) {
-        logger.warn(LANGUAGE_NOT_FOUND.replace("{}", match[1]));
-        logger.warn("Falling back to no-highlight mode for this block.", block);
-      }
-      return language ? match[1] : 'no-highlight';
-    }
-
-    return classes
-      .split(/\s+/)
-      .find((_class) => shouldNotHighlight(_class) || getLanguage(_class));
-  }
-
-  /**
-   * Core highlighting function.
-   *
-   * OLD API
-   * highlight(lang, code, ignoreIllegals, continuation)
-   *
-   * NEW API
-   * highlight(code, {lang, ignoreIllegals})
-   *
-   * @param {string} codeOrLanguageName - the language to use for highlighting
-   * @param {string | HighlightOptions} optionsOrCode - the code to highlight
-   * @param {boolean} [ignoreIllegals] - whether to ignore illegal matches, default is to bail
-   *
-   * @returns {HighlightResult} Result - an object that represents the result
-   * @property {string} language - the language name
-   * @property {number} relevance - the relevance score
-   * @property {string} value - the highlighted HTML code
-   * @property {string} code - the original raw code
-   * @property {CompiledMode} top - top of the current mode stack
-   * @property {boolean} illegal - indicates whether any illegal matches were found
-  */
-  function highlight(codeOrLanguageName, optionsOrCode, ignoreIllegals) {
-    let code = "";
-    let languageName = "";
-    if (typeof optionsOrCode === "object") {
-      code = codeOrLanguageName;
-      ignoreIllegals = optionsOrCode.ignoreIllegals;
-      languageName = optionsOrCode.language;
-    } else {
-      // old API
-      logger.deprecated("10.7.0", "highlight(lang, code, ...args) has been deprecated.");
-      logger.deprecated("10.7.0", "Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277");
-      languageName = codeOrLanguageName;
-      code = optionsOrCode;
-    }
-
-    // https://github.com/highlightjs/highlight.js/issues/3149
-    // eslint-disable-next-line no-undefined
-    if (ignoreIllegals === undefined) { ignoreIllegals = true; }
-
-    /** @type {BeforeHighlightContext} */
-    const context = {
-      code,
-      language: languageName
-    };
-    // the plugin can change the desired language or the code to be highlighted
-    // just be changing the object it was passed
-    fire("before:highlight", context);
-
-    // a before plugin can usurp the result completely by providing it's own
-    // in which case we don't even need to call highlight
-    const result = context.result
-      ? context.result
-      : _highlight(context.language, context.code, ignoreIllegals);
-
-    result.code = context.code;
-    // the plugin can change anything in result to suite it
-    fire("after:highlight", result);
-
-    return result;
-  }
-
-  /**
-   * private highlight that's used internally and does not fire callbacks
-   *
-   * @param {string} languageName - the language to use for highlighting
-   * @param {string} codeToHighlight - the code to highlight
-   * @param {boolean?} [ignoreIllegals] - whether to ignore illegal matches, default is to bail
-   * @param {CompiledMode?} [continuation] - current continuation mode, if any
-   * @returns {HighlightResult} - result of the highlight operation
-  */
-  function _highlight(languageName, codeToHighlight, ignoreIllegals, continuation) {
-    const keywordHits = Object.create(null);
-
-    /**
-     * Return keyword data if a match is a keyword
-     * @param {CompiledMode} mode - current mode
-     * @param {string} matchText - the textual match
-     * @returns {KeywordData | false}
-     */
-    function keywordData(mode, matchText) {
-      return mode.keywords[matchText];
-    }
-
-    function processKeywords() {
-      if (!top.keywords) {
-        emitter.addText(modeBuffer);
-        return;
-      }
-
-      let lastIndex = 0;
-      top.keywordPatternRe.lastIndex = 0;
-      let match = top.keywordPatternRe.exec(modeBuffer);
-      let buf = "";
-
-      while (match) {
-        buf += modeBuffer.substring(lastIndex, match.index);
-        const word = language.case_insensitive ? match[0].toLowerCase() : match[0];
-        const data = keywordData(top, word);
-        if (data) {
-          const [kind, keywordRelevance] = data;
-          emitter.addText(buf);
-          buf = "";
-
-          keywordHits[word] = (keywordHits[word] || 0) + 1;
-          if (keywordHits[word] <= MAX_KEYWORD_HITS) relevance += keywordRelevance;
-          if (kind.startsWith("_")) {
-            // _ implied for relevance only, do not highlight
-            // by applying a class name
-            buf += match[0];
-          } else {
-            const cssClass = language.classNameAliases[kind] || kind;
-            emitKeyword(match[0], cssClass);
-          }
-        } else {
-          buf += match[0];
-        }
-        lastIndex = top.keywordPatternRe.lastIndex;
-        match = top.keywordPatternRe.exec(modeBuffer);
-      }
-      buf += modeBuffer.substring(lastIndex);
-      emitter.addText(buf);
-    }
-
-    function processSubLanguage() {
-      if (modeBuffer === "") return;
-      /** @type HighlightResult */
-      let result = null;
-
-      if (typeof top.subLanguage === 'string') {
-        if (!languages[top.subLanguage]) {
-          emitter.addText(modeBuffer);
-          return;
-        }
-        result = _highlight(top.subLanguage, modeBuffer, true, continuations[top.subLanguage]);
-        continuations[top.subLanguage] = /** @type {CompiledMode} */ (result._top);
-      } else {
-        result = highlightAuto(modeBuffer, top.subLanguage.length ? top.subLanguage : null);
-      }
-
-      // Counting embedded language score towards the host language may be disabled
-      // with zeroing the containing mode relevance. Use case in point is Markdown that
-      // allows XML everywhere and makes every XML snippet to have a much larger Markdown
-      // score.
-      if (top.relevance > 0) {
-        relevance += result.relevance;
-      }
-      emitter.__addSublanguage(result._emitter, result.language);
-    }
-
-    function processBuffer() {
-      if (top.subLanguage != null) {
-        processSubLanguage();
-      } else {
-        processKeywords();
-      }
-      modeBuffer = '';
-    }
-
-    /**
-     * @param {string} text
-     * @param {string} scope
-     */
-    function emitKeyword(keyword, scope) {
-      if (keyword === "") return;
-
-      emitter.startScope(scope);
-      emitter.addText(keyword);
-      emitter.endScope();
-    }
-
-    /**
-     * @param {CompiledScope} scope
-     * @param {RegExpMatchArray} match
-     */
-    function emitMultiClass(scope, match) {
-      let i = 1;
-      const max = match.length - 1;
-      while (i <= max) {
-        if (!scope._emit[i]) { i++; continue; }
-        const klass = language.classNameAliases[scope[i]] || scope[i];
-        const text = match[i];
-        if (klass) {
-          emitKeyword(text, klass);
-        } else {
-          modeBuffer = text;
-          processKeywords();
-          modeBuffer = "";
-        }
-        i++;
-      }
-    }
-
-    /**
-     * @param {CompiledMode} mode - new mode to start
-     * @param {RegExpMatchArray} match
-     */
-    function startNewMode(mode, match) {
-      if (mode.scope && typeof mode.scope === "string") {
-        emitter.openNode(language.classNameAliases[mode.scope] || mode.scope);
-      }
-      if (mode.beginScope) {
-        // beginScope just wraps the begin match itself in a scope
-        if (mode.beginScope._wrap) {
-          emitKeyword(modeBuffer, language.classNameAliases[mode.beginScope._wrap] || mode.beginScope._wrap);
-          modeBuffer = "";
-        } else if (mode.beginScope._multi) {
-          // at this point modeBuffer should just be the match
-          emitMultiClass(mode.beginScope, match);
-          modeBuffer = "";
-        }
-      }
-
-      top = Object.create(mode, { parent: { value: top } });
-      return top;
-    }
-
-    /**
-     * @param {CompiledMode } mode - the mode to potentially end
-     * @param {RegExpMatchArray} match - the latest match
-     * @param {string} matchPlusRemainder - match plus remainder of content
-     * @returns {CompiledMode | void} - the next mode, or if void continue on in current mode
-     */
-    function endOfMode(mode, match, matchPlusRemainder) {
-      let matched = regex.startsWith(mode.endRe, matchPlusRemainder);
-
-      if (matched) {
-        if (mode["on:end"]) {
-          const resp = new Response(mode);
-          mode["on:end"](match, resp);
-          if (resp.isMatchIgnored) matched = false;
-        }
-
-        if (matched) {
-          while (mode.endsParent && mode.parent) {
-            mode = mode.parent;
-          }
-          return mode;
-        }
-      }
-      // even if on:end fires an `ignore` it's still possible
-      // that we might trigger the end node because of a parent mode
-      if (mode.endsWithParent) {
-        return endOfMode(mode.parent, match, matchPlusRemainder);
-      }
-    }
-
-    /**
-     * Handle matching but then ignoring a sequence of text
-     *
-     * @param {string} lexeme - string containing full match text
-     */
-    function doIgnore(lexeme) {
-      if (top.matcher.regexIndex === 0) {
-        // no more regexes to potentially match here, so we move the cursor forward one
-        // space
-        modeBuffer += lexeme[0];
-        return 1;
-      } else {
-        // no need to move the cursor, we still have additional regexes to try and
-        // match at this very spot
-        resumeScanAtSamePosition = true;
-        return 0;
-      }
-    }
-
-    /**
-     * Handle the start of a new potential mode match
-     *
-     * @param {EnhancedMatch} match - the current match
-     * @returns {number} how far to advance the parse cursor
-     */
-    function doBeginMatch(match) {
-      const lexeme = match[0];
-      const newMode = match.rule;
-
-      const resp = new Response(newMode);
-      // first internal before callbacks, then the public ones
-      const beforeCallbacks = [newMode.__beforeBegin, newMode["on:begin"]];
-      for (const cb of beforeCallbacks) {
-        if (!cb) continue;
-        cb(match, resp);
-        if (resp.isMatchIgnored) return doIgnore(lexeme);
-      }
-
-      if (newMode.skip) {
-        modeBuffer += lexeme;
-      } else {
-        if (newMode.excludeBegin) {
-          modeBuffer += lexeme;
-        }
-        processBuffer();
-        if (!newMode.returnBegin && !newMode.excludeBegin) {
-          modeBuffer = lexeme;
-        }
-      }
-      startNewMode(newMode, match);
-      return newMode.returnBegin ? 0 : lexeme.length;
-    }
-
-    /**
-     * Handle the potential end of mode
-     *
-     * @param {RegExpMatchArray} match - the current match
-     */
-    function doEndMatch(match) {
-      const lexeme = match[0];
-      const matchPlusRemainder = codeToHighlight.substring(match.index);
-
-      const endMode = endOfMode(top, match, matchPlusRemainder);
-      if (!endMode) { return NO_MATCH; }
-
-      const origin = top;
-      if (top.endScope && top.endScope._wrap) {
-        processBuffer();
-        emitKeyword(lexeme, top.endScope._wrap);
-      } else if (top.endScope && top.endScope._multi) {
-        processBuffer();
-        emitMultiClass(top.endScope, match);
-      } else if (origin.skip) {
-        modeBuffer += lexeme;
-      } else {
-        if (!(origin.returnEnd || origin.excludeEnd)) {
-          modeBuffer += lexeme;
-        }
-        processBuffer();
-        if (origin.excludeEnd) {
-          modeBuffer = lexeme;
-        }
-      }
-      do {
-        if (top.scope) {
-          emitter.closeNode();
-        }
-        if (!top.skip && !top.subLanguage) {
-          relevance += top.relevance;
-        }
-        top = top.parent;
-      } while (top !== endMode.parent);
-      if (endMode.starts) {
-        startNewMode(endMode.starts, match);
-      }
-      return origin.returnEnd ? 0 : lexeme.length;
-    }
-
-    function processContinuations() {
-      const list = [];
-      for (let current = top; current !== language; current = current.parent) {
-        if (current.scope) {
-          list.unshift(current.scope);
-        }
-      }
-      list.forEach(item => emitter.openNode(item));
-    }
-
-    /** @type {{type?: MatchType, index?: number, rule?: Mode}}} */
-    let lastMatch = {};
-
-    /**
-     *  Process an individual match
-     *
-     * @param {string} textBeforeMatch - text preceding the match (since the last match)
-     * @param {EnhancedMatch} [match] - the match itself
-     */
-    function processLexeme(textBeforeMatch, match) {
-      const lexeme = match && match[0];
-
-      // add non-matched text to the current mode buffer
-      modeBuffer += textBeforeMatch;
-
-      if (lexeme == null) {
-        processBuffer();
-        return 0;
-      }
-
-      // we've found a 0 width match and we're stuck, so we need to advance
-      // this happens when we have badly behaved rules that have optional matchers to the degree that
-      // sometimes they can end up matching nothing at all
-      // Ref: https://github.com/highlightjs/highlight.js/issues/2140
-      if (lastMatch.type === "begin" && match.type === "end" && lastMatch.index === match.index && lexeme === "") {
-        // spit the "skipped" character that our regex choked on back into the output sequence
-        modeBuffer += codeToHighlight.slice(match.index, match.index + 1);
-        if (!SAFE_MODE) {
-          /** @type {AnnotatedError} */
-          const err = new Error(`0 width match regex (${languageName})`);
-          err.languageName = languageName;
-          err.badRule = lastMatch.rule;
-          throw err;
-        }
-        return 1;
-      }
-      lastMatch = match;
-
-      if (match.type === "begin") {
-        return doBeginMatch(match);
-      } else if (match.type === "illegal" && !ignoreIllegals) {
-        // illegal match, we do not continue processing
-        /** @type {AnnotatedError} */
-        const err = new Error('Illegal lexeme "' + lexeme + '" for mode "' + (top.scope || '<unnamed>') + '"');
-        err.mode = top;
-        throw err;
-      } else if (match.type === "end") {
-        const processed = doEndMatch(match);
-        if (processed !== NO_MATCH) {
-          return processed;
-        }
-      }
-
-      // edge case for when illegal matches $ (end of line) which is technically
-      // a 0 width match but not a begin/end match so it's not caught by the
-      // first handler (when ignoreIllegals is true)
-      if (match.type === "illegal" && lexeme === "") {
-        // advance so we aren't stuck in an infinite loop
-        return 1;
-      }
-
-      // infinite loops are BAD, this is a last ditch catch all. if we have a
-      // decent number of iterations yet our index (cursor position in our
-      // parsing) still 3x behind our index then something is very wrong
-      // so we bail
-      if (iterations > 100000 && iterations > match.index * 3) {
-        const err = new Error('potential infinite loop, way more iterations than matches');
-        throw err;
-      }
-
-      /*
-      Why might be find ourselves here?  An potential end match that was
-      triggered but could not be completed.  IE, `doEndMatch` returned NO_MATCH.
-      (this could be because a callback requests the match be ignored, etc)
-
-      This causes no real harm other than stopping a few times too many.
-      */
-
-      modeBuffer += lexeme;
-      return lexeme.length;
-    }
-
-    const language = getLanguage(languageName);
-    if (!language) {
-      logger.error(LANGUAGE_NOT_FOUND.replace("{}", languageName));
-      throw new Error('Unknown language: "' + languageName + '"');
-    }
-
-    const md = compileLanguage(language);
-    let result = '';
-    /** @type {CompiledMode} */
-    let top = continuation || md;
-    /** @type Record<string,CompiledMode> */
-    const continuations = {}; // keep continuations for sub-languages
-    const emitter = new options.__emitter(options);
-    processContinuations();
-    let modeBuffer = '';
-    let relevance = 0;
-    let index = 0;
-    let iterations = 0;
-    let resumeScanAtSamePosition = false;
-
-    try {
-      if (!language.__emitTokens) {
-        top.matcher.considerAll();
-
-        for (;;) {
-          iterations++;
-          if (resumeScanAtSamePosition) {
-            // only regexes not matched previously will now be
-            // considered for a potential match
-            resumeScanAtSamePosition = false;
-          } else {
-            top.matcher.considerAll();
-          }
-          top.matcher.lastIndex = index;
-
-          const match = top.matcher.exec(codeToHighlight);
-          // console.log("match", match[0], match.rule && match.rule.begin)
-
-          if (!match) break;
-
-          const beforeMatch = codeToHighlight.substring(index, match.index);
-          const processedCount = processLexeme(beforeMatch, match);
-          index = match.index + processedCount;
-        }
-        processLexeme(codeToHighlight.substring(index));
-      } else {
-        language.__emitTokens(codeToHighlight, emitter);
-      }
-
-      emitter.finalize();
-      result = emitter.toHTML();
-
-      return {
-        language: languageName,
-        value: result,
-        relevance,
-        illegal: false,
-        _emitter: emitter,
-        _top: top
-      };
-    } catch (err) {
-      if (err.message && err.message.includes('Illegal')) {
-        return {
-          language: languageName,
-          value: escape(codeToHighlight),
-          illegal: true,
-          relevance: 0,
-          _illegalBy: {
-            message: err.message,
-            index,
-            context: codeToHighlight.slice(index - 100, index + 100),
-            mode: err.mode,
-            resultSoFar: result
-          },
-          _emitter: emitter
-        };
-      } else if (SAFE_MODE) {
-        return {
-          language: languageName,
-          value: escape(codeToHighlight),
-          illegal: false,
-          relevance: 0,
-          errorRaised: err,
-          _emitter: emitter,
-          _top: top
-        };
-      } else {
-        throw err;
-      }
-    }
-  }
-
-  /**
-   * returns a valid highlight result, without actually doing any actual work,
-   * auto highlight starts with this and it's possible for small snippets that
-   * auto-detection may not find a better match
-   * @param {string} code
-   * @returns {HighlightResult}
-   */
-  function justTextHighlightResult(code) {
-    const result = {
-      value: escape(code),
-      illegal: false,
-      relevance: 0,
-      _top: PLAINTEXT_LANGUAGE,
-      _emitter: new options.__emitter(options)
-    };
-    result._emitter.addText(code);
-    return result;
-  }
-
-  /**
-  Highlighting with language detection. Accepts a string with the code to
-  highlight. Returns an object with the following properties:
-
-  - language (detected language)
-  - relevance (int)
-  - value (an HTML string with highlighting markup)
-  - secondBest (object with the same structure for second-best heuristically
-    detected language, may be absent)
-
-    @param {string} code
-    @param {Array<string>} [languageSubset]
-    @returns {AutoHighlightResult}
-  */
-  function highlightAuto(code, languageSubset) {
-    languageSubset = languageSubset || options.languages || Object.keys(languages);
-    const plaintext = justTextHighlightResult(code);
-
-    const results = languageSubset.filter(getLanguage).filter(autoDetection).map(name =>
-      _highlight(name, code, false)
-    );
-    results.unshift(plaintext); // plaintext is always an option
-
-    const sorted = results.sort((a, b) => {
-      // sort base on relevance
-      if (a.relevance !== b.relevance) return b.relevance - a.relevance;
-
-      // always award the tie to the base language
-      // ie if C++ and Arduino are tied, it's more likely to be C++
-      if (a.language && b.language) {
-        if (getLanguage(a.language).supersetOf === b.language) {
-          return 1;
-        } else if (getLanguage(b.language).supersetOf === a.language) {
-          return -1;
-        }
-      }
-
-      // otherwise say they are equal, which has the effect of sorting on
-      // relevance while preserving the original ordering - which is how ties
-      // have historically been settled, ie the language that comes first always
-      // wins in the case of a tie
-      return 0;
-    });
-
-    const [best, secondBest] = sorted;
-
-    /** @type {AutoHighlightResult} */
-    const result = best;
-    result.secondBest = secondBest;
-
-    return result;
-  }
-
-  /**
-   * Builds new class name for block given the language name
-   *
-   * @param {HTMLElement} element
-   * @param {string} [currentLang]
-   * @param {string} [resultLang]
-   */
-  function updateClassName(element, currentLang, resultLang) {
-    const language = (currentLang && aliases[currentLang]) || resultLang;
-
-    element.classList.add("hljs");
-    element.classList.add(`language-${language}`);
-  }
-
-  /**
-   * Applies highlighting to a DOM node containing code.
-   *
-   * @param {HighlightedHTMLElement} element - the HTML element to highlight
-  */
-  function highlightElement(element) {
-    /** @type HTMLElement */
-    let node = null;
-    const language = blockLanguage(element);
-
-    if (shouldNotHighlight(language)) return;
-
-    fire("before:highlightElement",
-      { el: element, language });
-
-    if (element.dataset.highlighted) {
-      console.log("Element previously highlighted. To highlight again, first unset `dataset.highlighted`.", element);
-      return;
-    }
-
-    // we should be all text, no child nodes (unescaped HTML) - this is possibly
-    // an HTML injection attack - it's likely too late if this is already in
-    // production (the code has likely already done its damage by the time
-    // we're seeing it)... but we yell loudly about this so that hopefully it's
-    // more likely to be caught in development before making it to production
-    if (element.children.length > 0) {
-      if (!options.ignoreUnescapedHTML) {
-        console.warn("One of your code blocks includes unescaped HTML. This is a potentially serious security risk.");
-        console.warn("https://github.com/highlightjs/highlight.js/wiki/security");
-        console.warn("The element with unescaped HTML:");
-        console.warn(element);
-      }
-      if (options.throwUnescapedHTML) {
-        const err = new HTMLInjectionError(
-          "One of your code blocks includes unescaped HTML.",
-          element.innerHTML
-        );
-        throw err;
-      }
-    }
-
-    node = element;
-    const text = node.textContent;
-    const result = language ? highlight(text, { language, ignoreIllegals: true }) : highlightAuto(text);
-
-    element.innerHTML = result.value;
-    element.dataset.highlighted = "yes";
-    updateClassName(element, language, result.language);
-    element.result = {
-      language: result.language,
-      // TODO: remove with version 11.0
-      re: result.relevance,
-      relevance: result.relevance
-    };
-    if (result.secondBest) {
-      element.secondBest = {
-        language: result.secondBest.language,
-        relevance: result.secondBest.relevance
-      };
-    }
-
-    fire("after:highlightElement", { el: element, result, text });
-  }
-
-  /**
-   * Updates highlight.js global options with the passed options
-   *
-   * @param {Partial<HLJSOptions>} userOptions
-   */
-  function configure(userOptions) {
-    options = inherit(options, userOptions);
-  }
-
-  // TODO: remove v12, deprecated
-  const initHighlighting = () => {
-    highlightAll();
-    logger.deprecated("10.6.0", "initHighlighting() deprecated.  Use highlightAll() now.");
-  };
-
-  // TODO: remove v12, deprecated
-  function initHighlightingOnLoad() {
-    highlightAll();
-    logger.deprecated("10.6.0", "initHighlightingOnLoad() deprecated.  Use highlightAll() now.");
-  }
-
-  let wantsHighlight = false;
-
-  /**
-   * auto-highlights all pre>code elements on the page
-   */
-  function highlightAll() {
-    // if we are called too early in the loading process
-    if (document.readyState === "loading") {
-      wantsHighlight = true;
-      return;
-    }
-
-    const blocks = document.querySelectorAll(options.cssSelector);
-    blocks.forEach(highlightElement);
-  }
-
-  function boot() {
-    // if a highlight was requested before DOM was loaded, do now
-    if (wantsHighlight) highlightAll();
-  }
-
-  // make sure we are in the browser environment
-  if (typeof window !== 'undefined' && window.addEventListener) {
-    window.addEventListener('DOMContentLoaded', boot, false);
-  }
-
-  /**
-   * Register a language grammar module
-   *
-   * @param {string} languageName
-   * @param {LanguageFn} languageDefinition
-   */
-  function registerLanguage(languageName, languageDefinition) {
-    let lang = null;
-    try {
-      lang = languageDefinition(hljs);
-    } catch (error) {
-      logger.error("Language definition for '{}' could not be registered.".replace("{}", languageName));
-      // hard or soft error
-      if (!SAFE_MODE) { throw error; } else { logger.error(error); }
-      // languages that have serious errors are replaced with essentially a
-      // "plaintext" stand-in so that the code blocks will still get normal
-      // css classes applied to them - and one bad language won't break the
-      // entire highlighter
-      lang = PLAINTEXT_LANGUAGE;
-    }
-    // give it a temporary name if it doesn't have one in the meta-data
-    if (!lang.name) lang.name = languageName;
-    languages[languageName] = lang;
-    lang.rawDefinition = languageDefinition.bind(null, hljs);
-
-    if (lang.aliases) {
-      registerAliases(lang.aliases, { languageName });
-    }
-  }
-
-  /**
-   * Remove a language grammar module
-   *
-   * @param {string} languageName
-   */
-  function unregisterLanguage(languageName) {
-    delete languages[languageName];
-    for (const alias of Object.keys(aliases)) {
-      if (aliases[alias] === languageName) {
-        delete aliases[alias];
-      }
-    }
-  }
-
-  /**
-   * @returns {string[]} List of language internal names
-   */
-  function listLanguages() {
-    return Object.keys(languages);
-  }
-
-  /**
-   * @param {string} name - name of the language to retrieve
-   * @returns {Language | undefined}
-   */
-  function getLanguage(name) {
-    name = (name || '').toLowerCase();
-    return languages[name] || languages[aliases[name]];
-  }
-
-  /**
-   *
-   * @param {string|string[]} aliasList - single alias or list of aliases
-   * @param {{languageName: string}} opts
-   */
-  function registerAliases(aliasList, { languageName }) {
-    if (typeof aliasList === 'string') {
-      aliasList = [aliasList];
-    }
-    aliasList.forEach(alias => { aliases[alias.toLowerCase()] = languageName; });
-  }
-
-  /**
-   * Determines if a given language has auto-detection enabled
-   * @param {string} name - name of the language
-   */
-  function autoDetection(name) {
-    const lang = getLanguage(name);
-    return lang && !lang.disableAutodetect;
-  }
-
-  /**
-   * Upgrades the old highlightBlock plugins to the new
-   * highlightElement API
-   * @param {HLJSPlugin} plugin
-   */
-  function upgradePluginAPI(plugin) {
-    // TODO: remove with v12
-    if (plugin["before:highlightBlock"] && !plugin["before:highlightElement"]) {
-      plugin["before:highlightElement"] = (data) => {
-        plugin["before:highlightBlock"](
-          Object.assign({ block: data.el }, data)
-        );
-      };
-    }
-    if (plugin["after:highlightBlock"] && !plugin["after:highlightElement"]) {
-      plugin["after:highlightElement"] = (data) => {
-        plugin["after:highlightBlock"](
-          Object.assign({ block: data.el }, data)
-        );
-      };
-    }
-  }
-
-  /**
-   * @param {HLJSPlugin} plugin
-   */
-  function addPlugin(plugin) {
-    upgradePluginAPI(plugin);
-    plugins.push(plugin);
-  }
-
-  /**
-   * @param {HLJSPlugin} plugin
-   */
-  function removePlugin(plugin) {
-    const index = plugins.indexOf(plugin);
-    if (index !== -1) {
-      plugins.splice(index, 1);
-    }
-  }
-
-  /**
-   *
-   * @param {PluginEvent} event
-   * @param {any} args
-   */
-  function fire(event, args) {
-    const cb = event;
-    plugins.forEach(function(plugin) {
-      if (plugin[cb]) {
-        plugin[cb](args);
-      }
-    });
-  }
-
-  /**
-   * DEPRECATED
-   * @param {HighlightedHTMLElement} el
-   */
-  function deprecateHighlightBlock(el) {
-    logger.deprecated("10.7.0", "highlightBlock will be removed entirely in v12.0");
-    logger.deprecated("10.7.0", "Please use highlightElement now.");
-
-    return highlightElement(el);
-  }
-
-  /* Interface definition */
-  Object.assign(hljs, {
-    highlight,
-    highlightAuto,
-    highlightAll,
-    highlightElement,
-    // TODO: Remove with v12 API
-    highlightBlock: deprecateHighlightBlock,
-    configure,
-    initHighlighting,
-    initHighlightingOnLoad,
-    registerLanguage,
-    unregisterLanguage,
-    listLanguages,
-    getLanguage,
-    registerAliases,
-    autoDetection,
-    inherit,
-    addPlugin,
-    removePlugin
-  });
-
-  hljs.debugMode = function() { SAFE_MODE = false; };
-  hljs.safeMode = function() { SAFE_MODE = true; };
-  hljs.versionString = packageJSON.version;
-
-  hljs.regex = {
-    concat: regex.concat,
-    lookahead: regex.lookahead,
-    either: regex.either,
-    optional: regex.optional,
-    anyNumberOfTimes: regex.anyNumberOfTimes
-  };
-
-  for (const key in MODES) {
-    // @ts-ignore
-    if (typeof MODES[key] === "object") {
-      // @ts-ignore
-      deepFreeze(MODES[key]);
-    }
-  }
-
-  // merge all the modes/regexes into our main object
-  Object.assign(hljs, MODES);
-
-  return hljs;
-};
-
-// Other names for the variable may break build script
-const highlight = HLJS({});
-
-// returns a new instance of the highlighter to be used for extensions
-// check https://github.com/wooorm/lowlight/issues/47
-highlight.newInstance = () => HLJS({});
-
-// export an "instance" of the highlighter
-export default highlight;
diff --git a/src/imports/istina-editor.css b/src/imports/istina-editor.css
deleted file mode 100644 (file)
index 1b27f37..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-
-.istina-basis
-{
-       font-size: 14px;
-       position: absolute;
-       font-family: monospace;
-       color: rgba(255, 255, 255, 0.5);
-       font-weight: bold;
-       width: 100%;
-       background-color: rgba(0, 0, 0, 0);
-       overflow-y: auto;
-       outline: none;
-       white-space: nowrap;
-}
-.istina-overlay
-{
-       font-size: 14px;
-       pointer-events: none;
-       font-family: monospace;
-       width: 100%;
-       background-color: #1f1f1f;
-       color: #9cdcfe;
-       font-weight: bold;
-       overflow-y: auto;
-       outline: none;
-       white-space: nowrap;
-}
-.istina-linecounter
-{
-       font-size: 14px;
-       width: 100%;
-       text-align: center;
-       font-weight: bold;
-       font-family: monospace;
-       background-color: #1f1f1f;
-       color: #6e7681;
-       overflow-y: auto;
-       &::-webkit-scrollbar { display: none; }
-       -ms-overflow-style: none;
-       scrollbar-width: none;
-}
-
-.istina-bracket { color: #da70d6; }
-.istina-number { color: #b5cea8; }
-.istina-comment { color: #6a9955; }
-.istina-keyword { color: #dcdcaa; }
-.istina-semicolon { color: #ffffff; }
\ No newline at end of file
diff --git a/src/imports/istina-editor.js b/src/imports/istina-editor.js
deleted file mode 100644 (file)
index b1f8d67..0000000
+++ /dev/null
@@ -1,490 +0,0 @@
-
-window.$ = x => document.querySelectorAll(x);
-var IstinaEditor = {};
-IstinaEditor.escapables =
-[
-       [ "&amp;", "&" ],
-       [ "&nbsp;", " " ],
-       [ "&gt;", ">" ],
-       [ "&lt;", "<" ],
-];
-
-IstinaEditor.htmlToText = function(x, y)
-{
-       var str;
-       if (y == undefined)
-       {
-               var div = document.createElement("div");
-               div.innerHTML = x;
-               str = IstinaEditor.htmlToText(x, div);
-               if (str.length > 0)
-               {
-                       str = str.substring(0, str.length - 1);
-               }
-               return str;
-       }
-       
-       if (y.nodeType == Node.TEXT_NODE)
-       {
-               return y.textContent + "\n";
-       }
-
-       str = "";
-       if (y.tagName == "BR")
-       {
-               var prev = y.previousSibling;
-               var next = y.nextSibling;
-               window.brb = y;
-               
-               str = "\n";
-               /*if (prev == null && next == null)
-               {
-                       str = "\n";
-               }
-               else if (prev != null && prev.nodeType != Node.TEXT_NODE)
-               {
-                       str = "\n";
-               }
-               else if (next != null && next.nodeType != Node.TEXT_NODE)
-               {
-                       str = "\n";
-               }*/
-               if (next != null && next.tagName == "DIV")
-               {
-                       str = "";
-                       if (prev == null)
-                       {
-                               str = "\n";
-                       }
-               }
-       }
-       
-       for (var i = 0; i < y.childNodes.length; i++)
-       {
-               str += IstinaEditor.htmlToText(x, y.childNodes[i]);
-       }
-       return str;
-}
-IstinaEditor.removeEmptyNodes = function(v)
-{
-       if (window.pauseCleaning) return;
-       if (v == undefined)
-       {
-               IstinaEditor.removeEmptyNodes($(".istina-basis")[0]);
-               return;
-       }
-       /*
-       if (v.tagName == "SPAN" && v.childNodes.length > 0)
-       {
-               v.parentNode.insertBefore(v.childNodes[0], v);
-               v.remove();
-               return;
-       }
-       */;
-       if (v.tagName != "DIV")
-       {
-               return;
-       }
-       if (v.className != "istina-basis")
-       {
-               if (v.innerHTML.length == 0)
-               {
-                       v.remove();
-                       return;
-               }
-       }
-       for (var i = 0; i < v.childNodes.length; i++)
-       {
-               IstinaEditor.removeEmptyNodes(v.childNodes[i]);
-       }
-}
-
-IstinaEditor.getText = function(x, y, z)
-{
-       if (x == undefined || y == undefined)
-       {
-               z = [];
-               IstinaEditor.getText([], $(".istina-basis")[0], z);
-               if (z.length == 0) return "";
-               z.sort((a, b) => a[0] - b[0]);
-               while (z.length > 0 && z[0][0] == 0)
-               {
-                       z.splice(0, 1);
-               }
-               if (z.length == 0) return "";
-               var str = "";
-               var prevline = z[0][0];
-               for (var i = 0; i < z.length; i++)
-               {
-                       if (Math.abs(prevline - z[i][0]) > 5)
-                       {
-                               str += "\n";
-                       }
-                       str += z[i][1];
-                       prevline = z[i][0];
-               }
-               return str.replaceAll(String.fromCharCode(160), " ");
-       }
-       
-       if (y.nodeType == Node.TEXT_NODE)
-       {
-               var r = document.createRange();
-               r.selectNodeContents(y);
-               var n = parseFloat(r.getBoundingClientRect().y.toString());
-               n += parseFloat($(".istina-basis")[0].scrollTop.toString());
-               z[z.length] = [ r.getBoundingClientRect().y + $(".istina-basis")[0].scrollTop, y.textContent ];
-               return;
-       }
-       else if (y.className != "istina-basis")
-       {
-               var n = parseFloat(y.getBoundingClientRect().y.toString());
-               n += parseFloat($(".istina-basis")[0].scrollTop.toString());
-               z[z.length] = [ y.getBoundingClientRect().y + $(".istina-basis")[0].scrollTop, "" ];
-       }
-
-       for (var i = 0; i < y.childNodes.length; i++)
-       {
-               IstinaEditor.getText(x, y.childNodes[i], z);
-       }
-}
-
-IstinaEditor.textToNodes = function(txt)
-{
-       IstinaEditor.escapables.forEach(x => { txt = txt.replaceAll(x[1], x[0]); });
-       var out = [];
-       txt = txt.replaceAll("\r", "").replaceAll(" ", "&nbsp;").split("\n");
-       for (var i = 0; i < txt.length; i++)
-       {
-               var tmp = txt[i].trim();
-               if (i == 0)
-               {
-                       if (tmp.length > 0)
-                       {
-                               IstinaEditor.escapables.forEach(x => tmp = tmp.replaceAll(x[0], x[1]));
-                               out[out.length] = document.createTextNode(tmp);
-                       }
-               }
-               else
-               {
-                       out[out.length] = document.createElement("div");
-                       if (tmp.length == 0)
-                       {
-                               out[out.length - 1].innerHTML = "<br>";
-                       }
-                       else
-                       {
-                               out[out.length - 1].innerHTML = tmp;
-                       }
-               }
-       }
-       return out;
-}
-
-IstinaEditor.setText = function(txt)
-{
-       IstinaEditor.escapables.forEach(x => { txt = txt.replaceAll(x[1], x[0]); });
-       var out = "";
-       txt = txt.trim().replaceAll("\r", "").split("\n");
-       for (var i = 0; i < txt.length; i++)
-       {
-               var tmp = txt[i].trim();
-               if (tmp.length == 0)
-               {
-                       out += "<div><br></div>";
-               }
-               else
-               {
-                       out += "<div>" + tmp + "</div>";
-               }
-       }
-       out = out.replaceAll(" ", "&nbsp;");
-       $(".istina-basis")[0].innerHTML = out;
-}
-
-IstinaEditor.highlightForQAnsel = function(txt)
-{
-       var lhs = "!!!" + Math.random().toString().replace(".", "0") + "!!!";
-       var rhs = "!!!" + Math.random().toString().replace(".", "1") + "!!!";
-       txt = txt.replaceAll(/[&].*?[;]/g, x => lhs + x.replace("&", "").replace(";", "") + rhs);
-       txt = txt.replaceAll(/[;]/g, "<span class='istina-semicolon'>;</span>");
-       txt = txt.replaceAll(new RegExp(lhs + ".*?" + rhs, "g"), x => "&" + x.replace(lhs, "").replace(rhs, "") + ";");
-
-       txt = txt.replaceAll
-       (
-               /[\[][0-9][0-9]*[\]]/g,
-               x =>
-               {
-                       x = x.replace("[", "<span class='istina-bracket'>[</span><span class='istina-number'>");
-                       x = x.replace("]", "</span><span class='istina-bracket'>]</span>");
-                       return x;
-               }
-       );
-       //u(#,#,#); rx(#); ry(#); rz(#); if(c==#); if(c[#]==%i)
-       var keywords =
-       [
-               "qreg",
-               "creg",
-               "density",
-               "h",
-               "x",
-               "y",
-               "z",
-               "t",
-               "s",
-               "tdg",
-               "sdg",
-               "cx",
-               "swap",
-               "cswap",
-               "fredkin",
-               "ccx",
-               "toffoli",
-               "measure",
-               "print",
-               "sample",
-               "set",
-               "reset",
-               "barrier",
-               "hvar",
-               "noise",
-               "shots",
-               "rand",
-               "born"
-       ];
-               
-       for (var i = 0; i < keywords.length; i++)
-       {
-               if (keywords[i] == "hvar" || keywords[i] == "noise" || keywords[i] == "shots") continue;
-               var tmp = new RegExp("(^|[ ]|[;]|[>])" + keywords[i] + "($|[ ]|[<]|[&])", "g");
-               txt = txt.replaceAll(tmp, x =>
-               {
-                       var c = x.charAt(0);
-                       var tagonL = "";
-                       if (c == " " || c == ";" || c == ">")
-                       {
-                               tagonL = c;
-                               x = x.substring(1, x.length);
-                       }
-                       var tagonR = "";
-                       c = x.charAt(x.length - 1);
-                       if (c == " " || c == "<" || c == "&")
-                       {
-                               tagonR = c;
-                               x = x.substring(0, x.length - 1);
-                       }               
-                       return tagonL + "<span class='istina-keyword'>" + x + "</span>" + tagonR;
-               });
-       }
-       txt = txt.replaceAll
-       (
-               /(rx|ry|rz)[(].*?[)]/g,
-               x =>
-               {
-                       var lhs = x.split("(")[0];
-                       var rhs = x.split("(")[1].split(")")[0];
-                       x = "<span class='istina-keyword'>" + lhs + "</span>";
-                       x += "<span class='istina-bracket'>(</span>";
-                       x += "<span class='istina-number'>" + rhs + "</span>";
-                       x += "<span class='istina-bracket'>)</span>";
-                       return x;
-               }
-       );
-       txt = txt.replaceAll
-       (
-               /(noise|hvar|shots)( |&nbsp;)[.\-0-9][.\-0-9]*/g,
-               x =>
-               {
-                       x = x.replace(" ", "&nbsp;");
-                       var lhs = x.split("&nbsp;")[0].trim();
-                       var rhs = x.split("&nbsp;")[1].trim();
-                       x = "<span class='istina-keyword'>" + lhs + "</span>";
-                       x += " ";
-                       x += "<span class='istina-number'>" + rhs + "</span>";
-                       return x;
-               }
-       );
-       txt = txt.replaceAll
-       (
-               /if[(].*?[)]/g,
-               x =>
-               {
-                       var rhs = x.split("(")[1].split(")")[0];
-                       x = "<span class='istina-keyword'>if</span>";
-                       x += "<span class='istina-bracket'>(</span>";
-                       x += rhs;
-                       x += "<span class='istina-bracket'>)</span>";
-                       x = x.replace("==0", "==<span class='istina-number'>0</span>");
-                       x = x.replace("==1", "==<span class='istina-number'>1</span>");
-                       return x;
-               }
-       );
-       txt = txt.replaceAll
-       (
-               /[/][/].*?([<]div|[<]br|$)/g,
-               x =>
-               {
-                       var tagon = "";
-                       var tagons = [ "<div", "<br" ];
-                       for (var i = 0; i < tagons.length; i++)
-                       {
-                               if (x.substring(x.length - tagons[i].length, x.length) == tagons[i])
-                               {
-                                       x = x.substring(0, x.length - tagons[i].length);
-                                       tagon = tagons[i];
-                                       break;
-                               }
-                       }
-                       x = x.replaceAll(/[<]span[ ]class[=]['].*?['][>]/g, "<span>");
-                       x = "<span class='istina-comment'>" + x + "</span>" + tagon;
-                       return x;
-               }
-       );
-       return txt;
-}
-
-IstinaEditor.init = function()
-{
-       document.querySelector("istina-editor").innerHTML = `
-               <table border="0" style="width: 100%; height: 100%;">
-                       <tr>
-                               <td style="width: 3%;"><div class="istina-linecounter">1</div></td>
-                               <td style="width: 96%; text-align: top;">
-                                       <div class="istina-basis" contenteditable spellcheck="false" autocorrect="off" autocapitalization="off"></div>
-                                       <div class="istina-overlay"></div>
-                               </td>
-                       </tr>
-                       <!-- <div>qreg q[2];</div><div>h q[0];</div><div>cx q[0], q[1];</div><div>sample;</div> -->
-               </table>
-       `;
-
-       $(".istina-basis")[0].addEventListener("paste", (e) =>
-       {
-               window.pauseCleaning = true;
-               e.preventDefault();
-               var text = (event.clipboardData || window.clipboardData).getData('text');
-               //text = IstinaEditor.htmlToText(text);
-               var sel = window.getSelection();
-               if (sel.rangeCount > 0)
-               {
-                       var range = sel.getRangeAt(0);
-                       range.deleteContents();
-                       if (!text.includes("\n"))
-                       {
-                               var textNode = document.createTextNode(text);
-                               range.insertNode(textNode);
-                               range.setStartAfter(textNode);
-                               range.setEndAfter(textNode);
-                               sel.removeAllRanges();
-                               sel.addRange(range);
-                       }
-                       else
-                       {
-                               var last;
-                               IstinaEditor.textToNodes(text).forEach(x =>
-                               {
-                                       range.insertNode(x);
-                                       range.setStartAfter(x);
-                                       range.setEndAfter(x);
-                               });
-                               sel.removeAllRanges();
-                               sel.addRange(range);
-                       }
-               }
-               window.pauseCleaning = undefined;
-       });
-       
-       setInterval(() =>
-       {
-               if (window.stopMainLoop) return;
-               try
-               {
-                       IstinaEditor.removeEmptyNodes();
-                       $(".istina-overlay")[0].scrollTop = $(".istina-basis")[0].scrollTop;
-                       $(".istina-overlay")[0].scrollLeft = $(".istina-basis")[0].scrollLeft;
-                       $(".istina-linecounter")[0].scrollTop = $(".istina-basis")[0].scrollTop;
-                       $(".istina-linecounter")[0].scrollTop = $(".istina-basis")[0].scrollTop;
-                       var txt = $(".istina-basis")[0].innerHTML;
-                       if (txt == window.oldHTML) return;
-                       localStorage.setItem("previous_text", IstinaEditor.getText());
-                       
-                       //<fix for a mobile bug>
-                       /*
-                       var pos = 0;
-                       var found = false;
-                       for (; pos < txt.length; pos++)
-                       {
-                               if (txt.substring(pos, pos + "<div>".length) == "<div>")
-                               {
-                                       found = true;
-                                       break;
-                               }
-                       }
-                       if (pos != 0 && found)
-                       {
-                               var lhs = txt.substring(0, pos);
-                               var rhs = txt.substring(pos, txt.length);
-                               txt = "<div>" + lhs + "</div>" + rhs;
-                               $(".istina-basis")[0].innerHTML = txt;
-                       }
-                       if (txt.includes("</div><br><div>"))
-                       {
-                               txt = txt.replaceAll("</div><br><div>", "");
-                               $(".istina-basis")[0].innerHTML = txt;
-                       
-                       }*/
-                       //</fix for a mobile bug>
-                       
-                       if (txt.includes("qreg") || txt.includes("creg"))
-                       {
-                               txt = IstinaEditor.highlightForQAnsel(txt);
-                       }
-                       
-                       $(".istina-overlay")[0].innerHTML = txt;
-                       window.oldHTML = $(".istina-basis")[0].innerHTML;
-                       txt = $(".istina-basis")[0].innerHTML;
-                       var linecount = IstinaEditor.getText().split("\n").length;
-                       txt = "";
-                       for (var i = 0; i < linecount; i++)
-                       {
-                               txt += "<div>" + (i + 1) + "</div>";
-                       }
-                       $(".istina-linecounter")[0].innerHTML = txt;
-               }
-               catch (x)
-               {
-                       alert("ERR(3): " + x);
-                       window.stopMainLoop = true;
-               }
-       }, 10); 
-
-       window.addEventListener("DOMContentLoaded", () =>
-       {
-               setTimeout(function()
-               {
-                       try
-                       {
-                               var tmph = Math.round($("istina-editor")[0].parentNode.getBoundingClientRect().height) + "px";
-                               var tmpw = Math.round($(".istina-overlay")[0].getBoundingClientRect().width) + "px";
-                               $(".istina-overlay")[0].style.width = tmpw;
-                               $(".istina-basis")[0].style.width = tmpw;
-                               $(".istina-basis,.istina-overlay,.istina-linecounter").forEach(x =>
-                               {
-                                       x.style.height = tmph;
-                               });
-                               
-                               var prevText = localStorage.getItem("previous_text");
-                               if (prevText)
-                               {
-                                       if (typeof(prevText) == "string")
-                                       {
-                                               IstinaEditor.setText(prevText);
-                                       }
-                               }
-                       }
-                       catch (x)
-                       {
-                               alert("ERR(4): " + x);
-                       }
-               }, 100);
-       });
-}
\ No newline at end of file
diff --git a/src/imports/jasmal.js b/src/imports/jasmal.js
deleted file mode 100644 (file)
index 30ed964..0000000
+++ /dev/null
@@ -1,12534 +0,0 @@
-var __extends = (this && this.__extends) || (function () {\r
-    var extendStatics = Object.setPrototypeOf ||\r
-        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r
-        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r
-    return function (d, b) {\r
-        extendStatics(d, b);\r
-        function __() { this.constructor = d; }\r
-        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r
-    };\r
-})();\r
-System.register("jasmal/lib/constant", [], function (exports_1, context_1) {\r
-    "use strict";\r
-    var __moduleName = context_1 && context_1.id;\r
-    var MAX_SAFE_INTEGER, MIN_SAFE_INTEGER, EPSILON, M_PI_2, NOT_IMPLEMENTED;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            exports_1("MAX_SAFE_INTEGER", MAX_SAFE_INTEGER = 9007199254740991);\r
-            exports_1("MIN_SAFE_INTEGER", MIN_SAFE_INTEGER = -9007199254740991);\r
-            exports_1("EPSILON", EPSILON = 7 / 3 - 4 / 3 - 1);\r
-            exports_1("M_PI_2", M_PI_2 = Math.PI / 2);\r
-            exports_1("NOT_IMPLEMENTED", NOT_IMPLEMENTED = function () {\r
-                throw new Error('Not implemented.');\r
-            });\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/math/cmath", ["jasmal/lib/constant"], function (exports_2, context_2) {\r
-    "use strict";\r
-    var __moduleName = context_2 && context_2.id;\r
-    var constant_1, CMath;\r
-    return {\r
-        setters: [\r
-            function (constant_1_1) {\r
-                constant_1 = constant_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            CMath = (function () {\r
-                function CMath() {\r
-                }\r
-                CMath.length2 = function (x, y) {\r
-                    var absX = Math.abs(x), absY = Math.abs(y);\r
-                    if (absX > absY) {\r
-                        var ratio = absY / absX;\r
-                        return absX * Math.sqrt(1.0 + ratio * ratio);\r
-                    }\r
-                    else {\r
-                        if (absY === 0) {\r
-                            return absX;\r
-                        }\r
-                        else {\r
-                            var ratio = absX / absY;\r
-                            return absY * Math.sqrt(1.0 + ratio * ratio);\r
-                        }\r
-                    }\r
-                };\r
-                CMath.cdivCC = function (reX, imX, reY, imY) {\r
-                    var s = Math.abs(reY) + Math.abs(imY);\r
-                    if (s === 0.0) {\r
-                        if (reX === 0) {\r
-                            if (imX === 0) {\r
-                                return [NaN, NaN];\r
-                            }\r
-                            else {\r
-                                return [0, imX / 0];\r
-                            }\r
-                        }\r
-                        else {\r
-                            return [reX / 0, imX === 0 ? 0 : imX / 0];\r
-                        }\r
-                    }\r
-                    else {\r
-                        var reXs = reX / s;\r
-                        var imXs = imX / s;\r
-                        var reYs = reY / s;\r
-                        var imYs = imY / s;\r
-                        s = reYs * reYs + imYs * imYs;\r
-                        return [(reXs * reYs + imXs * imYs) / s, (imXs * reYs - reXs * imYs) / s];\r
-                    }\r
-                };\r
-                CMath.cdivRC = function (reX, reY, imY) {\r
-                    var r, t;\r
-                    if (Math.abs(reY) > Math.abs(imY)) {\r
-                        r = imY / reY;\r
-                        t = reY + imY * r;\r
-                        return [reX / t, -r / t * reX];\r
-                    }\r
-                    else {\r
-                        if (imY === 0) {\r
-                            return [Infinity, 0];\r
-                        }\r
-                        else {\r
-                            r = reY / imY;\r
-                            t = reY * r + imY;\r
-                            return [r / t * reX, -reX / t];\r
-                        }\r
-                    }\r
-                };\r
-                CMath.cReciprocal = function (reX, imX) {\r
-                    var absReX = Math.abs(reX);\r
-                    var absImX = Math.abs(imX);\r
-                    var r, d;\r
-                    if (absImX < absReX) {\r
-                        r = imX / reX;\r
-                        d = reX + imX * r;\r
-                        return [1 / d, -r / d];\r
-                    }\r
-                    else {\r
-                        if (absImX === 0) {\r
-                            return [Infinity, 0];\r
-                        }\r
-                        r = reX / imX;\r
-                        d = imX + reX * r;\r
-                        return [r / d, -1 / d];\r
-                    }\r
-                };\r
-                CMath.csqrt = function (reX, imX) {\r
-                    if (isNaN(reX) || isNaN(imX)) {\r
-                        return [NaN, NaN];\r
-                    }\r
-                    if (!isFinite(imX)) {\r
-                        return [Infinity, imX > 0 ? Infinity : -Infinity];\r
-                    }\r
-                    else if (!isFinite(reX)) {\r
-                        return reX > 0 ? [Infinity, 0] : [0, imX >= 0 ? Infinity : -Infinity];\r
-                    }\r
-                    var reY = 0, imY = 0;\r
-                    var absReX = Math.abs(reX), absImX = Math.abs(imX);\r
-                    var l = 0, ratio;\r
-                    if (absReX > absImX) {\r
-                        ratio = absImX / absReX;\r
-                        l = absReX * Math.sqrt(1.0 + ratio * ratio);\r
-                    }\r
-                    else {\r
-                        if (absImX !== 0) {\r
-                            ratio = absReX / absImX;\r
-                            l = absImX * Math.sqrt(1.0 + ratio * ratio);\r
-                        }\r
-                    }\r
-                    var s = Math.sqrt(0.5 * (l + Math.abs(reX)));\r
-                    if (reX >= 0)\r
-                        reY = s;\r
-                    if (imX < 0)\r
-                        s = -s;\r
-                    if (reX <= 0)\r
-                        imY = s;\r
-                    if (reX < 0)\r
-                        reY = 0.5 * (imX / imY);\r
-                    if (reX > 0)\r
-                        imY = 0.5 * (imX / reY);\r
-                    return [reY, imY];\r
-                };\r
-                CMath.csin = function (re, im) {\r
-                    var s = Math.sin(re), c = Math.cos(re);\r
-                    var ep = Math.exp(im), en = Math.exp(-im);\r
-                    return [0.5 * (ep + en) * s, 0.5 * (ep - en) * c];\r
-                };\r
-                CMath.ccos = function (re, im) {\r
-                    var s = Math.sin(re), c = Math.cos(re);\r
-                    var ep = Math.exp(im), en = Math.exp(-im);\r
-                    return [0.5 * (ep + en) * c, -0.5 * (ep - en) * s];\r
-                };\r
-                CMath.ctan = function (re, im) {\r
-                    var re2 = re + re;\r
-                    var im2 = im + im;\r
-                    var ep = Math.exp(im2), en = Math.exp(-im2);\r
-                    var d = 0.5 * (ep + en) + Math.cos(re2);\r
-                    return [Math.sin(re2) / d, 0.5 * (ep - en) / d];\r
-                };\r
-                CMath.ccot = function (re, im) {\r
-                    var re2 = re + re;\r
-                    var im2 = im + im;\r
-                    var ep = Math.exp(im2), en = Math.exp(-im2);\r
-                    var d = 0.5 * (ep + en) - Math.cos(re2);\r
-                    return [Math.sin(re2) / d, -0.5 * (ep - en) / d];\r
-                };\r
-                CMath.casin = function (reX, imX) {\r
-                    var tRe1, tIm1, tRe2, tIm2, r, s;\r
-                    if (imX === 0) {\r
-                        if (reX > 1 || reX < -1) {\r
-                            r = 1 / reX;\r
-                            s = Math.abs(reX + Math.abs(reX) * Math.sqrt(1 - r * r));\r
-                            return [reX > 0 ? constant_1.M_PI_2 : -constant_1.M_PI_2, -Math.log(s)];\r
-                        }\r
-                        else {\r
-                            return [Math.asin(reX), 0];\r
-                        }\r
-                    }\r
-                    else {\r
-                        _a = CMath.csqrt(1 - reX, -imX), tRe1 = _a[0], tIm1 = _a[1];\r
-                        _b = CMath.csqrt(1 + reX, imX), tRe2 = _b[0], tIm2 = _b[1];\r
-                        r = tRe1;\r
-                        tRe1 = r * tRe2 - tIm1 * tIm2;\r
-                        tIm1 = r * tIm2 + tIm1 * tRe2;\r
-                        tRe1 -= imX;\r
-                        tIm1 += reX;\r
-                        _c = CMath.clog(tRe1, tIm1), tRe1 = _c[0], tIm1 = _c[1];\r
-                        return [tIm1, -tRe1];\r
-                    }\r
-                    var _a, _b, _c;\r
-                };\r
-                CMath.cacos = function (re, im) {\r
-                    var _a = CMath.casin(re, im), tRe = _a[0], tIm = _a[1];\r
-                    return [constant_1.M_PI_2 - tRe, -tIm];\r
-                };\r
-                CMath.catan = function (re, im) {\r
-                    var _a = CMath.clog(1 + im, -re), tRe1 = _a[0], tIm1 = _a[1];\r
-                    var _b = CMath.clog(1 - im, re), tRe2 = _b[0], tIm2 = _b[1];\r
-                    return [-0.5 * (tIm1 - tIm2), 0.5 * (tRe1 - tRe2)];\r
-                };\r
-                CMath.cacot = function (re, im) {\r
-                    var _a = CMath.cdivRC(1, re, im), invRe = _a[0], invIm = _a[1];\r
-                    var _b = CMath.clog(1 + invIm, -invRe), tRe1 = _b[0], tIm1 = _b[1];\r
-                    var _c = CMath.clog(1 - invIm, invRe), tRe2 = _c[0], tIm2 = _c[1];\r
-                    return [-0.5 * (tIm1 - tIm2), 0.5 * (tRe1 - tRe2)];\r
-                };\r
-                CMath.csinh = function (re, im) {\r
-                    var s = Math.sin(im), c = Math.cos(im);\r
-                    var ep = Math.exp(re), en = Math.exp(-re);\r
-                    return [0.5 * (ep - en) * c, 0.5 * (ep + en) * s];\r
-                };\r
-                CMath.ccosh = function (re, im) {\r
-                    var s = Math.sin(im), c = Math.cos(im);\r
-                    var ep = Math.exp(re), en = Math.exp(-re);\r
-                    return [0.5 * (ep + en) * c, 0.5 * (ep - en) * s];\r
-                };\r
-                CMath.ctanh = function (re, im) {\r
-                    var re2 = re + re;\r
-                    var im2 = im + im;\r
-                    var ep = Math.exp(re2), en = Math.exp(-re2);\r
-                    var d = 0.5 * (ep + en) + Math.cos(im2);\r
-                    return [0.5 * (ep - en) / d, Math.sin(im2) / d];\r
-                };\r
-                CMath.ccoth = function (re, im) {\r
-                    var re2 = re + re;\r
-                    var im2 = im + im;\r
-                    var ep = Math.exp(re2), en = Math.exp(-re2);\r
-                    var d = 0.5 * (ep + en) - Math.cos(im2);\r
-                    return [0.5 * (ep - en) / d, -Math.sin(im2) / d];\r
-                };\r
-                CMath.casinh = function (re, im) {\r
-                    var _a = CMath.csqrt(re * re - im * im + 1, 2 * re * im), tRe = _a[0], tIm = _a[1];\r
-                    return CMath.clog(tRe + re, tIm + im);\r
-                };\r
-                CMath.cacosh = function (re, im) {\r
-                    var _a = CMath.csqrt(re + 1, im), tRe1 = _a[0], tIm1 = _a[1];\r
-                    var _b = CMath.csqrt(re - 1, im), tRe2 = _b[0], tIm2 = _b[1];\r
-                    var tmp = tRe1;\r
-                    tRe1 = tmp * tRe2 - tIm1 * tIm2;\r
-                    tIm1 = tmp * tIm2 + tIm1 * tRe2;\r
-                    return CMath.clog(tRe1 + re, tIm1 + im);\r
-                };\r
-                CMath.catanh = function (re, im) {\r
-                    var _a = CMath.clog(1 + re, im), tRe1 = _a[0], tIm1 = _a[1];\r
-                    var _b = CMath.clog(1 - re, -im), tRe2 = _b[0], tIm2 = _b[1];\r
-                    return [0.5 * (tRe1 - tRe2), 0.5 * (tIm1 - tIm2)];\r
-                };\r
-                CMath.cacoth = function (re, im) {\r
-                    var _a = CMath.cdivRC(1, re, im), invRe = _a[0], invIm = _a[1];\r
-                    var _b = CMath.clog(1 + invRe, invIm), tRe1 = _b[0], tIm1 = _b[1];\r
-                    var _c = CMath.clog(1 - invRe, -invIm), tRe2 = _c[0], tIm2 = _c[1];\r
-                    return [0.5 * (tRe1 - tRe2), 0.5 * (tIm1 - tIm2)];\r
-                };\r
-                CMath.cexp = function (re, im) {\r
-                    var ep = Math.exp(re);\r
-                    return [ep * Math.cos(im), ep * Math.sin(im)];\r
-                };\r
-                CMath.clog = function (re, im) {\r
-                    if (isNaN(re) || isNaN(im)) {\r
-                        return [NaN, NaN];\r
-                    }\r
-                    if (im === 0) {\r
-                        if (re >= 0) {\r
-                            return [Math.log(re), 0];\r
-                        }\r
-                        else {\r
-                            return [Math.log(-re), Math.PI];\r
-                        }\r
-                    }\r
-                    else {\r
-                        var l = CMath.length2(re, im);\r
-                        return [Math.log(l), Math.atan2(im, re)];\r
-                    }\r
-                };\r
-                CMath.cpowRR = function (reX, reY) {\r
-                    if (reX >= 0 || Math.floor(reY) === reY) {\r
-                        return [Math.pow(reX, reY), 0];\r
-                    }\r
-                    else {\r
-                        return CMath.cpow(reX, 0, reY, 0);\r
-                    }\r
-                };\r
-                CMath.cpow = function (reX, imX, reY, imY) {\r
-                    if (isNaN(reX) || isNaN(imX) || isNaN(reY) || isNaN(imY)) {\r
-                        return [NaN, NaN];\r
-                    }\r
-                    var _a = CMath.clog(reX, imX), lxr = _a[0], lxi = _a[1];\r
-                    var zr = lxr * reY - lxi * imY;\r
-                    var zi = lxr * imY + lxi * reY;\r
-                    return CMath.cexp(zr, zi);\r
-                };\r
-                return CMath;\r
-            }());\r
-            exports_2("CMath", CMath);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/complexNumber", ["jasmal/lib/math/cmath"], function (exports_3, context_3) {\r
-    "use strict";\r
-    var __moduleName = context_3 && context_3.id;\r
-    var cmath_1, ComplexNumber;\r
-    return {\r
-        setters: [\r
-            function (cmath_1_1) {\r
-                cmath_1 = cmath_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            ComplexNumber = (function () {\r
-                function ComplexNumber(r, i) {\r
-                    if (r === void 0) { r = 0; }\r
-                    if (i === void 0) { i = 0; }\r
-                    if (Array.isArray(r)) {\r
-                        this._re = r[0];\r
-                        this._im = r[1];\r
-                    }\r
-                    else {\r
-                        this._re = r;\r
-                        this._im = i;\r
-                    }\r
-                }\r
-                Object.defineProperty(ComplexNumber.prototype, "re", {\r
-                    get: function () {\r
-                        return this._re;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(ComplexNumber.prototype, "im", {\r
-                    get: function () {\r
-                        return this._im;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                ComplexNumber.prototype.addc = function (y) {\r
-                    return new ComplexNumber(this._re + y._re, this._im + y._im);\r
-                };\r
-                ComplexNumber.prototype.addr = function (y) {\r
-                    return new ComplexNumber(this._re + y, this._im);\r
-                };\r
-                ComplexNumber.prototype.subc = function (y) {\r
-                    return new ComplexNumber(this._re - y._re, this._im - y._im);\r
-                };\r
-                ComplexNumber.prototype.subr = function (y) {\r
-                    return new ComplexNumber(this._re - y, this._im);\r
-                };\r
-                ComplexNumber.prototype.mulc = function (y) {\r
-                    return new ComplexNumber(this._re * y._re - this._im * y._im, this._re * y._im + this._im * y._re);\r
-                };\r
-                ComplexNumber.prototype.mulr = function (y) {\r
-                    return new ComplexNumber(this._re * y, this._im * y);\r
-                };\r
-                ComplexNumber.prototype.divc = function (y) {\r
-                    if (y._im === 0) {\r
-                        return this.divr(y._re);\r
-                    }\r
-                    var _a = cmath_1.CMath.cdivCC(this._re, this._im, y._re, y._im), re = _a[0], im = _a[1];\r
-                    return new ComplexNumber(re, im);\r
-                };\r
-                ComplexNumber.prototype.divr = function (y) {\r
-                    return new ComplexNumber(this._re / y, this._im / y);\r
-                };\r
-                ComplexNumber.prototype.neg = function () {\r
-                    return new ComplexNumber(-this._re, -this._im);\r
-                };\r
-                ComplexNumber.prototype.inv = function () {\r
-                    var _a = cmath_1.CMath.cReciprocal(this._re, this._im), re = _a[0], im = _a[1];\r
-                    return new ComplexNumber(re, im);\r
-                };\r
-                ComplexNumber.prototype.norm = function () {\r
-                    return ComplexNumber.norm2(this._re, this._im);\r
-                };\r
-                ComplexNumber.prototype.angle = function () {\r
-                    return ComplexNumber.angle2(this._re, this._im);\r
-                };\r
-                ComplexNumber.prototype.conjugate = function () {\r
-                    return new ComplexNumber(this._re, -this._im);\r
-                };\r
-                ComplexNumber.prototype.equals = function (y) {\r
-                    return this._re === y._re && this._im === y._im;\r
-                };\r
-                ComplexNumber.prototype.toString = function () {\r
-                    return this._re + (this._im >= 0 ? '+' : '-') + this._im + 'j';\r
-                };\r
-                ComplexNumber.norm2 = function (re, im) {\r
-                    return cmath_1.CMath.length2(re, im);\r
-                };\r
-                ComplexNumber.angle2 = function (re, im) {\r
-                    return Math.atan2(im, re);\r
-                };\r
-                return ComplexNumber;\r
-            }());\r
-            exports_3("ComplexNumber", ComplexNumber);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/helper/shapeHelper", ["jasmal/lib/helper/objHelper"], function (exports_4, context_4) {\r
-    "use strict";\r
-    var __moduleName = context_4 && context_4.id;\r
-    var objHelper_1, ShapeHelper;\r
-    return {\r
-        setters: [\r
-            function (objHelper_1_1) {\r
-                objHelper_1 = objHelper_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            ShapeHelper = (function () {\r
-                function ShapeHelper() {\r
-                }\r
-                ShapeHelper.validateShape = function (shape) {\r
-                    if (shape.length === 0 || shape.length == undefined) {\r
-                        throw new Error('Shape must be a non-empty array.');\r
-                    }\r
-                    for (var i = 0; i < shape.length; i++) {\r
-                        if ((shape[i] | 0) !== shape[i]) {\r
-                            throw new Error('Shape can only consists of integers.');\r
-                        }\r
-                        if (shape[i] < 0) {\r
-                            throw new Error("The length of dimension " + i + " must be nonnegative.");\r
-                        }\r
-                    }\r
-                };\r
-                ShapeHelper.getSizeFromShape = function (shape) {\r
-                    var s = shape[0];\r
-                    for (var i = 1; i < shape.length; i++) {\r
-                        s *= shape[i];\r
-                    }\r
-                    return s;\r
-                };\r
-                ShapeHelper.computeStrides = function (shape) {\r
-                    var strides = [1];\r
-                    var d = 1;\r
-                    for (var i = shape.length - 1; i > 0; i--) {\r
-                        d *= shape[i];\r
-                        strides.unshift(d);\r
-                    }\r
-                    return strides;\r
-                };\r
-                ShapeHelper.shapeToString = function (shape) {\r
-                    if (Array.isArray(shape)) {\r
-                        return "[" + shape.join('x') + "]";\r
-                    }\r
-                    else {\r
-                        return "[" + Array.prototype.join.call(shape, 'x') + "]";\r
-                    }\r
-                };\r
-                ShapeHelper.isScalarShape = function (shape) {\r
-                    for (var i = 0; i < shape.length; i++) {\r
-                        if (shape[i] !== 1) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                ShapeHelper.getSqueezedShape = function (shape) {\r
-                    var newShape = [];\r
-                    for (var i = 0; i < shape.length; i++) {\r
-                        if (shape[i] !== 1) {\r
-                            newShape.push(shape[i]);\r
-                        }\r
-                    }\r
-                    if (newShape.length === 0) {\r
-                        newShape.push(1);\r
-                    }\r
-                    return newShape;\r
-                };\r
-                ShapeHelper.compareShape = function (shape1, shape2) {\r
-                    if (shape1.length !== shape2.length) {\r
-                        return false;\r
-                    }\r
-                    for (var i = 0; i < shape1.length; i++) {\r
-                        if (shape1[i] !== shape2[i]) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                ShapeHelper.compareSqueezedShape = function (shape1, shape2) {\r
-                    return ShapeHelper.compareShape(ShapeHelper.getSqueezedShape(shape1), ShapeHelper.getSqueezedShape(shape2));\r
-                };\r
-                ShapeHelper.checkBroadcastingCompatibility = function (shapeXIn, shapeYIn) {\r
-                    'use strict';\r
-                    var shapeZ = [];\r
-                    if (shapeXIn.length < shapeYIn.length) {\r
-                        var shapeX = Array.prototype.slice.call(shapeXIn);\r
-                        while (shapeX.length < shapeYIn.length)\r
-                            shapeX.unshift(1);\r
-                        shapeXIn = shapeX;\r
-                    }\r
-                    if (shapeYIn.length < shapeXIn.length) {\r
-                        var shapeY = Array.prototype.slice.call(shapeYIn);\r
-                        while (shapeY.length < shapeXIn.length)\r
-                            shapeY.unshift(1);\r
-                        shapeYIn = shapeY;\r
-                    }\r
-                    var exact = true;\r
-                    for (var i = 0; i < shapeXIn.length; i++) {\r
-                        if (shapeXIn[i] !== shapeYIn[i]) {\r
-                            if ((shapeXIn[i] !== 1 && shapeYIn[i] !== 1) ||\r
-                                (shapeXIn[i] === 0 && shapeYIn[i] !== 0) ||\r
-                                (shapeXIn[i] !== 0 && shapeYIn[i] === 0)) {\r
-                                throw new Error('Incompatible shape.');\r
-                            }\r
-                            exact = false;\r
-                        }\r
-                        shapeZ.push(Math.max(shapeXIn[i], shapeYIn[i]));\r
-                    }\r
-                    return {\r
-                        shapeX: shapeXIn,\r
-                        shapeY: shapeYIn,\r
-                        shapeZ: shapeZ,\r
-                        exact: exact\r
-                    };\r
-                };\r
-                ShapeHelper.inferShapeFromArray = function (arr) {\r
-                    var shape = [];\r
-                    var curEl = arr;\r
-                    while (Array.isArray(curEl) || objHelper_1.ObjectHelper.isTypedArray(curEl)) {\r
-                        shape.push(curEl.length);\r
-                        curEl = curEl[0];\r
-                    }\r
-                    if (shape.length === 0) {\r
-                        throw new Error('Input is not an array.');\r
-                    }\r
-                    return shape;\r
-                };\r
-                ShapeHelper.validateArrayShape = function (arr, shape, level) {\r
-                    if (level === void 0) { level = 0; }\r
-                    if (arr.length !== shape[level]) {\r
-                        throw new Error('The structure of the input array does not match that of a tensor.');\r
-                    }\r
-                    if (level < shape.length - 1) {\r
-                        for (var i = 0; i < arr.length; i++) {\r
-                            if (Array.isArray(arr[i])) {\r
-                                ShapeHelper.validateArrayShape(arr[i], shape, level + 1);\r
-                            }\r
-                            else {\r
-                                throw new Error('Cannot have mixed array and non-array elements at the same level.');\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                return ShapeHelper;\r
-            }());\r
-            exports_4("ShapeHelper", ShapeHelper);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/helper/comparisonHelper", [], function (exports_5, context_5) {\r
-    "use strict";\r
-    var __moduleName = context_5 && context_5.id;\r
-    var ComparisonHelper;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            ComparisonHelper = (function () {\r
-                function ComparisonHelper() {\r
-                }\r
-                ComparisonHelper.compareNumberAsc = function (a, b) {\r
-                    if (isNaN(a)) {\r
-                        return isNaN(b) ? 0 : 1;\r
-                    }\r
-                    else {\r
-                        if (isNaN(b)) {\r
-                            return -1;\r
-                        }\r
-                        if (a > b) {\r
-                            return 1;\r
-                        }\r
-                        else if (a < b) {\r
-                            return -1;\r
-                        }\r
-                        else {\r
-                            return 0;\r
-                        }\r
-                    }\r
-                };\r
-                ComparisonHelper.compareNumberDesc = function (a, b) {\r
-                    return ComparisonHelper.compareNumberAsc(b, a);\r
-                };\r
-                ComparisonHelper.compareNumberWithIndexAsc = function (a, b, ia, ib) {\r
-                    if (isNaN(a)) {\r
-                        return isNaN(b) ? (ia > ib ? 1 : -1) : 1;\r
-                    }\r
-                    else {\r
-                        if (isNaN(b)) {\r
-                            return -1;\r
-                        }\r
-                        if (a > b) {\r
-                            return 1;\r
-                        }\r
-                        else if (a < b) {\r
-                            return -1;\r
-                        }\r
-                        else {\r
-                            return ia > ib ? 1 : -1;\r
-                        }\r
-                    }\r
-                };\r
-                return ComparisonHelper;\r
-            }());\r
-            exports_5("ComparisonHelper", ComparisonHelper);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/helper/dataHelper", ["jasmal/lib/helper/objHelper", "jasmal/lib/helper/comparisonHelper"], function (exports_6, context_6) {\r
-    "use strict";\r
-    var __moduleName = context_6 && context_6.id;\r
-    var objHelper_2, comparisonHelper_1, DataHelper;\r
-    return {\r
-        setters: [\r
-            function (objHelper_2_1) {\r
-                objHelper_2 = objHelper_2_1;\r
-            },\r
-            function (comparisonHelper_1_1) {\r
-                comparisonHelper_1 = comparisonHelper_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            DataHelper = (function () {\r
-                function DataHelper() {\r
-                }\r
-                DataHelper.naturalNumbers = function (n) {\r
-                    var s = new Array(n);\r
-                    for (var i = 0; i < n; i++) {\r
-                        s[i] = i;\r
-                    }\r
-                    return s;\r
-                };\r
-                DataHelper.naturalNumbersAsInt32 = function (n) {\r
-                    if (objHelper_2.ObjectHelper.hasTypedArraySupport()) {\r
-                        var s = new Int32Array(n);\r
-                        for (var i = 0; i < n; i++) {\r
-                            s[i] = i;\r
-                        }\r
-                        return s;\r
-                    }\r
-                    else {\r
-                        return DataHelper.naturalNumbers(n);\r
-                    }\r
-                };\r
-                DataHelper.allocateFloat64Array = function (size) {\r
-                    return objHelper_2.ObjectHelper.hasTypedArraySupport()\r
-                        ? new Float64Array(size)\r
-                        : DataHelper.allocateJsArray(size);\r
-                };\r
-                DataHelper.allocateInt32Array = function (size) {\r
-                    return objHelper_2.ObjectHelper.hasTypedArraySupport()\r
-                        ? new Int32Array(size)\r
-                        : DataHelper.allocateJsArray(size);\r
-                };\r
-                DataHelper.allocateJsArray = function (size) {\r
-                    var arr = new Array(size);\r
-                    for (var i = 0; i < size; i++) {\r
-                        arr[i] = 0;\r
-                    }\r
-                    return arr;\r
-                };\r
-                DataHelper.areArraysEqual = function (x, y) {\r
-                    if (x === y)\r
-                        return true;\r
-                    if (x.length !== y.length)\r
-                        return false;\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] !== y[i]) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.areArraysApproximatelyEqual = function (x, y, tolerance) {\r
-                    if (x === y)\r
-                        return true;\r
-                    if (x.length !== y.length)\r
-                        return false;\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (isNaN(x[i]) || isNaN(y[i]) || Math.abs(x[i] - y[i]) > tolerance) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.isArrayAllNonZeros = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] === 0) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.isArrayAllZeros = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] !== 0) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.isArrayApproximatelyAllZeros = function (x, tolerance) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (isNaN(x[i]) || Math.abs(x[i]) > tolerance) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.isArrayAllFinite = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (!isFinite(x[i])) {\r
-                            return false;\r
-                        }\r
-                    }\r
-                    return true;\r
-                };\r
-                DataHelper.anyNegative = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] < 0) {\r
-                            return true;\r
-                        }\r
-                    }\r
-                    return false;\r
-                };\r
-                DataHelper.findReal = function (re) {\r
-                    var indices = [];\r
-                    for (var i = 0; i < re.length; i++) {\r
-                        if (re[i] !== 0) {\r
-                            indices.push(i);\r
-                        }\r
-                    }\r
-                    return indices;\r
-                };\r
-                DataHelper.findComplex = function (re, im) {\r
-                    var indices = [];\r
-                    for (var i = 0; i < re.length; i++) {\r
-                        if (re[i] !== 0 || im[i] !== 0) {\r
-                            indices.push(i);\r
-                        }\r
-                    }\r
-                    return indices;\r
-                };\r
-                DataHelper.findWithCallbackReal = function (re, cb) {\r
-                    var indices = [];\r
-                    for (var i = 0; i < re.length; i++) {\r
-                        if (cb(re[i], 0)) {\r
-                            indices.push(i);\r
-                        }\r
-                    }\r
-                    return indices;\r
-                };\r
-                DataHelper.findWithCallbackComplex = function (re, im, cb) {\r
-                    var indices = [];\r
-                    for (var i = 0; i < re.length; i++) {\r
-                        if (cb(re[i], im[i])) {\r
-                            indices.push(i);\r
-                        }\r
-                    }\r
-                    return indices;\r
-                };\r
-                DataHelper.copy = function (from, to, offset) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (from.length + offset > to.length) {\r
-                        throw new Error('Not enough space.');\r
-                    }\r
-                    for (var i = 0; i < from.length; i++) {\r
-                        to[i + offset] = from[i];\r
-                    }\r
-                };\r
-                DataHelper.firstIndexOf = function (reX, reArr) {\r
-                    for (var i = 0; i < reArr.length; i++) {\r
-                        if (reArr[i] === reX) {\r
-                            return i;\r
-                        }\r
-                    }\r
-                    return -1;\r
-                };\r
-                DataHelper.firstIndexOfComplex = function (reX, imX, reArr, imArr) {\r
-                    for (var i = 0; i < reArr.length; i++) {\r
-                        if (reArr[i] === reX && imArr[i] === imX) {\r
-                            return i;\r
-                        }\r
-                    }\r
-                    return -1;\r
-                };\r
-                DataHelper.binarySearch = function (reX, reArr) {\r
-                    if (isNaN(reX)) {\r
-                        return -1;\r
-                    }\r
-                    var l = 0;\r
-                    var h = reArr.length - 1;\r
-                    var m;\r
-                    var status;\r
-                    while (l <= h) {\r
-                        m = (l + h) >>> 1;\r
-                        status = comparisonHelper_1.ComparisonHelper.compareNumberAsc(reX, reArr[m]);\r
-                        if (status > 0) {\r
-                            l = m + 1;\r
-                        }\r
-                        else if (status < 0) {\r
-                            h = m - 1;\r
-                        }\r
-                        else {\r
-                            return m;\r
-                        }\r
-                    }\r
-                    return -1;\r
-                };\r
-                DataHelper.binarySearchComplex = function (reX, imX, reArr, imArr) {\r
-                    if (isNaN(reX) || isNaN(imX)) {\r
-                        return -1;\r
-                    }\r
-                    var l = 0;\r
-                    var h = reArr.length - 1;\r
-                    var m;\r
-                    var status;\r
-                    while (l <= h) {\r
-                        m = (l + h) >>> 1;\r
-                        status = comparisonHelper_1.ComparisonHelper.compareNumberAsc(reX, reArr[m]);\r
-                        if (status === 0) {\r
-                            status = comparisonHelper_1.ComparisonHelper.compareNumberAsc(imX, imArr[m]);\r
-                        }\r
-                        if (status > 0) {\r
-                            l = m + 1;\r
-                        }\r
-                        else if (status < 0) {\r
-                            h = m - 1;\r
-                        }\r
-                        else {\r
-                            return m;\r
-                        }\r
-                    }\r
-                    return -1;\r
-                };\r
-                return DataHelper;\r
-            }());\r
-            exports_6("DataHelper", DataHelper);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/storage", ["jasmal/lib/helper/shapeHelper", "jasmal/lib/helper/objHelper", "jasmal/lib/helper/dataHelper"], function (exports_7, context_7) {\r
-    "use strict";\r
-    var __moduleName = context_7 && context_7.id;\r
-    var shapeHelper_1, objHelper_3, dataHelper_1, TensorStorage;\r
-    return {\r
-        setters: [\r
-            function (shapeHelper_1_1) {\r
-                shapeHelper_1 = shapeHelper_1_1;\r
-            },\r
-            function (objHelper_3_1) {\r
-                objHelper_3 = objHelper_3_1;\r
-            },\r
-            function (dataHelper_1_1) {\r
-                dataHelper_1 = dataHelper_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            TensorStorage = (function () {\r
-                function TensorStorage(data, dtype) {\r
-                    this._data = data;\r
-                    this._dtype = dtype;\r
-                    this.refCount = 0;\r
-                }\r
-                TensorStorage.ValidateDTypeSupport = function (dtype) {\r
-                    if (!objHelper_3.ObjectHelper.hasTypedArraySupport()) {\r
-                        if (!((dtype === 3) || (dtype === 0))) {\r
-                            throw new Error('When native typed arrays are not available, only DType.LOGIC and DType.FLOAT64 are supported.');\r
-                        }\r
-                    }\r
-                };\r
-                TensorStorage.create = function (size, dtype) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    var data;\r
-                    if (objHelper_3.ObjectHelper.hasTypedArraySupport()) {\r
-                        switch (dtype) {\r
-                            case 0:\r
-                                data = new Uint8Array(size);\r
-                                break;\r
-                            case 1:\r
-                                data = new Int32Array(size);\r
-                                break;\r
-                            case 3:\r
-                                data = new Float64Array(size);\r
-                                break;\r
-                            default:\r
-                                throw new Error("Unknown dtype \"" + dtype + "\".");\r
-                        }\r
-                    }\r
-                    else {\r
-                        TensorStorage.ValidateDTypeSupport(dtype);\r
-                        data = dataHelper_1.DataHelper.allocateJsArray(size);\r
-                    }\r
-                    return new TensorStorage(data, dtype);\r
-                };\r
-                TensorStorage.fromTypedArray = function (arr, dtype) {\r
-                    switch (dtype) {\r
-                        case 0:\r
-                            var storage = TensorStorage.create(arr.length, dtype);\r
-                            for (var i = 0; i < arr.length; i++) {\r
-                                storage.setAsLogicAtUnchecked(i, arr[i]);\r
-                            }\r
-                        case 1:\r
-                            return new TensorStorage(new Int32Array(arr), 1);\r
-                        case 3:\r
-                            return new TensorStorage(new Float64Array(arr), 3);\r
-                        default:\r
-                            throw new Error("Unknown dtype \"" + dtype + "\".");\r
-                    }\r
-                };\r
-                TensorStorage.fromArray = function (arr, shape, dtype) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    TensorStorage.ValidateDTypeSupport(dtype);\r
-                    var strides = shapeHelper_1.ShapeHelper.computeStrides(shape);\r
-                    var size = strides[0] * shape[0];\r
-                    var storage = TensorStorage.create(size, dtype);\r
-                    var copyFromArray = function (arr, level, offset) {\r
-                        if (level === shape.length - 1) {\r
-                            if (storage.dtype === 0) {\r
-                                for (var i = 0; i < shape[level]; i++) {\r
-                                    storage.setAsLogicAtUnchecked(offset + i, arr[i]);\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (var i = 0; i < shape[level]; i++) {\r
-                                    storage.data[offset + i] = arr[i];\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < shape[level]; i++) {\r
-                                copyFromArray(arr[i], level + 1, offset);\r
-                                offset += strides[level];\r
-                            }\r
-                        }\r
-                    };\r
-                    copyFromArray(arr, 0, 0);\r
-                    return storage;\r
-                };\r
-                TensorStorage.prototype.dataCopy = function () {\r
-                    var data;\r
-                    if (objHelper_3.ObjectHelper.hasTypedArraySupport()) {\r
-                        switch (this.dtype) {\r
-                            case 0:\r
-                                data = new Uint8Array(this.data);\r
-                                break;\r
-                            case 1:\r
-                                data = new Int32Array(this.data);\r
-                                break;\r
-                            case 3:\r
-                                data = new Float64Array(this.data);\r
-                                break;\r
-                            default:\r
-                                throw new Error("This should never happen!");\r
-                        }\r
-                    }\r
-                    else {\r
-                        data = this.data.slice();\r
-                    }\r
-                    return new TensorStorage(data, this.dtype);\r
-                };\r
-                Object.defineProperty(TensorStorage.prototype, "data", {\r
-                    get: function () {\r
-                        return this._data;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(TensorStorage.prototype, "dtype", {\r
-                    get: function () {\r
-                        return this._dtype;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                TensorStorage.prototype.setAsLogicAtUnchecked = function (offset, v) {\r
-                    if (isNaN(v)) {\r
-                        throw new Error('Cannot convert NaN to logic values.');\r
-                    }\r
-                    this._data[offset] = !!v ? 1 : 0;\r
-                };\r
-                TensorStorage.prototype.getAsLogicAtUnchecked = function (offset) {\r
-                    if (isNaN(this._data[offset])) {\r
-                        throw new Error('Cannot convert NaN to logic values.');\r
-                    }\r
-                    return this._data[offset] !== 0 ? 1 : 0;\r
-                };\r
-                TensorStorage.prototype.copyAsType = function (dtype) {\r
-                    var data;\r
-                    if (objHelper_3.ObjectHelper.hasTypedArraySupport()) {\r
-                        switch (dtype) {\r
-                            case 0:\r
-                                data = new Uint8Array(this.data.length);\r
-                                for (var i = 0; i < this.data.length; i++) {\r
-                                    data[i] = this.getAsLogicAtUnchecked(i);\r
-                                }\r
-                                break;\r
-                            case 1:\r
-                                data = new Int32Array(this.data);\r
-                                break;\r
-                            case 3:\r
-                                data = new Float64Array(this.data);\r
-                                break;\r
-                            default:\r
-                                throw new Error("This should never happen!");\r
-                        }\r
-                    }\r
-                    else {\r
-                        TensorStorage.ValidateDTypeSupport(dtype);\r
-                        switch (dtype) {\r
-                            case 0:\r
-                                data = new Array(this.data.length);\r
-                                for (var i = 0; i < this.data.length; i++) {\r
-                                    data[i] = this.getAsLogicAtUnchecked(i);\r
-                                }\r
-                                break;\r
-                            case 3:\r
-                                data = this.data.slice();\r
-                                break;\r
-                            default:\r
-                                throw new Error("This should never happen!");\r
-                        }\r
-                    }\r
-                    return new TensorStorage(data, dtype);\r
-                };\r
-                TensorStorage.Empty = TensorStorage.create(0, 0);\r
-                return TensorStorage;\r
-            }());\r
-            exports_7("TensorStorage", TensorStorage);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/tensor", ["jasmal/lib/storage", "jasmal/lib/dtype", "jasmal/lib/complexNumber", "jasmal/lib/helper/shapeHelper", "jasmal/lib/helper/dataHelper", "jasmal/lib/helper/objHelper"], function (exports_8, context_8) {\r
-    "use strict";\r
-    var __moduleName = context_8 && context_8.id;\r
-    var storage_1, dtype_1, complexNumber_1, shapeHelper_2, dataHelper_2, objHelper_4, OffsetCalculatorFactory, Tensor;\r
-    return {\r
-        setters: [\r
-            function (storage_1_1) {\r
-                storage_1 = storage_1_1;\r
-            },\r
-            function (dtype_1_1) {\r
-                dtype_1 = dtype_1_1;\r
-            },\r
-            function (complexNumber_1_1) {\r
-                complexNumber_1 = complexNumber_1_1;\r
-            },\r
-            function (shapeHelper_2_1) {\r
-                shapeHelper_2 = shapeHelper_2_1;\r
-            },\r
-            function (dataHelper_2_1) {\r
-                dataHelper_2 = dataHelper_2_1;\r
-            },\r
-            function (objHelper_4_1) {\r
-                objHelper_4 = objHelper_4_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            OffsetCalculatorFactory = (function () {\r
-                function OffsetCalculatorFactory() {\r
-                }\r
-                OffsetCalculatorFactory.create = function (dim) {\r
-                    if (!OffsetCalculatorFactory._cached[dim]) {\r
-                        var funcBody = '\'use strict\'; return ';\r
-                        for (var i = 0; i < dim - 1; i++) {\r
-                            funcBody += "indices[" + i + "] * strides[" + i + "] + ";\r
-                        }\r
-                        funcBody += "indices[" + (dim - 1) + "];";\r
-                        OffsetCalculatorFactory._cached[dim] = (new Function('indices', 'strides', funcBody));\r
-                    }\r
-                    return OffsetCalculatorFactory._cached[dim];\r
-                };\r
-                OffsetCalculatorFactory._cached = [];\r
-                return OffsetCalculatorFactory;\r
-            }());\r
-            Tensor = (function () {\r
-                function Tensor(re, im, shape) {\r
-                    this._re = re;\r
-                    this._re.refCount++;\r
-                    this._im = im;\r
-                    if (im !== storage_1.TensorStorage.Empty) {\r
-                        if (im.dtype !== re.dtype) {\r
-                            throw new Error('Inconsistent dtype.');\r
-                        }\r
-                        this._im.refCount++;\r
-                    }\r
-                    this._shape = shape;\r
-                    this._updateStridesAndCalculator();\r
-                }\r
-                Tensor.complex = function (re, im) {\r
-                    if (re.hasComplexStorage() || im.hasComplexStorage()) {\r
-                        throw new Error('Real tensor(s) expected.');\r
-                    }\r
-                    if (re.dtype !== im.dtype) {\r
-                        throw new Error('Real part and imaginary part must share the same data type.');\r
-                    }\r
-                    if (!shapeHelper_2.ShapeHelper.compareShape(re._shape, im._shape)) {\r
-                        throw new Error('Real part and imaginary part must share the same shape.');\r
-                    }\r
-                    return new Tensor(re._re, im._re, re.shape);\r
-                };\r
-                Tensor.fromArray = function (re, im, dtype) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    storage_1.TensorStorage.ValidateDTypeSupport(dtype);\r
-                    if (re == undefined)\r
-                        throw new Error('Real part must be specified.');\r
-                    var isReTypedArray = objHelper_4.ObjectHelper.isTypedArray(re);\r
-                    if (!Array.isArray(re) && !isReTypedArray) {\r
-                        throw new Error('Array expected.');\r
-                    }\r
-                    var isImTypedArray = false;\r
-                    if (im != undefined && !Array.isArray(im) && !(isImTypedArray = objHelper_4.ObjectHelper.isTypedArray(im))) {\r
-                        throw new Error('Array expected.');\r
-                    }\r
-                    var isComplex = im && im.length > 0;\r
-                    if (isComplex && dtype === 0) {\r
-                        throw new Error('Cannot convert a complex array to a logic tensor.');\r
-                    }\r
-                    var shape = shapeHelper_2.ShapeHelper.inferShapeFromArray(re);\r
-                    shapeHelper_2.ShapeHelper.validateArrayShape(re, shape);\r
-                    if (isComplex)\r
-                        shapeHelper_2.ShapeHelper.validateArrayShape(im, shape);\r
-                    var reStorage = isReTypedArray\r
-                        ? storage_1.TensorStorage.fromTypedArray(re, dtype)\r
-                        : storage_1.TensorStorage.fromArray(re, shape, dtype);\r
-                    var imStorage;\r
-                    if (isComplex) {\r
-                        imStorage = isImTypedArray\r
-                            ? storage_1.TensorStorage.fromTypedArray(im, dtype)\r
-                            : storage_1.TensorStorage.fromArray(im, shape, dtype);\r
-                    }\r
-                    else {\r
-                        imStorage = storage_1.TensorStorage.Empty;\r
-                    }\r
-                    return new Tensor(reStorage, imStorage, shape);\r
-                };\r
-                Tensor.zeros = function (shape, dtype) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    shapeHelper_2.ShapeHelper.validateShape(shape);\r
-                    var re = storage_1.TensorStorage.create(shapeHelper_2.ShapeHelper.getSizeFromShape(shape), dtype);\r
-                    return new Tensor(re, storage_1.TensorStorage.Empty, Array.isArray(shape) ? shape.slice() : Array.prototype.slice.call(shape));\r
-                };\r
-                Tensor.ones = function (shape, dtype) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    shapeHelper_2.ShapeHelper.validateShape(shape);\r
-                    var re = storage_1.TensorStorage.create(shapeHelper_2.ShapeHelper.getSizeFromShape(shape), dtype);\r
-                    for (var i = 0; i < re.data.length; i++) {\r
-                        re.data[i] = 1;\r
-                    }\r
-                    return new Tensor(re, storage_1.TensorStorage.Empty, Array.isArray(shape) ? shape.slice() : Array.prototype.slice.call(shape));\r
-                };\r
-                Tensor.scalar = function (x, y, dtype, ndim) {\r
-                    if (dtype === void 0) { dtype = 3; }\r
-                    if (ndim === void 0) { ndim = 1; }\r
-                    var re, im;\r
-                    if (x instanceof complexNumber_1.ComplexNumber) {\r
-                        re = x.re;\r
-                        im = x.im;\r
-                    }\r
-                    else {\r
-                        re = x;\r
-                        im = y || 0;\r
-                    }\r
-                    var reStorage = storage_1.TensorStorage.create(1, dtype);\r
-                    reStorage.data[0] = re;\r
-                    var imStorage;\r
-                    if (im !== 0) {\r
-                        imStorage = storage_1.TensorStorage.create(1, dtype);\r
-                        imStorage.data[0] = im;\r
-                    }\r
-                    else {\r
-                        imStorage = storage_1.TensorStorage.Empty;\r
-                    }\r
-                    var T = new Tensor(reStorage, imStorage, [1]);\r
-                    if (ndim > 1) {\r
-                        var shape = new Array(ndim);\r
-                        for (var i = 0; i < ndim; i++) {\r
-                            shape[i] = 1;\r
-                        }\r
-                        T._shape = shape;\r
-                        T._updateStridesAndCalculator();\r
-                    }\r
-                    return T;\r
-                };\r
-                Tensor.toTensor = function (x) {\r
-                    if (Array.isArray(x)) {\r
-                        return Tensor.fromArray(x);\r
-                    }\r
-                    else if (objHelper_4.ObjectHelper.isTypedArray(x)) {\r
-                        return Tensor.fromArray(x);\r
-                    }\r
-                    else if (x instanceof complexNumber_1.ComplexNumber) {\r
-                        return Tensor.scalar(x);\r
-                    }\r
-                    else if (Object.prototype.toString.call(x) === '[object Number]') {\r
-                        return Tensor.scalar(x);\r
-                    }\r
-                    else {\r
-                        throw new Error("Cannot convert " + Object.prototype.toString.call(x) + " to a tensor.");\r
-                    }\r
-                };\r
-                Tensor.isEqual = function (x, y) {\r
-                    if (x === y)\r
-                        return true;\r
-                    if (x == undefined || y == undefined)\r
-                        return false;\r
-                    if (!shapeHelper_2.ShapeHelper.compareShape(x._shape, y._shape))\r
-                        return false;\r
-                    if (x.dtype !== y.dtype)\r
-                        return false;\r
-                    if (x.hasComplexStorage() !== y.hasComplexStorage())\r
-                        return false;\r
-                    if (!dataHelper_2.DataHelper.areArraysEqual(x.realData, y.realData))\r
-                        return false;\r
-                    if (x.hasComplexStorage() && !dataHelper_2.DataHelper.areArraysEqual(x.imagData, y.imagData))\r
-                        return false;\r
-                    return true;\r
-                };\r
-                Tensor.isNumericallyEqual = function (x, y) {\r
-                    if (x === y)\r
-                        return true;\r
-                    if (x == undefined || y == undefined)\r
-                        return false;\r
-                    if (!shapeHelper_2.ShapeHelper.compareShape(x._shape, y._shape))\r
-                        return false;\r
-                    if (!dataHelper_2.DataHelper.areArraysEqual(x.realData, y.realData))\r
-                        return false;\r
-                    if (x.hasComplexStorage()) {\r
-                        if (y.hasComplexStorage()) {\r
-                            return dataHelper_2.DataHelper.areArraysEqual(x.imagData, y.imagData);\r
-                        }\r
-                        else {\r
-                            return dataHelper_2.DataHelper.isArrayAllZeros(x.imagData);\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (y.hasComplexStorage()) {\r
-                            return dataHelper_2.DataHelper.isArrayAllZeros(y.imagData);\r
-                        }\r
-                        else {\r
-                            return true;\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.isApproximatelyEqual = function (x, y, tolerance) {\r
-                    if (tolerance < 0) {\r
-                        throw new Error('Tolerance must be nonnegative.');\r
-                    }\r
-                    if (x === y)\r
-                        return true;\r
-                    if (x == undefined || y == undefined)\r
-                        return false;\r
-                    if (!shapeHelper_2.ShapeHelper.compareShape(x._shape, y._shape))\r
-                        return false;\r
-                    if (!dataHelper_2.DataHelper.areArraysApproximatelyEqual(x.realData, y.realData, tolerance))\r
-                        return false;\r
-                    if (x.hasComplexStorage()) {\r
-                        if (y.hasComplexStorage()) {\r
-                            return dataHelper_2.DataHelper.areArraysApproximatelyEqual(x.imagData, y.imagData, tolerance);\r
-                        }\r
-                        else {\r
-                            return dataHelper_2.DataHelper.isArrayApproximatelyAllZeros(x.imagData, tolerance);\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (y.hasComplexStorage()) {\r
-                            return dataHelper_2.DataHelper.isArrayApproximatelyAllZeros(y.imagData, tolerance);\r
-                        }\r
-                        else {\r
-                            return true;\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.analyzeOpInput = function (value) {\r
-                    var isOriginalTypeScalar = false;\r
-                    var hasOnlyOneElement = false, isComplex = false;\r
-                    var re = 0, im = 0;\r
-                    var reArr = [], imArr = [];\r
-                    var originalShape = [1];\r
-                    var originalType = 4;\r
-                    var originalDType = 3;\r
-                    if (value instanceof Tensor) {\r
-                        reArr = value._re.data;\r
-                        hasOnlyOneElement = value.size === 1;\r
-                        if (hasOnlyOneElement) {\r
-                            re = value._re.data[0];\r
-                            if (value.hasComplexStorage()) {\r
-                                im = value._im.data[0];\r
-                            }\r
-                            isComplex = im !== 0;\r
-                            if (isComplex) {\r
-                                imArr = value._im.data;\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (value.hasNonZeroComplexStorage()) {\r
-                                imArr = value._im.data;\r
-                                isComplex = true;\r
-                            }\r
-                        }\r
-                        originalShape = value._shape;\r
-                        originalType = 3;\r
-                        originalDType = value.dtype;\r
-                    }\r
-                    else if (Array.isArray(value) || objHelper_4.ObjectHelper.isTypedArray(value)) {\r
-                        if (Array.isArray(value[0])) {\r
-                            var tmp = Tensor.analyzeOpInput(Tensor.fromArray(value));\r
-                            tmp.originalType = 2;\r
-                            return tmp;\r
-                        }\r
-                        else {\r
-                            reArr = value;\r
-                            hasOnlyOneElement = value.length === 1;\r
-                            if (hasOnlyOneElement) {\r
-                                re = value[0];\r
-                            }\r
-                            else {\r
-                                originalShape = [value.length];\r
-                            }\r
-                            originalType = 2;\r
-                        }\r
-                    }\r
-                    else if (value instanceof complexNumber_1.ComplexNumber) {\r
-                        re = value.re;\r
-                        im = value.im;\r
-                        isComplex = im !== 0;\r
-                        hasOnlyOneElement = true;\r
-                        originalType = 1;\r
-                        isOriginalTypeScalar = true;\r
-                    }\r
-                    else if (typeof value === 'number') {\r
-                        re = value;\r
-                        hasOnlyOneElement = true;\r
-                        originalType = 0;\r
-                        isOriginalTypeScalar = true;\r
-                    }\r
-                    else {\r
-                        throw new Error("Unsupported value " + value + ".");\r
-                    }\r
-                    return {\r
-                        isInputScalar: isOriginalTypeScalar,\r
-                        hasOnlyOneElement: hasOnlyOneElement,\r
-                        isComplex: isComplex,\r
-                        re: re,\r
-                        im: im,\r
-                        reArr: reArr,\r
-                        imArr: imArr,\r
-                        originalShape: originalShape,\r
-                        originalType: originalType,\r
-                        originalDType: originalDType,\r
-                        originalInput: value\r
-                    };\r
-                };\r
-                Object.defineProperty(Tensor.prototype, "dtype", {\r
-                    get: function () {\r
-                        return this._re.dtype;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(Tensor.prototype, "shape", {\r
-                    get: function () {\r
-                        return this._shape.slice();\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(Tensor.prototype, "strides", {\r
-                    get: function () {\r
-                        return this._strides.slice();\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Tensor.prototype._updateStridesAndCalculator = function () {\r
-                    this._strides = shapeHelper_2.ShapeHelper.computeStrides(this._shape);\r
-                    this._offsetCalculator = OffsetCalculatorFactory.create(this._shape.length);\r
-                };\r
-                Object.defineProperty(Tensor.prototype, "ndim", {\r
-                    get: function () {\r
-                        return this._shape.length;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(Tensor.prototype, "size", {\r
-                    get: function () {\r
-                        return this._re.data.length;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(Tensor.prototype, "realData", {\r
-                    get: function () {\r
-                        return this._re.data;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Object.defineProperty(Tensor.prototype, "imagData", {\r
-                    get: function () {\r
-                        if (!this.hasComplexStorage()) {\r
-                            throw new Error('Attempting to access the imaginary part for a real matrix.');\r
-                        }\r
-                        return this._im.data;\r
-                    },\r
-                    enumerable: true,\r
-                    configurable: true\r
-                });\r
-                Tensor.prototype.isScalar = function () {\r
-                    return this._re.data.length === 1;\r
-                };\r
-                Tensor.prototype.isEmpty = function () {\r
-                    return this._re.data.length === 0;\r
-                };\r
-                Tensor.prototype.hasComplexStorage = function () {\r
-                    return this._im !== storage_1.TensorStorage.Empty;\r
-                };\r
-                Tensor.prototype.hasNonZeroComplexStorage = function () {\r
-                    return this._im !== storage_1.TensorStorage.Empty && !dataHelper_2.DataHelper.isArrayAllZeros(this._im.data);\r
-                };\r
-                Tensor.prototype.set = function () {\r
-                    if (arguments.length < 2) {\r
-                        throw new Error('Too few arguments.');\r
-                    }\r
-                    if (arguments.length !== 2 && arguments.length !== this.ndim + 1) {\r
-                        throw new Error("Expecting " + (this.ndim + 1) + " arguments.");\r
-                    }\r
-                    this._handleSetGet(arguments, true);\r
-                };\r
-                Tensor.prototype._setBatch = function (iterDef, value) {\r
-                    this._setSubTensor({\r
-                        definitions: [iterDef],\r
-                        areAllConstantType: false\r
-                    }, value);\r
-                };\r
-                Tensor.prototype._setSubTensor = function (iterInfo, value) {\r
-                    var iterDefs = iterInfo.definitions;\r
-                    var ndim;\r
-                    var strides;\r
-                    var trailingOffset = 0;\r
-                    var finalStride = 1;\r
-                    var _a = Tensor._inferShapeFromIterDefs(iterDefs), shapeSub = _a[0], sizeSub = _a[1];\r
-                    if (sizeSub === 0) {\r
-                        return;\r
-                    }\r
-                    var maxLevel = iterDefs.length - 1;\r
-                    if (iterDefs.length === 1) {\r
-                        ndim = 1;\r
-                        strides = [this.size];\r
-                    }\r
-                    else {\r
-                        ndim = this.ndim;\r
-                        strides = this._strides;\r
-                        var i = shapeSub.length - 1;\r
-                        while (shapeSub[i] === 1 && i > 0) {\r
-                            i--;\r
-                        }\r
-                        maxLevel = i;\r
-                        trailingOffset = 0;\r
-                        for (var k = i + 1; k < shapeSub.length; k++) {\r
-                            switch (iterDefs[k].type) {\r
-                                case 0:\r
-                                    trailingOffset += strides[k] * iterDefs[k].index;\r
-                                    break;\r
-                                case 2:\r
-                                    trailingOffset += strides[k] * iterDefs[k].indices[0];\r
-                                    break;\r
-                                case 1:\r
-                                    trailingOffset += strides[k] * iterDefs[k].start;\r
-                                    break;\r
-                                default:\r
-                                    throw new Error('Should never reach here.');\r
-                            }\r
-                            finalStride *= strides[k - 1];\r
-                        }\r
-                    }\r
-                    var v = Tensor.analyzeOpInput(value);\r
-                    this.ensureUnsharedLocalStorage();\r
-                    if (v.hasOnlyOneElement) {\r
-                        var newRe = v.re, newIm = v.im;\r
-                        if (v.isComplex) {\r
-                            this.ensureComplexStorage();\r
-                            this._setSubTensorC1(iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, 0, 0);\r
-                        }\r
-                        else {\r
-                            this._setSubTensorR1(iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, 0, 0);\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (v.originalShape.length === 1 && v.reArr.length !== sizeSub) {\r
-                            throw new Error('The size of the tensor/array does not match the number of indices.');\r
-                        }\r
-                        if (v.originalShape.length > 1 && !shapeHelper_2.ShapeHelper.compareSqueezedShape(v.originalShape, shapeSub)) {\r
-                            throw new Error("Attempting to update the " + shapeHelper_2.ShapeHelper.shapeToString(shapeSub) + " sub tensor"\r
-                                + ("with a tensor of incompatible shape " + shapeHelper_2.ShapeHelper.shapeToString(v.originalShape) + "."));\r
-                        }\r
-                        var newRe = v.reArr, newIm = v.imArr;\r
-                        var stridesSub = shapeHelper_2.ShapeHelper.computeStrides(shapeSub);\r
-                        if (v.isComplex) {\r
-                            this.ensureComplexStorage();\r
-                            this._setSubTensorCN(iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, 0, 0, 0);\r
-                        }\r
-                        else {\r
-                            this._setSubTensorRN(iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, 0, 0, 0);\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._setSubTensorR1 = function (iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, level, offsetX) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._re.data[offsetX + ind.index * finalStride + trailingOffset] = newRe;\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset] = newRe;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._setSubTensorR1(iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.index);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._setSubTensorR1(iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i);\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._setSubTensorR1(iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i);\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._setSubTensorR1(iterDefs, newRe, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.indices[i]);\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._setSubTensorC1 = function (iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, level, offsetX) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._re.data[offsetX + ind.index * finalStride + trailingOffset] = newRe;\r
-                                this._im.data[offsetX + ind.index * finalStride + trailingOffset] = newIm;\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe;\r
-                                        this._im.data[offsetX + i * finalStride + trailingOffset] = newIm;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe;\r
-                                        this._im.data[offsetX + i * finalStride + trailingOffset] = newIm;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset] = newRe;\r
-                                    this._im.data[offsetX + ind.indices[i] * finalStride + trailingOffset] = newIm;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._setSubTensorC1(iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.index);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._setSubTensorC1(iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i);\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._setSubTensorC1(iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i);\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._setSubTensorC1(iterDefs, newRe, newIm, maxLevel, strides, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.indices[i]);\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                ;\r
-                Tensor.prototype._setSubTensorRN = function (iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, level, offsetX, offsetY) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        var j = void 0;\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._re.data[offsetX + ind.index * finalStride + trailingOffset] =\r
-                                    newRe[offsetY + ind.index];\r
-                                break;\r
-                            case 1:\r
-                                j = 0;\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe[offsetY + j];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe[offsetY + j];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                j = 0;\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset] =\r
-                                        newRe[offsetY + j];\r
-                                    j++;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._setSubTensorRN(iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.index, offsetY);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._setSubTensorRN(iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i, offsetY);\r
-                                        offsetY += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._setSubTensorRN(iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i, offsetY);\r
-                                        offsetY += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._setSubTensorRN(iterDefs, newRe, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.indices[i], offsetY);\r
-                                    offsetY += stridesSub[level];\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._setSubTensorCN = function (iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, level, offsetX, offsetY) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        var j = void 0;\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._re.data[offsetX + ind.index * finalStride + trailingOffset] =\r
-                                    newRe[offsetY + ind.index];\r
-                                this._im.data[offsetX + ind.index * finalStride + trailingOffset] =\r
-                                    newIm[offsetY + ind.index];\r
-                                break;\r
-                            case 1:\r
-                                j = 0;\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe[offsetY + j];\r
-                                        this._im.data[offsetX + i * finalStride + trailingOffset] = newIm[offsetY + j];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._re.data[offsetX + i * finalStride + trailingOffset] = newRe[offsetY + j];\r
-                                        this._im.data[offsetX + i * finalStride + trailingOffset] = newIm[offsetY + j];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                j = 0;\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset] =\r
-                                        newRe[offsetY + j];\r
-                                    this._im.data[offsetX + ind.indices[i] * finalStride + trailingOffset] =\r
-                                        newIm[offsetY + j];\r
-                                    j++;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._setSubTensorCN(iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.index, offsetY);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._setSubTensorCN(iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i, offsetY);\r
-                                        offsetY += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._setSubTensorCN(iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * i, offsetY);\r
-                                        offsetY += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._setSubTensorCN(iterDefs, newRe, newIm, maxLevel, strides, stridesSub, finalStride, trailingOffset, level + 1, offsetX + strides[level] * ind.indices[i], offsetY);\r
-                                    offsetY += stridesSub[level];\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype.get = function () {\r
-                    if (arguments.length < 1) {\r
-                        throw new Error('Too few arguments.');\r
-                    }\r
-                    var keepDims = false;\r
-                    var nIdx = arguments.length;\r
-                    if (arguments.length > 1) {\r
-                        if (Object.prototype.toString.call(arguments[arguments.length - 1]) === '[object Boolean]') {\r
-                            keepDims = arguments[arguments.length - 1];\r
-                            nIdx--;\r
-                        }\r
-                    }\r
-                    if (nIdx !== 1 && nIdx !== this.ndim) {\r
-                        throw new Error("Expecting " + nIdx + " index arguments.");\r
-                    }\r
-                    return this._handleSetGet(nIdx === arguments.length ? arguments : Array.prototype.slice.call(arguments, 0, nIdx), false, keepDims);\r
-                };\r
-                Tensor.prototype._getBatch = function (iterDefs, keepDims) {\r
-                    return this._getSubTensor({\r
-                        definitions: [iterDefs],\r
-                        areAllConstantType: false\r
-                    }, keepDims);\r
-                };\r
-                Tensor.prototype._getSubTensor = function (iterInfo, keepDims) {\r
-                    var iterDefs = iterInfo.definitions;\r
-                    var stridesX;\r
-                    var _a = Tensor._inferShapeFromIterDefs(iterDefs), shapeSub = _a[0], sizeSub = _a[1];\r
-                    var result;\r
-                    if (sizeSub === 0) {\r
-                        if (iterInfo.areAllConstantType) {\r
-                            throw new Error('This should never happen!');\r
-                        }\r
-                        else {\r
-                            result = Tensor.zeros(shapeSub, this.dtype);\r
-                            if (!keepDims) {\r
-                                for (var i = 0, j = 0; i < shapeSub.length; i++, j++) {\r
-                                    if (iterDefs[j].type === 0) {\r
-                                        shapeSub.splice(i, 1);\r
-                                        i--;\r
-                                    }\r
-                                }\r
-                                result._shape = shapeSub;\r
-                                result._updateStridesAndCalculator();\r
-                            }\r
-                            return result;\r
-                        }\r
-                    }\r
-                    var maxLevel = iterDefs.length - 1;\r
-                    if (iterDefs.length === 1) {\r
-                        stridesX = [this.size];\r
-                    }\r
-                    else {\r
-                        stridesX = this._strides;\r
-                    }\r
-                    if (iterInfo.areAllConstantType) {\r
-                        var offset = 0;\r
-                        for (var i = 0; i < shapeSub.length; i++) {\r
-                            switch (iterDefs[i].type) {\r
-                                case 0:\r
-                                    offset += stridesX[i] * iterDefs[i].index;\r
-                                    break;\r
-                                case 1:\r
-                                    offset += stridesX[i] * iterDefs[i].start;\r
-                                    break;\r
-                                case 2:\r
-                                    offset += stridesX[i] * iterDefs[i].indices[0];\r
-                                    break;\r
-                                default:\r
-                                    throw new Error('Should never reach here.');\r
-                            }\r
-                        }\r
-                        var re = this._re.data[offset];\r
-                        var im = this.hasComplexStorage() ? this._im.data[offset] : 0;\r
-                        if (keepDims) {\r
-                            return Tensor.scalar(re, im, this.dtype, shapeSub.length);\r
-                        }\r
-                        else {\r
-                            return im === 0 ? re : new complexNumber_1.ComplexNumber(re, im);\r
-                        }\r
-                    }\r
-                    else {\r
-                        result = Tensor.zeros(shapeSub, this.dtype);\r
-                        var newRe = result._re.data;\r
-                        var i = shapeSub.length - 1;\r
-                        var trailingOffset = 0;\r
-                        var finalStride = 1;\r
-                        var stridesSub = shapeHelper_2.ShapeHelper.computeStrides(shapeSub);\r
-                        while (shapeSub[i] === 1 && i > 0) {\r
-                            i--;\r
-                        }\r
-                        maxLevel = i;\r
-                        trailingOffset = 0;\r
-                        for (var k = i + 1; k < shapeSub.length; k++) {\r
-                            switch (iterDefs[k].type) {\r
-                                case 0:\r
-                                    trailingOffset += stridesX[k] * iterDefs[k].index;\r
-                                    break;\r
-                                case 2:\r
-                                    trailingOffset += stridesX[k] * iterDefs[k].indices[0];\r
-                                    break;\r
-                                case 1:\r
-                                    trailingOffset += stridesX[k] * iterDefs[k].start;\r
-                                    break;\r
-                                default:\r
-                                    throw new Error('Should never reach here.');\r
-                            }\r
-                            finalStride *= stridesX[k - 1];\r
-                        }\r
-                        if (this.hasComplexStorage()) {\r
-                            result.ensureComplexStorage();\r
-                            var newIm = result._im.data;\r
-                            this._getSubTensorC(iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, 0, 0, 0);\r
-                        }\r
-                        else {\r
-                            this._getSubTensorR(iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, 0, 0, 0);\r
-                        }\r
-                        if (!keepDims) {\r
-                            for (var i_1 = 0, j = 0; i_1 < shapeSub.length; i_1++, j++) {\r
-                                if (iterDefs[j].type === 0) {\r
-                                    shapeSub.splice(i_1, 1);\r
-                                    i_1--;\r
-                                }\r
-                            }\r
-                            result._shape = shapeSub;\r
-                            result._updateStridesAndCalculator();\r
-                        }\r
-                        return result;\r
-                    }\r
-                };\r
-                Tensor.prototype._getSubTensorR = function (iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level, offsetX, offsetSub) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        var j = 0;\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                newRe[offsetSub] = this._re.data[offsetX + ind.index * finalStride + trailingOffset];\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        newRe[offsetSub + j] = this._re.data[offsetX + i * finalStride + trailingOffset];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        newRe[offsetSub + j] = this._re.data[offsetX + i * finalStride + trailingOffset];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    newRe[offsetSub + j] =\r
-                                        this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset];\r
-                                    j++;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._getSubTensorR(iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * ind.index, offsetSub);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._getSubTensorR(iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * i, offsetSub);\r
-                                        offsetSub += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._getSubTensorR(iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * i, offsetSub);\r
-                                        offsetSub += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._getSubTensorR(iterDefs, newRe, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * ind.indices[i], offsetSub);\r
-                                    offsetSub += stridesSub[level];\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._getSubTensorC = function (iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level, offsetX, offsetSub) {\r
-                    var ind = iterDefs[level];\r
-                    if (level === maxLevel) {\r
-                        var j = 0;\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                newRe[offsetSub] = this._re.data[offsetX + ind.index * finalStride + trailingOffset];\r
-                                newIm[offsetSub] = this._im.data[offsetX + ind.index * finalStride + trailingOffset];\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        newRe[offsetSub + j] = this._re.data[offsetX + i * finalStride + trailingOffset];\r
-                                        newIm[offsetSub + j] = this._im.data[offsetX + i * finalStride + trailingOffset];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        newRe[offsetSub + j] = this._re.data[offsetX + i * finalStride + trailingOffset];\r
-                                        newIm[offsetSub + j] = this._im.data[offsetX + i * finalStride + trailingOffset];\r
-                                        j++;\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    newRe[offsetSub + j] =\r
-                                        this._re.data[offsetX + ind.indices[i] * finalStride + trailingOffset];\r
-                                    newIm[offsetSub + j] =\r
-                                        this._im.data[offsetX + ind.indices[i] * finalStride + trailingOffset];\r
-                                    j++;\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        switch (ind.type) {\r
-                            case 0:\r
-                                this._getSubTensorC(iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * ind.index, offsetSub);\r
-                                break;\r
-                            case 1:\r
-                                if (ind.step > 0) {\r
-                                    for (var i = ind.start; i < ind.stop; i += ind.step) {\r
-                                        this._getSubTensorC(iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * i, offsetSub);\r
-                                        offsetSub += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = ind.start; i > ind.stop; i += ind.step) {\r
-                                        this._getSubTensorC(iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * i, offsetSub);\r
-                                        offsetSub += stridesSub[level];\r
-                                    }\r
-                                }\r
-                                break;\r
-                            case 2:\r
-                                for (var i = 0; i < ind.indices.length; i++) {\r
-                                    this._getSubTensorC(iterDefs, newRe, newIm, maxLevel, stridesX, stridesSub, finalStride, trailingOffset, level + 1, offsetX + stridesX[level] * ind.indices[i], offsetSub);\r
-                                    offsetSub += stridesSub[level];\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._parseIndexIterDefs = function (args) {\r
-                    var iterDefs = [];\r
-                    var allAreConstantType = true;\r
-                    for (var i = 0; i < args.length; i++) {\r
-                        var ind = args[i];\r
-                        if (ind instanceof Tensor) {\r
-                            if (ind.hasNonZeroComplexStorage()) {\r
-                                throw new Error('Indices cannot be complex');\r
-                            }\r
-                            if (ind.dtype === 0) {\r
-                                if (ind.ndim !== 1 || ind.size !== this._shape[i]) {\r
-                                    throw new Error("1D logic tensor of size " + this._shape[i] + " expected for dimension " + (i + 1) + ".");\r
-                                }\r
-                                iterDefs.push({\r
-                                    type: 2,\r
-                                    indices: dataHelper_2.DataHelper.findReal(ind.realData)\r
-                                });\r
-                            }\r
-                            else {\r
-                                if (ind.ndim > 1) {\r
-                                    throw new Error("1D vector of indices expected form for dimension " + (i + 1) + "."\r
-                                        + ("Got a " + shapeHelper_2.ShapeHelper.shapeToString(ind.shape) + " tensor."));\r
-                                }\r
-                                iterDefs.push(this._parseSignedIndices(ind.realData, i));\r
-                            }\r
-                            allAreConstantType = false;\r
-                        }\r
-                        else if (Array.isArray(ind)) {\r
-                            if (ind.length > 0 && Array.isArray(ind[0])) {\r
-                                throw new Error("Expecting a 1D array of indices for " + (i + 1) + ". Got a nested array.");\r
-                            }\r
-                            iterDefs.push(this._parseSignedIndices(ind, i));\r
-                            allAreConstantType = false;\r
-                        }\r
-                        else if (typeof ind === 'string') {\r
-                            iterDefs.push(this._parseSlicingString(ind, i));\r
-                            allAreConstantType = false;\r
-                        }\r
-                        else {\r
-                            if (ind < 0) {\r
-                                ind += this._shape[i];\r
-                            }\r
-                            if ((ind | 0) !== ind) {\r
-                                throw new Error("The index for dimension " + (i + 1) + " should be a integer.");\r
-                            }\r
-                            if (ind >= this._shape[i]) {\r
-                                throw new Error("The index for dimension " + (i + 1) + " is out of bounds.");\r
-                            }\r
-                            iterDefs.push({\r
-                                type: 0,\r
-                                index: ind\r
-                            });\r
-                        }\r
-                    }\r
-                    return { definitions: iterDefs, areAllConstantType: allAreConstantType };\r
-                };\r
-                Tensor.prototype._parseSlicingString = function (str, dim) {\r
-                    var splits = str.trim().split(':');\r
-                    var start, stop, step;\r
-                    var max = dim == undefined ? this.size : this._shape[dim];\r
-                    switch (splits.length) {\r
-                        case 1:\r
-                            start = parseFloat(splits[0]);\r
-                            if (start < 0)\r
-                                start += max;\r
-                            this._checkIndex(start, dim);\r
-                            return {\r
-                                type: 0,\r
-                                index: start\r
-                            };\r
-                        case 2:\r
-                        case 3:\r
-                            if (splits.length === 3 && splits[2].length > 0) {\r
-                                step = parseFloat(splits[2]);\r
-                                if (Math.floor(step) !== step) {\r
-                                    throw new Error('Step must be an integer.');\r
-                                }\r
-                                if (step === 0) {\r
-                                    throw new Error('Step cannot be zero.');\r
-                                }\r
-                            }\r
-                            else {\r
-                                step = 1;\r
-                            }\r
-                            start = splits[0].length === 0\r
-                                ? (step > 0 ? 0 : max - 1)\r
-                                : parseFloat(splits[0]);\r
-                            if (start < 0)\r
-                                start += max;\r
-                            this._checkIndex(start, dim);\r
-                            if (splits[1].length === 0) {\r
-                                if (step > 0) {\r
-                                    stop = dim == undefined ? this.size : this._shape[dim];\r
-                                }\r
-                                else {\r
-                                    stop = -1;\r
-                                }\r
-                            }\r
-                            else {\r
-                                stop = parseFloat(splits[1]);\r
-                                if (stop < 0)\r
-                                    stop += max;\r
-                                if ((stop | 0) !== stop) {\r
-                                    throw new Error('Index must be an integer.');\r
-                                }\r
-                                if (stop < 0 || stop > max) {\r
-                                    throw new Error("Index " + stop + " is out of bounds for dimension " + dim + ".");\r
-                                }\r
-                            }\r
-                            return {\r
-                                type: 1,\r
-                                start: start,\r
-                                stop: stop,\r
-                                step: step\r
-                            };\r
-                        default:\r
-                            throw new Error("Invalid slicing definition '" + str + "'.");\r
-                    }\r
-                };\r
-                Tensor.prototype._parseSignedIndices = function (indices, dim) {\r
-                    var ret = undefined;\r
-                    var i, cur;\r
-                    var max = dim == undefined ? this.size : this._shape[dim];\r
-                    for (i = 0; i < indices.length; i++) {\r
-                        if (indices[i] < 0) {\r
-                            ret = new Array(indices.length);\r
-                            for (var j = 0; j < i; j++) {\r
-                                ret[j] = indices[j];\r
-                            }\r
-                            break;\r
-                        }\r
-                        this._checkIndex(indices[i], dim);\r
-                    }\r
-                    for (; i < indices.length; i++) {\r
-                        cur = indices[i] < 0 ? max + indices[i] : indices[i];\r
-                        this._checkIndex(cur, dim);\r
-                        ret[i] = cur;\r
-                    }\r
-                    return {\r
-                        type: 2,\r
-                        indices: ret || indices\r
-                    };\r
-                };\r
-                Tensor.prototype._checkIndex = function (index, dim) {\r
-                    if ((index | 0) !== index) {\r
-                        throw new Error('Index must be an integer.');\r
-                    }\r
-                    var max = dim == undefined ? this.size : this._shape[dim];\r
-                    if (index < 0 || index >= max) {\r
-                        if (dim == undefined) {\r
-                            throw new Error("Index " + index + " is out of bounds.");\r
-                        }\r
-                        else {\r
-                            throw new Error("Index " + index + " is out of bounds for dimension " + dim + ".");\r
-                        }\r
-                    }\r
-                };\r
-                Tensor._inferShapeFromIterDefs = function (iterDefs) {\r
-                    var shape = new Array(iterDefs.length);\r
-                    var size = 1;\r
-                    for (var i = 0; i < iterDefs.length; i++) {\r
-                        switch (iterDefs[i].type) {\r
-                            case 0:\r
-                                shape[i] = 1;\r
-                                break;\r
-                            case 2:\r
-                                shape[i] = iterDefs[i].indices.length;\r
-                                size *= shape[i];\r
-                                break;\r
-                            case 1:\r
-                                var start = iterDefs[i].start;\r
-                                var stop = iterDefs[i].stop;\r
-                                var step = iterDefs[i].step;\r
-                                if (start === stop || (start < stop && step < 0) || (start > stop && step > 0)) {\r
-                                    shape[i] = 0;\r
-                                    size = 0;\r
-                                }\r
-                                else {\r
-                                    var r = Math.abs(stop - start) - 1;\r
-                                    shape[i] = Math.max(0, Math.floor(r / Math.abs(step))) + 1;\r
-                                    size *= shape[i];\r
-                                }\r
-                                break;\r
-                            default:\r
-                                throw new Error('Should never reach here.');\r
-                        }\r
-                    }\r
-                    return [shape, size];\r
-                };\r
-                Tensor.prototype._handleSetGet = function (args, doSet, keepDims) {\r
-                    if (keepDims === void 0) { keepDims = false; }\r
-                    var arg0 = args[0];\r
-                    var tmp;\r
-                    var originalShape;\r
-                    if (args.length === (doSet ? 2 : 1)) {\r
-                        if (arg0 instanceof Tensor) {\r
-                            if (arg0.dtype === 0) {\r
-                                if (!shapeHelper_2.ShapeHelper.compareShape(arg0._shape, this._shape)) {\r
-                                    throw new Error('When using a logic tensor for indexing, its shape must match that of the tensor being indexed.');\r
-                                }\r
-                                if (doSet) {\r
-                                    this._setBatch({\r
-                                        type: 2,\r
-                                        indices: dataHelper_2.DataHelper.findReal(arg0.realData)\r
-                                    }, args[1]);\r
-                                }\r
-                                else {\r
-                                    return this._getBatch({\r
-                                        type: 2,\r
-                                        indices: dataHelper_2.DataHelper.findReal(arg0.realData)\r
-                                    }, keepDims);\r
-                                }\r
-                            }\r
-                            else {\r
-                                if (arg0.hasNonZeroComplexStorage()) {\r
-                                    throw new Error('Complex tensor cannot be used for indexing.');\r
-                                }\r
-                                if (doSet) {\r
-                                    this._setBatch(this._parseSignedIndices(arg0.realData), args[1]);\r
-                                }\r
-                                else {\r
-                                    if (arg0.ndim === 1 || arg0.isScalar()) {\r
-                                        return this._getBatch(this._parseSignedIndices(arg0.realData), keepDims);\r
-                                    }\r
-                                    else {\r
-                                        originalShape = arg0.shape;\r
-                                        tmp = this._getBatch(this._parseSignedIndices(arg0.realData), keepDims);\r
-                                        tmp._shape = originalShape;\r
-                                        tmp._updateStridesAndCalculator();\r
-                                        return tmp;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        else if (Array.isArray(arg0)) {\r
-                            if (doSet) {\r
-                                if (Array.isArray(arg0)) {\r
-                                    originalShape = shapeHelper_2.ShapeHelper.inferShapeFromArray(arg0);\r
-                                    shapeHelper_2.ShapeHelper.validateArrayShape(arg0, originalShape);\r
-                                    this._setBatch(this._parseSignedNestedIndexArray(arg0, originalShape), args[1]);\r
-                                }\r
-                                else {\r
-                                    this._setBatch(this._parseSignedIndices(arg0), args[1]);\r
-                                }\r
-                            }\r
-                            else {\r
-                                if (Array.isArray(arg0[0])) {\r
-                                    originalShape = shapeHelper_2.ShapeHelper.inferShapeFromArray(arg0);\r
-                                    shapeHelper_2.ShapeHelper.validateArrayShape(arg0, originalShape);\r
-                                    tmp = this._getBatch(this._parseSignedNestedIndexArray(arg0, originalShape), keepDims);\r
-                                    if (tmp instanceof Tensor) {\r
-                                        tmp._shape = originalShape;\r
-                                        tmp._updateStridesAndCalculator();\r
-                                    }\r
-                                    return tmp;\r
-                                }\r
-                                else {\r
-                                    return this._getBatch(this._parseSignedIndices(arg0), keepDims);\r
-                                }\r
-                            }\r
-                        }\r
-                        else if (arg0 instanceof Function) {\r
-                            var indices = this.hasComplexStorage()\r
-                                ? dataHelper_2.DataHelper.findWithCallbackComplex(this.realData, this.imagData, arg0)\r
-                                : dataHelper_2.DataHelper.findWithCallbackReal(this.realData, arg0);\r
-                            if (doSet) {\r
-                                this._setBatch({\r
-                                    type: 2,\r
-                                    indices: indices\r
-                                }, args[1]);\r
-                            }\r
-                            else {\r
-                                return this._getBatch({\r
-                                    type: 2,\r
-                                    indices: indices\r
-                                }, keepDims);\r
-                            }\r
-                        }\r
-                        else if (typeof arg0 === 'string') {\r
-                            if (doSet) {\r
-                                this._setBatch(this._parseSlicingString(arg0), args[1]);\r
-                            }\r
-                            else {\r
-                                return this._getBatch(this._parseSlicingString(arg0), keepDims);\r
-                            }\r
-                        }\r
-                        else {\r
-                            var i = arg0;\r
-                            if (i < 0) {\r
-                                i += this.size;\r
-                            }\r
-                            if ((i | 0) !== i) {\r
-                                throw new Error('Index should be an integer.');\r
-                            }\r
-                            if (doSet) {\r
-                                var v = args[1];\r
-                                if (v instanceof Tensor) {\r
-                                    if (v.size !== 1) {\r
-                                        throw new Error('Scalar tensor expected.');\r
-                                    }\r
-                                    this.setEl(i, v.getEl(0));\r
-                                }\r
-                                else if (Array.isArray(v)) {\r
-                                    if (v.length !== 1) {\r
-                                        throw new Error('One-element numerical array expected.');\r
-                                    }\r
-                                    this.setEl(i, v[0]);\r
-                                }\r
-                                else {\r
-                                    this.setEl(i, v);\r
-                                }\r
-                            }\r
-                            else {\r
-                                return this.getEl(i);\r
-                            }\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (doSet) {\r
-                            this._setSubTensor(this._parseIndexIterDefs(Array.prototype.slice.call(args, 0, args.length - 1)), args[args.length - 1]);\r
-                        }\r
-                        else {\r
-                            return this._getSubTensor(this._parseIndexIterDefs(args), keepDims);\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype._parseSignedNestedIndexArray = function (arr, shape) {\r
-                    var _this = this;\r
-                    var indices = new Array(shapeHelper_2.ShapeHelper.getSizeFromShape(shape));\r
-                    var strides = shapeHelper_2.ShapeHelper.computeStrides(shape);\r
-                    var _doParse = function (arr, level, offset) {\r
-                        if (level === shape.length - 1) {\r
-                            for (var i = 0; i < shape[level]; i++) {\r
-                                var cur = arr[i];\r
-                                if (cur < 0)\r
-                                    cur += _this.size;\r
-                                _this._checkIndex(cur);\r
-                                indices[offset + i] = cur;\r
-                            }\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < shape[level]; i++) {\r
-                                _doParse(arr[i], level + 1, offset);\r
-                                offset += strides[level];\r
-                            }\r
-                        }\r
-                    };\r
-                    _doParse(arr, 0, 0);\r
-                    return {\r
-                        type: 2,\r
-                        indices: indices\r
-                    };\r
-                };\r
-                Tensor.prototype.setEl = function () {\r
-                    if (arguments.length < 2) {\r
-                        throw new Error('Too few arguments.');\r
-                    }\r
-                    if (arguments.length > this._shape.length + 1) {\r
-                        throw new Error('Too many arguments.');\r
-                    }\r
-                    this.ensureUnsharedLocalStorage();\r
-                    var offset = arguments.length > 2 ? this._offsetCalculator(arguments, this._strides) : arguments[0], v = arguments[arguments.length - 1];\r
-                    if (offset < 0 || offset >= this.size) {\r
-                        throw new Error('Index out of bounds.');\r
-                    }\r
-                    if (v instanceof complexNumber_1.ComplexNumber) {\r
-                        if (this.dtype === 0) {\r
-                            throw new Error('Cannot store complex values in a logic tensor.');\r
-                        }\r
-                        this._re.data[offset] = v.re;\r
-                        if (v.im !== 0) {\r
-                            this.ensureComplexStorage();\r
-                            this._im.data[offset] = v.im;\r
-                        }\r
-                    }\r
-                    else {\r
-                        var nv = typeof v === 'number' ? v : Number(v);\r
-                        if (this.dtype === 0) {\r
-                            this._re.setAsLogicAtUnchecked(offset, nv);\r
-                        }\r
-                        else {\r
-                            this._re.data[offset] = nv;\r
-                        }\r
-                    }\r
-                };\r
-                Tensor.prototype.getEl = function () {\r
-                    var offset;\r
-                    if (arguments.length === 1) {\r
-                        offset = arguments[0];\r
-                    }\r
-                    else if (arguments.length === this._shape.length) {\r
-                        offset = this._offsetCalculator(arguments, this._strides);\r
-                    }\r
-                    else {\r
-                        throw new Error('Incorrect number of arguments.');\r
-                    }\r
-                    this._checkIndex(offset);\r
-                    return this.hasComplexStorage()\r
-                        ? new complexNumber_1.ComplexNumber(this._re.data[offset], this._im.data[offset])\r
-                        : this._re.data[offset];\r
-                };\r
-                Tensor.prototype.ensureUnsharedLocalStorage = function () {\r
-                    if (this._re.refCount > 1) {\r
-                        this._re.refCount--;\r
-                        this._re = this._re.dataCopy();\r
-                        this._re.refCount++;\r
-                    }\r
-                    if (this.hasComplexStorage()) {\r
-                        if (this._im.refCount > 1) {\r
-                            this._im.refCount--;\r
-                            this._im = this._im.dataCopy();\r
-                            this._im.refCount++;\r
-                        }\r
-                    }\r
-                    return this;\r
-                };\r
-                Tensor.prototype.ensureComplexStorage = function () {\r
-                    if (!this.hasComplexStorage()) {\r
-                        if (this.dtype !== 0) {\r
-                            this._im = storage_1.TensorStorage.create(this._re.data.length, this._re.dtype);\r
-                            this._im.refCount++;\r
-                        }\r
-                        else {\r
-                            throw new Error('Logic tensors cannot have a complex storage.');\r
-                        }\r
-                    }\r
-                    return this;\r
-                };\r
-                Tensor.prototype.real = function () {\r
-                    return new Tensor(this._re, storage_1.TensorStorage.Empty, this.shape);\r
-                };\r
-                Tensor.prototype.imag = function () {\r
-                    if (this.hasComplexStorage()) {\r
-                        return new Tensor(this._im, storage_1.TensorStorage.Empty, this.shape);\r
-                    }\r
-                    else {\r
-                        return Tensor.zeros(this._shape, this.dtype);\r
-                    }\r
-                };\r
-                Tensor.prototype.trimImaginaryPart = function () {\r
-                    if (this.hasComplexStorage()) {\r
-                        this._im.refCount--;\r
-                        this._im = storage_1.TensorStorage.Empty;\r
-                    }\r
-                    return this;\r
-                };\r
-                Tensor.prototype.map = function (f) {\r
-                    var n = this.size;\r
-                    var result = new Array(n);\r
-                    if (this.hasComplexStorage()) {\r
-                        for (var i = 0; i < n; i++) {\r
-                            result[i] = f(this._re.data[i], this._im.data[i]);\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (var i = 0; i < n; i++) {\r
-                            result[i] = f(this._re.data[i], 0);\r
-                        }\r
-                    }\r
-                    return result;\r
-                };\r
-                Tensor.prototype.reduce = function (f, initialValue) {\r
-                    var result = initialValue;\r
-                    if (this.hasComplexStorage()) {\r
-                        for (var i = 0, n = this.size; i < n; i++) {\r
-                            result = f(this._re.data[i], this._im.data[i], result);\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (var i = 0, n = this.size; i < n; i++) {\r
-                            result = f(this._re.data[i], 0, result);\r
-                        }\r
-                    }\r
-                    return result;\r
-                };\r
-                Tensor.prototype.prependAxis = function () {\r
-                    this._shape.unshift(1);\r
-                    this._updateStridesAndCalculator();\r
-                    return this;\r
-                };\r
-                Tensor.prototype.appendAxis = function () {\r
-                    this._shape.push(1);\r
-                    this._updateStridesAndCalculator();\r
-                    return this;\r
-                };\r
-                Tensor.prototype.reshape = function (newShape) {\r
-                    this._shape = this._calculateNewShape(newShape);\r
-                    this._updateStridesAndCalculator();\r
-                    return this;\r
-                };\r
-                Tensor.prototype.getReshapedCopy = function (newShape) {\r
-                    newShape = this._calculateNewShape(newShape);\r
-                    return new Tensor(this._re, this._im, newShape);\r
-                };\r
-                Tensor.prototype._calculateNewShape = function (newShape) {\r
-                    newShape = newShape.slice();\r
-                    var idxM1 = -1, ns = 1;\r
-                    for (var i = 0; i < newShape.length; i++) {\r
-                        if ((newShape[i] | 0) !== newShape[i]) {\r
-                            throw new Error('Expecting a 32-bit integer.');\r
-                        }\r
-                        if (newShape[i] === -1) {\r
-                            if (idxM1 >= 0) {\r
-                                throw new Error('Shape can only contain one unknown dimension.');\r
-                            }\r
-                            else {\r
-                                idxM1 = i;\r
-                            }\r
-                        }\r
-                        else {\r
-                            ns *= newShape[i];\r
-                        }\r
-                    }\r
-                    if (idxM1 >= 0) {\r
-                        newShape[idxM1] = this.size / ns;\r
-                        if (!isFinite(newShape[idxM1]) || (newShape[idxM1] | 0) !== newShape[idxM1]) {\r
-                            throw new Error('The inferred length of the unknown dimension is not an integer.');\r
-                        }\r
-                    }\r
-                    else {\r
-                        shapeHelper_2.ShapeHelper.validateShape(newShape);\r
-                        if (ns !== this.size) {\r
-                            throw new Error('The number of elements cannot change after reshaping.');\r
-                        }\r
-                    }\r
-                    return newShape;\r
-                };\r
-                Tensor.prototype.copy = function (copyStorageImmediately) {\r
-                    if (copyStorageImmediately === void 0) { copyStorageImmediately = false; }\r
-                    if (copyStorageImmediately) {\r
-                        return new Tensor(this._re.dataCopy(), this._im !== storage_1.TensorStorage.Empty ? this._im.dataCopy() : storage_1.TensorStorage.Empty, this.shape);\r
-                    }\r
-                    else {\r
-                        return new Tensor(this._re, this._im, this.shape);\r
-                    }\r
-                };\r
-                Tensor.prototype.asType = function (dtype, alwaysCopy) {\r
-                    if (alwaysCopy === void 0) { alwaysCopy = false; }\r
-                    if (dtype === this._re.dtype) {\r
-                        return this.copy(alwaysCopy);\r
-                    }\r
-                    else if (dtype === 0) {\r
-                        if (this.hasComplexStorage()) {\r
-                            throw new Error('Cannot convert a complex tensor to a logic tensor.');\r
-                        }\r
-                        return new Tensor(this._re.copyAsType(0), storage_1.TensorStorage.Empty, this.shape);\r
-                    }\r
-                    else {\r
-                        var re = this._re.copyAsType(dtype), im = this._im === storage_1.TensorStorage.Empty ? storage_1.TensorStorage.Empty : this._im.copyAsType(dtype);\r
-                        return new Tensor(re, im, this.shape);\r
-                    }\r
-                };\r
-                Tensor.prototype.toArray = function (realOnly) {\r
-                    if (realOnly === void 0) { realOnly = false; }\r
-                    var reArr = Tensor._toArray(this._re.data, this._shape, this._strides, 0, 0);\r
-                    if (realOnly) {\r
-                        return reArr;\r
-                    }\r
-                    else {\r
-                        var imArr = this.hasComplexStorage()\r
-                            ? Tensor._toArray(this._im.data, this._shape, this._strides, 0, 0)\r
-                            : [];\r
-                        return [reArr, imArr];\r
-                    }\r
-                };\r
-                Tensor._toArray = function (storage, shape, strides, level, offset) {\r
-                    var arr = new Array(shape[level]);\r
-                    if (level === shape.length - 1) {\r
-                        for (var i = 0; i < shape[level]; i++) {\r
-                            arr[i] = storage[offset + i];\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (var i = 0; i < shape[level]; i++) {\r
-                            arr[i] = Tensor._toArray(storage, shape, strides, level + 1, offset);\r
-                            offset += strides[level];\r
-                        }\r
-                    }\r
-                    return arr;\r
-                };\r
-                Tensor.prototype.toString = function () {\r
-                    var MAX_C = 3;\r
-                    var MAX_R = 4;\r
-                    var str;\r
-                    switch (this.ndim) {\r
-                        case 1:\r
-                            str = "[" + this._elementsToString(0, this.size, 1, MAX_C) + "]";\r
-                            break;\r
-                        case 2:\r
-                            str = '[';\r
-                            if (this._shape[0] <= MAX_R + MAX_R) {\r
-                                for (var i = 0; i < this._shape[0]; i++) {\r
-                                    str += "[" + this._elementsToString(i * this._shape[1], this._shape[1], 1, MAX_C) + "]";\r
-                                    if (i !== this._shape[0] - 1) {\r
-                                        str += ',\n ';\r
-                                    }\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (var i = 0; i < MAX_R; i++) {\r
-                                    str += "[" + this._elementsToString(i * this._shape[1], this._shape[1], 1, MAX_C) + "],\n ";\r
-                                }\r
-                                str += '...\n ';\r
-                                for (var i = this._shape[0] - MAX_R; i < this._shape[0]; i++) {\r
-                                    str += "[" + this._elementsToString(i * this._shape[1], this._shape[1], 1, MAX_C) + "]";\r
-                                    if (i !== this._shape[0] - 1) {\r
-                                        str += ',\n ';\r
-                                    }\r
-                                }\r
-                            }\r
-                            str += ']';\r
-                            break;\r
-                        default:\r
-                            var strComplex = this.hasComplexStorage() ? 'complex ' : '';\r
-                            str = "[" + this._shape.join('x') + " " + dtype_1.DTypeHelper.dTypeToString(this.dtype) + " " + strComplex + " tensor]";\r
-                    }\r
-                    return str;\r
-                };\r
-                Tensor.prototype._elementsToString = function (offset, count, stride, max) {\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (max === void 0) { max = 2; }\r
-                    var parts = [];\r
-                    if (count <= max + max) {\r
-                        for (var i = 0; i < count; i++) {\r
-                            parts.push(this._elementToString(offset + i * stride));\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (var i = 0; i < max; i++) {\r
-                            parts.push(this._elementToString(offset + i * stride));\r
-                        }\r
-                        parts.push('...');\r
-                        for (var i = count - max; i < count; i++) {\r
-                            parts.push(this._elementToString(offset + i * stride));\r
-                        }\r
-                    }\r
-                    return parts.join(', ');\r
-                };\r
-                Tensor.prototype._elementToString = function (offset) {\r
-                    var re = this._re.data[offset];\r
-                    if (this.dtype === 0) {\r
-                        return re !== 0 ? ' true' : 'false';\r
-                    }\r
-                    else {\r
-                        var str = re >= 0 ? ' ' : '';\r
-                        if (this.hasComplexStorage()) {\r
-                            var im = this._im.data[offset];\r
-                            if (this.dtype === 1) {\r
-                                str += re.toString() + " " + (im >= 0 ? '+' : '-') + Math.abs(im).toString() + "j";\r
-                            }\r
-                            else {\r
-                                str += re.toExponential(4) + " " + (im >= 0 ? '+' : '-') + " " + Math.abs(im).toExponential(4) + "j";\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (this.dtype === 1) {\r
-                                str += re.toString();\r
-                            }\r
-                            else {\r
-                                str += re.toExponential(4);\r
-                            }\r
-                        }\r
-                        return str;\r
-                    }\r
-                };\r
-                Tensor.ZERO = Tensor.zeros([1]);\r
-                return Tensor;\r
-            }());\r
-            exports_8("Tensor", Tensor);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/commonTypes", [], function (exports_9, context_9) {\r
-    "use strict";\r
-    var __moduleName = context_9 && context_9.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            ;\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/helper/objHelper", [], function (exports_10, context_10) {\r
-    "use strict";\r
-    var __moduleName = context_10 && context_10.id;\r
-    var HAS_TYPED_ARRAY_SUPPORT, ExtendChain, ObjectHelper;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            HAS_TYPED_ARRAY_SUPPORT = Float64Array && (typeof Float64Array === 'function');\r
-            ExtendChain = (function () {\r
-                function ExtendChain(src) {\r
-                    this._obj = src;\r
-                }\r
-                ExtendChain.prototype.extend = function (ext) {\r
-                    return new ExtendChain(ObjectHelper.extend(this._obj, ext));\r
-                };\r
-                ExtendChain.prototype.end = function () {\r
-                    return this._obj;\r
-                };\r
-                return ExtendChain;\r
-            }());\r
-            exports_10("ExtendChain", ExtendChain);\r
-            ObjectHelper = (function () {\r
-                function ObjectHelper() {\r
-                }\r
-                ObjectHelper.hasTypedArraySupport = function () {\r
-                    return HAS_TYPED_ARRAY_SUPPORT;\r
-                };\r
-                ObjectHelper.isTypedArray = function (x) {\r
-                    if (!HAS_TYPED_ARRAY_SUPPORT) {\r
-                        return false;\r
-                    }\r
-                    return (x instanceof Float64Array) ||\r
-                        (x instanceof Float32Array) ||\r
-                        (x instanceof Int32Array) ||\r
-                        (x instanceof Int16Array) ||\r
-                        (x instanceof Int8Array) ||\r
-                        (x instanceof Uint8Array) ||\r
-                        (x instanceof Uint16Array) ||\r
-                        (x instanceof Uint32Array) ||\r
-                        (x instanceof Uint8ClampedArray);\r
-                };\r
-                ObjectHelper.extend = function (src, ext) {\r
-                    for (var prop in ext) {\r
-                        if (ext.hasOwnProperty(prop)) {\r
-                            src[prop] = ext[prop];\r
-                        }\r
-                    }\r
-                    return src;\r
-                };\r
-                ObjectHelper.createExtendChain = function (src) {\r
-                    return new ExtendChain(src);\r
-                };\r
-                ObjectHelper.properties = function (obj) {\r
-                    var result = [];\r
-                    for (var prop in obj) {\r
-                        if (obj.hasOwnProperty(prop)) {\r
-                            result.push(prop);\r
-                        }\r
-                    }\r
-                    return result;\r
-                };\r
-                return ObjectHelper;\r
-            }());\r
-            exports_10("ObjectHelper", ObjectHelper);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/dtype", ["jasmal/lib/helper/objHelper"], function (exports_11, context_11) {\r
-    "use strict";\r
-    var __moduleName = context_11 && context_11.id;\r
-    var objHelper_5, DTypeHelper, OutputDTypeResolver;\r
-    return {\r
-        setters: [\r
-            function (objHelper_5_1) {\r
-                objHelper_5 = objHelper_5_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            DTypeHelper = (function () {\r
-                function DTypeHelper() {\r
-                }\r
-                DTypeHelper.dTypeToString = function (dtype) {\r
-                    switch (dtype) {\r
-                        case 0: return 'logic';\r
-                        case 1: return 'int32';\r
-                        case 3: return 'float64';\r
-                        default: return 'unknown';\r
-                    }\r
-                };\r
-                DTypeHelper.isWiderType = function (original, newType) {\r
-                    return newType > original;\r
-                };\r
-                DTypeHelper.getWiderType = function (t1, t2) {\r
-                    return t1 > t2 ? t1 : t2;\r
-                };\r
-                DTypeHelper.getDTypeOfIndices = function () {\r
-                    return objHelper_5.ObjectHelper.hasTypedArraySupport() ? 1 : 3;\r
-                };\r
-                return DTypeHelper;\r
-            }());\r
-            exports_11("DTypeHelper", DTypeHelper);\r
-            OutputDTypeResolver = (function () {\r
-                function OutputDTypeResolver() {\r
-                }\r
-                OutputDTypeResolver.uNoChange = function (t) {\r
-                    return t;\r
-                };\r
-                OutputDTypeResolver.uToLogic = function () {\r
-                    return 0;\r
-                };\r
-                OutputDTypeResolver.uToInt32 = function () {\r
-                    return 1;\r
-                };\r
-                OutputDTypeResolver.uToFloat = function () {\r
-                    return 3;\r
-                };\r
-                OutputDTypeResolver.uToLogicRealOnly = function (_t, isComplex) {\r
-                    return isComplex ? undefined : 0;\r
-                };\r
-                OutputDTypeResolver.uOnlyLogicToFloat = function (t, _isComplex) {\r
-                    return t === 0 ? 3 : t;\r
-                };\r
-                OutputDTypeResolver.uNoChangeExceptLogicToInt = function (t) {\r
-                    return t === 0 ? 1 : t;\r
-                };\r
-                OutputDTypeResolver.bWider = function (t1, _isComplex1, t2, _isComplex2) {\r
-                    return DTypeHelper.getWiderType(t1, t2);\r
-                };\r
-                OutputDTypeResolver.bWiderWithLogicToInt = function (t1, _isComplex1, t2, _isComplex2) {\r
-                    return DTypeHelper.getWiderType(t1 === 0 ? 1 : t1, t2 === 0 ? 1 : t2);\r
-                };\r
-                OutputDTypeResolver.bToInt32 = function () {\r
-                    return 1;\r
-                };\r
-                OutputDTypeResolver.bToFloat = function () {\r
-                    return 3;\r
-                };\r
-                OutputDTypeResolver.bToLogic = function () {\r
-                    return 0;\r
-                };\r
-                OutputDTypeResolver.bToLogicRealOnly = function (_t1, isComplex1, _t2, isComplex2) {\r
-                    return (isComplex1 || isComplex2) ? undefined : 0;\r
-                };\r
-                return OutputDTypeResolver;\r
-            }());\r
-            exports_11("OutputDTypeResolver", OutputDTypeResolver);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/random/engine", [], function (exports_12, context_12) {\r
-    "use strict";\r
-    var __moduleName = context_12 && context_12.id;\r
-    var mulUint32, MT19937Engine, NativeEngine;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            mulUint32 = Math.imul instanceof Function\r
-                ? function (x, y) { return Math.imul(x, y) >>> 0; }\r
-                : function (x, y) {\r
-                    var ah = (x >>> 16) & 0xffff, al = x & 0xffff, bh = (y >>> 16) & 0xffff, bl = y & 0xffff;\r
-                    var high = (ah * bl + al * bh) & 0xffff;\r
-                    return (((high << 16) >>> 0) + (al * bl)) >>> 0;\r
-                };\r
-            MT19937Engine = (function () {\r
-                function MT19937Engine() {\r
-                    this._mt = new Array(624);\r
-                    this._mti = 625;\r
-                }\r
-                MT19937Engine.prototype.setSeed = function (x) {\r
-                    this._seed = x >>> 0;\r
-                    this._mt[0] = this._seed;\r
-                    for (this._mti = 1; this._mti < 624; this._mti++) {\r
-                        var d = this._mt[this._mti - 1] ^ (this._mt[this._mti - 1] >>> 30);\r
-                        this._mt[this._mti] = (mulUint32(d, 1812433253) + this._mti) >>> 0;\r
-                    }\r
-                    return this;\r
-                };\r
-                MT19937Engine.prototype.getSeed = function () {\r
-                    return this._seed;\r
-                };\r
-                MT19937Engine.prototype.nextUint32 = function () {\r
-                    var mag01 = [0, 0x9908b0df];\r
-                    var y;\r
-                    if (this._mti >= 624) {\r
-                        if (this._mti === 625) {\r
-                            this.setSeed(5489);\r
-                        }\r
-                        var kk = 0;\r
-                        for (; kk < 624 - 397; kk++) {\r
-                            y = (this._mt[kk] & 0x80000000) | (this._mt[kk + 1] & 0x7fffffff);\r
-                            this._mt[kk] = this._mt[kk + 397] ^ (y >>> 1) ^ mag01[y & 0x01];\r
-                        }\r
-                        for (; kk < 623; kk++) {\r
-                            y = (this._mt[kk] & 0x80000000) | (this._mt[kk + 1] & 0x7fffffff);\r
-                            this._mt[kk] = this._mt[kk + 397 - 624] ^ (y >>> 1) ^ mag01[y & 0x01];\r
-                        }\r
-                        y = (this._mt[623] & 0x80000000) | (this._mt[0] & 0x7fffffff);\r
-                        this._mt[623] = this._mt[396] ^ (y >>> 1) ^ mag01[y & 0x01];\r
-                        this._mti = 0;\r
-                    }\r
-                    y = this._mt[this._mti++];\r
-                    y ^= (y >>> 11);\r
-                    y ^= (y << 7) & 0x9d2c5680;\r
-                    y ^= (y << 15) & 0xefc60000;\r
-                    y ^= (y >>> 18);\r
-                    return y >>> 0;\r
-                };\r
-                MT19937Engine.prototype.nextDouble = function () {\r
-                    var a, b;\r
-                    do {\r
-                        a = this.nextUint32() >>> 5;\r
-                        b = this.nextUint32() >>> 6;\r
-                    } while (a === 0 && b === 0);\r
-                    return (a * 67108864.0 + b) * (1.0 / 9007199254740992);\r
-                };\r
-                return MT19937Engine;\r
-            }());\r
-            exports_12("MT19937Engine", MT19937Engine);\r
-            NativeEngine = (function () {\r
-                function NativeEngine() {\r
-                }\r
-                NativeEngine.prototype.setSeed = function (_x) {\r
-                    throw new Error('Seeding is not supported with the native random engine.');\r
-                };\r
-                NativeEngine.prototype.getSeed = function () {\r
-                    throw new Error('Seeding is not supported with the native random engine.');\r
-                };\r
-                NativeEngine.prototype.nextDouble = function () {\r
-                    var x;\r
-                    do {\r
-                        x = Math.random();\r
-                    } while (x === 0);\r
-                    return x;\r
-                };\r
-                NativeEngine.prototype.nextUint32 = function () {\r
-                    return Math.floor(this.nextDouble() * 4294967296);\r
-                };\r
-                return NativeEngine;\r
-            }());\r
-            exports_12("NativeEngine", NativeEngine);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/core/definition", [], function (exports_13, context_13) {\r
-    "use strict";\r
-    var __moduleName = context_13 && context_13.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/arithmetic/definition", [], function (exports_14, context_14) {\r
-    "use strict";\r
-    var __moduleName = context_14 && context_14.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/random/definition", [], function (exports_15, context_15) {\r
-    "use strict";\r
-    var __moduleName = context_15 && context_15.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/definition", [], function (exports_16, context_16) {\r
-    "use strict";\r
-    var __moduleName = context_16 && context_16.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/templateEngine", [], function (exports_17, context_17) {\r
-    "use strict";\r
-    var __moduleName = context_17 && context_17.id;\r
-    var TemplateEngine;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            TemplateEngine = (function () {\r
-                function TemplateEngine() {\r
-                    this._cache = {};\r
-                }\r
-                TemplateEngine.prototype.generate = function (template, symbolMap, config) {\r
-                    if (!this._cache[template]) {\r
-                        this._cache[template] = this.createFunction(template);\r
-                    }\r
-                    var gen = this._cache[template];\r
-                    return gen(symbolMap, config);\r
-                };\r
-                TemplateEngine.prototype.createFunction = function (template) {\r
-                    var condReg = /^[ \t]*#(if(?:not)?|endif|else(?:if)?)([ \t]+.*)?$/gm;\r
-                    var tokens = [];\r
-                    var idx = 0;\r
-                    while (idx < template.length) {\r
-                        var match = condReg.exec(template);\r
-                        if (match) {\r
-                            if (match.index > idx) {\r
-                                tokens.push({\r
-                                    type: 0,\r
-                                    value: TemplateEngine._sanitize(template.slice(idx, match.index))\r
-                                });\r
-                            }\r
-                            switch (match[1]) {\r
-                                case 'if':\r
-                                    if (!match[2]) {\r
-                                        throw new Error('Missing condition after if.');\r
-                                    }\r
-                                    tokens.push({\r
-                                        type: 1,\r
-                                        value: match[2].trim()\r
-                                    });\r
-                                    break;\r
-                                case 'else':\r
-                                    if (match[2]) {\r
-                                        throw new Error('Unexpected condition after else.');\r
-                                    }\r
-                                    tokens.push({\r
-                                        type: 2,\r
-                                        value: ''\r
-                                    });\r
-                                    break;\r
-                                case 'elseif':\r
-                                    if (!match[2]) {\r
-                                        throw new Error('Missing condition after elseif.');\r
-                                    }\r
-                                    tokens.push({\r
-                                        type: 3,\r
-                                        value: match[2].trim()\r
-                                    });\r
-                                    break;\r
-                                case 'ifnot':\r
-                                    if (!match[2]) {\r
-                                        throw new Error('Missing condition after ifnot.');\r
-                                    }\r
-                                    tokens.push({\r
-                                        type: 5,\r
-                                        value: match[2].trim()\r
-                                    });\r
-                                    break;\r
-                                case 'endif':\r
-                                    if (match[2]) {\r
-                                        throw new Error('Unexpected condition after endif.');\r
-                                    }\r
-                                    tokens.push({\r
-                                        type: 4,\r
-                                        value: ''\r
-                                    });\r
-                                    break;\r
-                                default:\r
-                                    throw new Error("Unknown keyword '" + match[1] + "'.");\r
-                            }\r
-                            idx = match.index + match[0].length;\r
-                            while (idx < template.length && (template[idx] === '\r' || template[idx] === '\n')) {\r
-                                idx++;\r
-                            }\r
-                        }\r
-                        else {\r
-                            break;\r
-                        }\r
-                    }\r
-                    if (idx < template.length) {\r
-                        tokens.push({\r
-                            type: 0,\r
-                            value: TemplateEngine._sanitize(template.slice(idx, template.length))\r
-                        });\r
-                    }\r
-                    var balanceCounter = 0;\r
-                    var funcBody = "var result = '';\n";\r
-                    for (var i = 0; i < tokens.length; i++) {\r
-                        switch (tokens[i].type) {\r
-                            case 0:\r
-                                funcBody += "result += '" + tokens[i].value + "';\n";\r
-                                break;\r
-                            case 1:\r
-                                funcBody += "if (" + TemplateEngine._expandConditions(tokens[i].value) + ") {\n";\r
-                                balanceCounter++;\r
-                                break;\r
-                            case 5:\r
-                                funcBody += "if (!(" + TemplateEngine._expandConditions(tokens[i].value) + ")) {\n";\r
-                                balanceCounter++;\r
-                                break;\r
-                            case 2:\r
-                                funcBody += "} else {\n";\r
-                                break;\r
-                            case 3:\r
-                                funcBody += "} else if (" + TemplateEngine._expandConditions(tokens[i].value) + ") {\n";\r
-                                break;\r
-                            case 4:\r
-                                funcBody += '}\n';\r
-                                balanceCounter--;\r
-                                break;\r
-                            default:\r
-                                throw new Error("Unexpected token type " + tokens[i].type + ".");\r
-                        }\r
-                    }\r
-                    funcBody += 'return result;';\r
-                    if (balanceCounter !== 0) {\r
-                        throw new Error('Unbalanced if and endif statements.');\r
-                    }\r
-                    var templateFunc = new Function('config', funcBody);\r
-                    return function (symbolMap, config) {\r
-                        return TemplateEngine._interpolate(templateFunc(config), symbolMap);\r
-                    };\r
-                };\r
-                TemplateEngine._expandConditions = function (str) {\r
-                    return str.replace(/\w+/g, function (m) { return "config." + m; });\r
-                };\r
-                TemplateEngine._sanitize = function (str) {\r
-                    return str.replace(/\\/g, '\\\\').replace(/'/g, '\\\'').replace(/(\r\n)|\r|\n/g, '\\n');\r
-                };\r
-                TemplateEngine._interpolate = function (template, replacementMap) {\r
-                    return template.replace(/\$\w+/g, function (m, offset) {\r
-                        var standalone = true;\r
-                        var pos = offset - 1;\r
-                        var indent = 0;\r
-                        while (pos >= 0) {\r
-                            if (template[pos] === '\n') {\r
-                                break;\r
-                            }\r
-                            if (template[pos] !== ' ') {\r
-                                standalone = false;\r
-                                break;\r
-                            }\r
-                            indent++;\r
-                            pos--;\r
-                        }\r
-                        if (standalone) {\r
-                            pos = offset + m.length;\r
-                            while (pos < template.length) {\r
-                                if (template[pos] === '\n') {\r
-                                    break;\r
-                                }\r
-                                if (template[pos] !== ' ') {\r
-                                    standalone = false;\r
-                                }\r
-                                pos++;\r
-                            }\r
-                        }\r
-                        var replacement = replacementMap[m];\r
-                        if (replacement != undefined) {\r
-                            return standalone ? TemplateEngine._indent(replacement, indent, false) : replacement;\r
-                        }\r
-                        else {\r
-                            return m;\r
-                        }\r
-                    });\r
-                };\r
-                TemplateEngine._indent = function (str, indentSize, indentFirstLine) {\r
-                    if (indentFirstLine === void 0) { indentFirstLine = true; }\r
-                    var spaces = (new Array(indentSize + 1)).join(' ');\r
-                    var result = str.replace(/(\r?\n)/g, '$1' + spaces);\r
-                    return indentFirstLine ? spaces + result : result;\r
-                };\r
-                return TemplateEngine;\r
-            }());\r
-            exports_17("TemplateEngine", TemplateEngine);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/generatorBase", ["jasmal/lib/ops/generator/templateEngine"], function (exports_18, context_18) {\r
-    "use strict";\r
-    var __moduleName = context_18 && context_18.id;\r
-    var templateEngine_1, OpGeneratorBase;\r
-    return {\r
-        setters: [\r
-            function (templateEngine_1_1) {\r
-                templateEngine_1 = templateEngine_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            OpGeneratorBase = (function () {\r
-                function OpGeneratorBase() {\r
-                    this.DEP_OBJ_NAME = '__dep__';\r
-                    this._engine = new templateEngine_1.TemplateEngine();\r
-                }\r
-                OpGeneratorBase.prototype._checkUsedSymbols = function (code, allowed) {\r
-                    var reSymbol = /\$\w+/g;\r
-                    var m;\r
-                    var used = {};\r
-                    while (m = reSymbol.exec(code)) {\r
-                        if (allowed.indexOf(m[0]) < 0) {\r
-                            throw new Error("Symbol " + m[0] + " is not permitted in the following code:\n" + code);\r
-                        }\r
-                        used[m[0]] = true;\r
-                    }\r
-                    var result = [];\r
-                    for (var prop in used) {\r
-                        if (used.hasOwnProperty(prop)) {\r
-                            result.push(prop);\r
-                        }\r
-                    }\r
-                    return result;\r
-                };\r
-                OpGeneratorBase.prototype._flattenInlineFunctions = function (fs) {\r
-                    var result = '';\r
-                    for (var key in fs) {\r
-                        if (fs.hasOwnProperty(key)) {\r
-                            var fStr = fs[key].toString();\r
-                            if (fStr.indexOf('[native code]') > 0) {\r
-                                throw new Error('Cannot inline native functions.');\r
-                            }\r
-                            var idxFirstP = fStr.indexOf('(');\r
-                            if (idxFirstP < 0) {\r
-                                throw new Error('Cannot find the first pair of parenthesis.');\r
-                            }\r
-                            fStr = 'function ' + key + fStr.substr(idxFirstP);\r
-                            result += fStr + '\n';\r
-                        }\r
-                    }\r
-                    return result;\r
-                };\r
-                OpGeneratorBase.prototype._generateDependencyBlock = function (depNames) {\r
-                    var _this = this;\r
-                    return depNames.map(function (x) { return "var " + x + " = " + _this.DEP_OBJ_NAME + "." + x + ";"; }).join('\n');\r
-                };\r
-                return OpGeneratorBase;\r
-            }());\r
-            exports_18("OpGeneratorBase", OpGeneratorBase);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/el/unaryOpTemplates", [], function (exports_19, context_19) {\r
-    "use strict";\r
-    var __moduleName = context_19 && context_19.id;\r
-    var UNARY_OP_TEMPLATE, S_BLOCK_TEMPLATE, T_BLOCK_TEMPLATE;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            exports_19("UNARY_OP_TEMPLATE", UNARY_OP_TEMPLATE = "'use strict';\n$Dependencies\n#if HAS_PARAM\nreturn function(x, param, inPlace) {\n#else\nreturn function(x, inPlace) {\n#endif\n    inPlace = inPlace || false;\n    // we accept OpInputInfo as an input \n    var infoX;\n    if (x['originalType'] != undefined) {\n        infoX = x;\n        x = infoX.originalInput;\n    } else {\n        infoX = Tensor.analyzeOpInput(x)\n    }\n    if (infoX.originalType === " + 4 + ") {\n        throw new Error('Unsupported input type.');\n    }\n    #if NO_IN_PLACE\n    if (inPlace) {\n        throw new Error('In-place operation is not supported.');\n    }\n    #else\n    if (inPlace && infoX.originalType !== " + 3 + ") {\n        throw new Error('Cannot perform in-place operations when the operand is not a tensor.');\n    }\n    #endif\n    #if NO_COMPLEX_INPUT\n    if (infoX.isComplex) {\n        throw new Error('Complex input is not supported.');\n    }\n    #endif\n    var dtypeX = infoX.originalDType, dtypeY;\n    var reX = infoX.reArr, imX = infoX.imArr, reY, imY, tmp1, tmp2, tmp3, tmp4, y;\n    var i = 0;\n    dtypeY = outputDTypeResolver(dtypeX, infoX.isComplex);\n    if (dtypeY == undefined) {\n        throw new Error('The operation on ' + DTypeHelper.dTypeToString(dtypeX) + ' is not available.');\n    }\n    if (infoX.isInputScalar) {\n        var reXScalar = infoX.re, imXScalar = infoX.im;\n        var reYScalar = 0, imYScalar = 0;\n        $SBlock\n        return imYScalar === 0 ? reYScalar : new ComplexNumber(reYScalar, imYScalar);\n    } else {\n        if (inPlace) {\n            if (DTypeHelper.isWiderType(dtypeX, dtypeY)) {\n                throw new Error('Cannot perform in-place operations for data type ' + DTypeHelper.dTypeToString(dtypeX) + '.');\n            }\n            y = x;\n            y.ensureUnsharedLocalStorage();\n        } else {\n            y = Tensor.zeros(infoX.originalShape, dtypeY);\n        }\n        $TBlock\n        return y;\n    }\n}");\r
-            exports_19("S_BLOCK_TEMPLATE", S_BLOCK_TEMPLATE = "#if NO_COMPLEX_INPUT\n$RBlock\n#else\nif (infoX.isComplex) {\n    $CBlock\n} else {\n    $RBlock\n}\n#endif");\r
-            exports_19("T_BLOCK_TEMPLATE", T_BLOCK_TEMPLATE = "#if NO_COMPLEX_INPUT\nreY = y.realData;\n#if OUTPUT_R_COMPLEX\ny.ensureComplexStorage();\nimY = y.imagData;\n#endif\nfor (i = 0;i < reY.length;i++) {\n    $RBlock\n}\n#else\nif (infoX.isComplex) {\n    reY = y.realData;\n#if OUTPUT_C_COMPLEX\n    y.ensureComplexStorage();\n    imY = y.imagData;\n#endif\n    for (i = 0;i < reY.length;i++) {\n        $CBlock\n    }\n#ifnot OUTPUT_C_COMPLEX\n    // in place operation for a complex tensor but output is real\n    // we need set imaginary part to 0\n    if (inPlace) {\n        imY = imY || y.imagData;\n        for (i = 0;i < imY.length;i++) {\n            imY[i] = 0;\n        }\n    } \n#endif\n} else {\n    reY = y.realData;\n#if OUTPUT_R_COMPLEX\n    y.ensureComplexStorage();\n    imY = y.imagData;\n#endif\n    for (i = 0;i < reY.length;i++) {\n        $RBlock\n    }\n}\n#endif");\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/el/binaryOpTemplates", [], function (exports_20, context_20) {\r
-    "use strict";\r
-    var __moduleName = context_20 && context_20.id;\r
-    var BIN_EL_OP_TEMPLATE, SS_BLOCK_TEMPLATE, ST_BLOCK_TEMPLATE, TS_BLOCK_TEMPLATE, TT_BLOCK_TEMPLATE, TT_NORMAL_BLOCK_TEMPLATE, TT_BROADCAST_BLOCK_TEMPLATE, TT_BROADCAST_SUB_BLOCK_TEMPLATE;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            exports_20("BIN_EL_OP_TEMPLATE", BIN_EL_OP_TEMPLATE = "'use strict';\n$Dependencies\n$InlineFunctions\nreturn function (x, y, inPlace) {\n    // process inputs\n    inPlace = inPlace || false;\n    // init common variables\n    var infoX, infoY;\n    if (x['originalType'] != undefined) {\n        infoX = x;\n        x = infoX.originalInput;\n    } else {\n        infoX = Tensor.analyzeOpInput(x);\n    }\n    if (y['originalType'] != undefined) {\n        infoY = y;\n        y = infoY.originalInput;\n    } else {\n        infoY = Tensor.analyzeOpInput(y);\n    }\n    if (infoX.originalType === " + 4 + " || infoY.originalType === " + 4 + ") {\n        throw new Error('Unsupported input type.');\n    }\n    #if NO_IN_PLACE\n    if (inPlace) {\n        throw new Error('In-place operation is not supported.');\n    }\n    #else\n    if (inPlace && infoX.originalType !== " + 3 + ") {\n        throw new Error('In-place operation is not allowed when the first operand is not a tensor.');\n    }\n    #endif\n    #if NO_COMPLEX_INPUT\n    if (infoX.isComplex) {\n        throw new Error('Complex input is not allowed.');\n    }\n    if (infoY.isComplex) {\n        throw new Error('Complex input is not allowed.');\n    }\n    #endif\n    var isXScalar = infoX.isInputScalar;\n    var isYScalar = infoY.isInputScalar;\n    var shouldOutputTensor = !isXScalar || !isYScalar;\n    var dtypeX = infoX.originalDType, dtypeY = infoY.originalDType, dtypeZ;\n    var reXScalar = infoX.re, imXScalar = infoX.im, reYScalar = infoY.re, imYScalar = infoY.im;\n    var reZScalar = 0, imZScalar = 0;\n    var reX = infoX.reArr, imX = infoX.imArr, reY = infoY.reArr, imY = infoY.imArr;\n    var reZ, imZ, tmp1, tmp2, tmp3, tmp4, z, s;\n    var i = 0;\n    // check dtype\n    dtypeZ = outputDTypeResolver(dtypeX, infoX.isComplex, dtypeY, infoY.isComplex);\n    if (dtypeZ == undefined) {\n        throw new Error('Operation between ' + DTypeHelper.dTypeToString(dtypeX) + ' and ' \n            + DTypeHelper.dTypeToString(dtypeY) + ' is not available.');\n    }\n    // main procedure\n    if (isXScalar) {\n        if (isYScalar) {\n            \n            $SSBlock\n        } else {\n            $STBlock\n        }\n    } else {\n#ifnot NO_IN_PLACE\n        if (inPlace && DTypeHelper.isWiderType(dtypeX, dtypeZ)) {\n            throw new Error('Cannot downcast from ' + DTypeHelper.dTypeToString(dtypeY) + ' to ' +\n                DTypeHelper.dTypeToString(dtypeX) + ' when performing in-place operation.');\n        }\n#endif\n        if (isYScalar) {\n            $TSBlock\n        } else {\n            $TTBlock\n        }\n    }\n    return z;\n}");\r
-            exports_20("SS_BLOCK_TEMPLATE", SS_BLOCK_TEMPLATE = "// reX, imX, reY, imY have already been set when processing inputs\n#if NO_COMPLEX_INPUT\n$RRBlock\n#else\nif (infoX.isComplex) {\n    if (infoY.isComplex) {\n        $CCBlock\n    } else {\n        $CRBlock\n    }\n} else {\n    if (infoY.isComplex) {\n        $RCBlock\n    } else {\n        $RRBlock\n    }\n}\n#endif\nz = imZScalar === 0 ? reZScalar : new ComplexNumber(reZScalar, imZScalar);");\r
-            exports_20("ST_BLOCK_TEMPLATE", ST_BLOCK_TEMPLATE = "// reX, imX, reY, imY have already been set when processing inputs\n#if NO_IN_PLACE\n#else\nif (inPlace) {\n    throw new Error('In-place operation cannot be performed because the output shape is different from that of the first operand.')\n}\n#endif\nz = Tensor.zeros(infoY.originalShape, dtypeZ);\nreZ = z.realData;\n#if NO_COMPLEX_INPUT\n#if OUTPUT_RR_COMPLEX\nz.ensureComplexStorage();\nimZ = z.imagData;\n#endif\nfor (i = 0;i < reZ.length;i++) {\n    // reX, reY[] -> reZ[], imZ[]?\n    $RRBlock\n}\n#else\nif (infoX.isComplex) {\n    if (infoY.isComplex) {  \n#if OUTPUT_CC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX, imX, reY[], imY[] -> reZ[], imZ[]?\n            $CCBlock\n        }\n    } else {\n#if OUTPUT_CR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX, imX, reY[] -> reZ[], imZ[]?\n            $CRBlock\n        }\n    }\n} else {\n    if (infoY.isComplex) {\n#if OUTPUT_RC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX, reY[], imY[] -> reZ[], imZ[]?\n            $RCBlock\n        }\n    } else {\n#if OUTPUT_RR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX, reY[] -> reZ[], imZ[]?\n            $RRBlock\n        }\n    }\n}\n#endif");\r
-            exports_20("TS_BLOCK_TEMPLATE", TS_BLOCK_TEMPLATE = "// reX, imX, reY, imY have already been set when processing inputs\n#if NO_IN_PLACE\nz = Tensor.zeros(infoX.originalShape, dtypeZ);\n#else\nif (inPlace) {\n    z = x;\n    z.ensureUnsharedLocalStorage();\n} else {\n    z = Tensor.zeros(infoX.originalShape, dtypeZ);\n}\n#endif\nreZ = z.realData;\n#if NO_COMPLEX_INPUT\n#if OUTPUT_RR_COMPLEX\nz.ensureComplexStorage();\nimZ = z.imagData;\n#endif\nfor (i = 0;i < reZ.length;i++) {\n    // reX[], reY -> reZ[], imZ[]?\n    $RRBlock\n}\n#else\nif (infoY.isComplex) {\n    if (infoX.isComplex) {\n#if OUTPUT_CC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], imX[], reY, imY -> reZ[], imZ[]?\n            $CCBlock\n        }\n#if !NO_IN_PLACE && !OUTPUT_CC_COMPLEX\n        if (inPlace) {\n            imZ = imZ || z.imagData;\n            for (i = 0;i < imZ.length;i++) {\n                imZ[i] = 0;\n            }\n        }\n#endif\n    } else {\n#if OUTPUT_RC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], reY, imY -> reZ[], imZ[]?\n            $RCBlock\n        }\n    }\n} else {\n    if (infoX.isComplex) {\n#if OUTPUT_CR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], imX[], reY -> reZ[], imZ[]?\n            $CRBlock\n        }\n#if !NO_IN_PLACE && !OUTPUT_CR_COMPLEX\n        if (inPlace) {\n            imZ = imZ || z.imagData;\n            for (i = 0;i < imZ.length;i++) {\n                imZ[i] = 0;\n            }\n        }\n#endif\n    } else {\n#if OUTPUT_RR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], reY -> reZ[], imZ[]?\n            $RRBlock\n        }\n    }\n}\n#endif");\r
-            exports_20("TT_BLOCK_TEMPLATE", TT_BLOCK_TEMPLATE = "var results, shapeX, shapeY, shapeZ;\nresults = ShapeHelper.checkBroadcastingCompatibility(infoX.originalShape, infoY.originalShape);\nshapeX = results.shapeX;\nshapeY = results.shapeY;\nshapeZ = results.shapeZ;\nif (results.exact) {\n#if NO_IN_PLACE\n    z = Tensor.zeros(shapeZ, dtypeZ);\n#else\n    if (inPlace) {\n        z = x;\n        z.ensureUnsharedLocalStorage();\n    } else {\n        z = Tensor.zeros(shapeZ, dtypeZ);\n    }\n#endif\n    $TTNormalBlock\n} else {\n#if NO_IN_PLACE\n    z = Tensor.zeros(shapeZ, dtypeZ);\n#else\n    if (inPlace) {\n        if (!ShapeHelper.compareShape(shapeX, shapeZ)) {\n            throw new Error('Cannot perform in-place operations when the output shape different from that of the first operand.');\n        }\n        z = x;\n        z.ensureUnsharedLocalStorage();\n    } else {\n        z = Tensor.zeros(shapeZ, dtypeZ);\n    }\n#endif\n    $TTBroadcastBlock\n}");\r
-            exports_20("TT_NORMAL_BLOCK_TEMPLATE", TT_NORMAL_BLOCK_TEMPLATE = "reZ = z.realData;\n#if NO_COMPLEX_INPUT\n#if OUTPUT_RR_COMPLEX\nz.ensureComplexStorage();\nimZ = z.imagData;\n#endif\nfor (i = 0;i < reZ.length;i++) {\n    // reX[], reY[] -> reZ[], imZ[]?\n    $RRBlock\n}\n#else\nif (infoX.isComplex) {\n    reZ = z.realData;\n    if (infoY.isComplex) {\n#if OUTPUT_CC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], imX[], reY[], imY[] -> reZ[], imZ[]?\n            $CCBlock\n        }\n    } else {\n#if OUTPUT_CR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        reY = y.realData;\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], imX[], reY[] -> reZ[], imZ[]?\n            $CRBlock\n        }\n    }\n#if !NO_IN_PLACE && (!OUTPUT_CC_COMPLEX || !OUTPUT_CR_COMPLEX)\n    if (inPlace) {\n        imZ = imZ || z.imagData;\n        for (i = 0;i < imZ.length;i++) {\n            imZ[i] = 0;\n        }\n    }\n#endif\n} else {\n    if (infoY.isComplex) {\n#if OUTPUT_RC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], reY[], imY[] -> reZ[], imZ[]?\n            $RCBlock\n        }\n    } else {\n#if OUTPUT_RR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        for (i = 0;i < reZ.length;i++) {\n            // reX[], reY[] -> reZ[], imZ[]?\n            $RRBlock\n        }\n    }\n}\n#endif");\r
-            exports_20("TT_BROADCAST_BLOCK_TEMPLATE", TT_BROADCAST_BLOCK_TEMPLATE = "// Because the number of dimensions are not fixed, we cannot use for loops here directly.\n// We will use recursion here.\nvar stridesX = ShapeHelper.computeStrides(shapeX);\nvar stridesY = ShapeHelper.computeStrides(shapeY);\nvar stridesZ = ShapeHelper.computeStrides(shapeZ);\nreZ = z.realData;\n#if NO_COMPLEX_INPUT\n#if OUTPUT_RR_COMPLEX\nz.ensureComplexStorage();\nimZ = z.imagData;\n#endif\n$RRBlock\n#else\nif (infoX.isComplex) {\n    if (infoY.isComplex) {\n#if OUTPUT_CC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        $CCBlock\n    } else {\n#if OUTPUT_CR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        $CRBlock\n    }\n#if !NO_IN_PLACE && (!OUTPUT_CC_COMPLEX || !OUTPUT_CR_COMPLEX)\n    if (inPlace) {\n        imZ = imZ || z.imagData;\n        for (i = 0;i < imZ.length;i++) {\n            imZ[i] = 0;\n        }\n    }\n#endif\n} else {\n    if (infoY.isComplex) {\n#if OUTPUT_RC_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        $RCBlock\n    } else {\n#if OUTPUT_RR_COMPLEX\n        z.ensureComplexStorage();\n        imZ = z.imagData;\n#endif\n        $RRBlock\n    }\n}\n#endif");\r
-            exports_20("TT_BROADCAST_SUB_BLOCK_TEMPLATE", TT_BROADCAST_SUB_BLOCK_TEMPLATE = "var applyOp = function (level, offsetX, offsetY, offsetZ) {\n    var i = 0;\n    if (level === shapeZ.length - 1) {\n        // last level\n        if (shapeX[level] === 1) {\n            // z[offsetZ + i] <- op(x[offsetX], y[offset + i])\n            for (i = 0;i < shapeZ[level];i++) {\n                $OpFixX\n            }\n        } else if (shapeY[level] === 1) {\n            // z[offsetZ + i] <- op(x[offsetX + i], y[offset])\n            for (i = 0;i < shapeZ[level];i++) {\n                $OpFixY\n            }\n        } else {\n            // z[offsetZ + i] <- op(x[offsetX + i], y[offset + i])\n            for (i = 0;i < shapeZ[level];i++) {\n                $OpNormal\n            }\n        }\n    } else {\n        if (shapeX[level] === 1) {\n            // fix index[level] = 1 for x\n            for (i = 0;i < shapeZ[level];i++) {\n                applyOp(level + 1, offsetX, offsetY, offsetZ);\n                offsetY += stridesY[level];\n                offsetZ += stridesZ[level];\n            }\n        } else if (shapeY[level] === 1) {\n            // fix index[level] = 1 for y\n            for (i = 0;i < shapeZ[level];i++) {\n                applyOp(level + 1, offsetX, offsetY, offsetZ);\n                offsetX += stridesX[level];\n                offsetZ += stridesZ[level];\n            }\n        } else {\n            for (i = 0;i < shapeZ[level];i++) {\n                applyOp(level + 1, offsetX, offsetY, offsetZ);\n                offsetX += stridesX[level];\n                offsetY += stridesY[level];\n                offsetZ += stridesZ[level];\n            }\n        }\n    }\n}\napplyOp(0, 0, 0, 0);");\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/el/generator", ["jasmal/lib/ops/generator/generatorBase", "jasmal/lib/dtype", "jasmal/lib/helper/shapeHelper", "jasmal/lib/tensor", "jasmal/lib/complexNumber", "jasmal/lib/math/cmath", "jasmal/lib/ops/generator/el/unaryOpTemplates", "jasmal/lib/ops/generator/el/binaryOpTemplates", "jasmal/lib/helper/objHelper"], function (exports_21, context_21) {\r
-    "use strict";\r
-    var __moduleName = context_21 && context_21.id;\r
-    var generatorBase_1, dtype_2, shapeHelper_3, tensor_1, complexNumber_2, cmath_2, unaryOpTemplates_1, binaryOpTemplates_1, objHelper_6, ElementWiseOpGenerator;\r
-    return {\r
-        setters: [\r
-            function (generatorBase_1_1) {\r
-                generatorBase_1 = generatorBase_1_1;\r
-            },\r
-            function (dtype_2_1) {\r
-                dtype_2 = dtype_2_1;\r
-            },\r
-            function (shapeHelper_3_1) {\r
-                shapeHelper_3 = shapeHelper_3_1;\r
-            },\r
-            function (tensor_1_1) {\r
-                tensor_1 = tensor_1_1;\r
-            },\r
-            function (complexNumber_2_1) {\r
-                complexNumber_2 = complexNumber_2_1;\r
-            },\r
-            function (cmath_2_1) {\r
-                cmath_2 = cmath_2_1;\r
-            },\r
-            function (unaryOpTemplates_1_1) {\r
-                unaryOpTemplates_1 = unaryOpTemplates_1_1;\r
-            },\r
-            function (binaryOpTemplates_1_1) {\r
-                binaryOpTemplates_1 = binaryOpTemplates_1_1;\r
-            },\r
-            function (objHelper_6_1) {\r
-                objHelper_6 = objHelper_6_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            ElementWiseOpGenerator = (function (_super) {\r
-                __extends(ElementWiseOpGenerator, _super);\r
-                function ElementWiseOpGenerator() {\r
-                    return _super !== null && _super.apply(this, arguments) || this;\r
-                }\r
-                ElementWiseOpGenerator.getInstance = function () {\r
-                    if (!ElementWiseOpGenerator._instance) {\r
-                        ElementWiseOpGenerator._instance = new ElementWiseOpGenerator();\r
-                    }\r
-                    return ElementWiseOpGenerator._instance;\r
-                };\r
-                ElementWiseOpGenerator.prototype.makeUnaryOp = function (opTemplate, opConfig) {\r
-                    var deps = this._getUnaryOpDependencies(opConfig);\r
-                    var funcBody = this.generateUnaryOpFuncBody(opTemplate, objHelper_6.ObjectHelper.properties(deps), opConfig);\r
-                    var fn = (new Function(this.DEP_OBJ_NAME, funcBody))(deps);\r
-                    return fn;\r
-                };\r
-                ElementWiseOpGenerator.prototype.makeRealOutputUnaryOp = function (opTemplate, opConfig) {\r
-                    var deps = this._getUnaryOpDependencies(opConfig);\r
-                    var funcBody = this.generateUnaryOpFuncBody(opTemplate, objHelper_6.ObjectHelper.properties(deps), opConfig, false, true);\r
-                    var fn = (new Function(this.DEP_OBJ_NAME, funcBody))(deps);\r
-                    return fn;\r
-                };\r
-                ElementWiseOpGenerator.prototype.makeOneParamUnaryOp = function (opTemplate, opConfig) {\r
-                    var deps = this._getUnaryOpDependencies(opConfig);\r
-                    var funcBody = this.generateUnaryOpFuncBody(opTemplate, objHelper_6.ObjectHelper.properties(deps), opConfig, true);\r
-                    var fn = (new Function(this.DEP_OBJ_NAME, funcBody))(deps);\r
-                    return fn;\r
-                };\r
-                ElementWiseOpGenerator.prototype._getUnaryOpDependencies = function (opConfig) {\r
-                    var base = {\r
-                        Tensor: tensor_1.Tensor,\r
-                        ComplexNumber: complexNumber_2.ComplexNumber,\r
-                        CMath: cmath_2.CMath,\r
-                        ShapeHelper: shapeHelper_3.ShapeHelper,\r
-                        DTypeHelper: dtype_2.DTypeHelper,\r
-                        outputDTypeResolver: opConfig && opConfig.outputDTypeResolver\r
-                            ? opConfig.outputDTypeResolver : dtype_2.OutputDTypeResolver.uNoChange,\r
-                    };\r
-                    return opConfig && opConfig.extraDependencies\r
-                        ? objHelper_6.ObjectHelper.extend(base, opConfig.extraDependencies)\r
-                        : base;\r
-                };\r
-                ElementWiseOpGenerator.prototype.generateUnaryOpFuncBody = function (opTemplate, depNames, opConfig, hasParam, forceRealOutput) {\r
-                    var realInputOnly = opTemplate.opC == undefined;\r
-                    var templateConfig = {\r
-                        NO_COMPLEX_INPUT: realInputOnly,\r
-                        NO_IN_PLACE: opConfig ? !!opConfig.noInPlaceOperation : false,\r
-                        HAS_PARAM: hasParam || false\r
-                    };\r
-                    var opRSymbolSet = hasParam\r
-                        ? ['$reX', '$reY', '$imY', '$tmp1', '$tmp2', '$tmp3', '$tmp4', '$param']\r
-                        : ['$reX', '$reY', '$imY', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    var opCSymbolSet = hasParam\r
-                        ? ['$reX', '$imX', '$reY', '$imY', '$tmp1', '$tmp2', '$tmp3', '$tmp4', '$param']\r
-                        : ['$reX', '$imX', '$reY', '$imY', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    var opRSymbols = this._checkUsedSymbols(opTemplate.opR, opRSymbolSet);\r
-                    var opCSymbols = realInputOnly ? [] : this._checkUsedSymbols(opTemplate.opC, opCSymbolSet);\r
-                    if (opRSymbols.indexOf('$imY') >= 0) {\r
-                        templateConfig['OUTPUT_R_COMPLEX'] = true;\r
-                    }\r
-                    if (opCSymbols.indexOf('$imY') >= 0) {\r
-                        templateConfig['OUTPUT_C_COMPLEX'] = true;\r
-                    }\r
-                    if (forceRealOutput) {\r
-                        if (templateConfig['OUTPUT_R_COMPLEX'] || templateConfig['OUTPUT_C_COMPLEX']) {\r
-                            throw new Error('Specified templates generates complex outputs when only real outputs are allowed.');\r
-                        }\r
-                    }\r
-                    var symbolMapScalar = {\r
-                        '$reX': 'reXScalar',\r
-                        '$imX': 'imXScalar',\r
-                        '$reY': 'reYScalar',\r
-                        '$imY': 'imYScalar',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4',\r
-                        '$param': 'param'\r
-                    };\r
-                    var symbolMapTensor = {\r
-                        '$reX': 'reX[i]',\r
-                        '$imX': 'imX[i]',\r
-                        '$reY': 'reY[i]',\r
-                        '$imY': 'imY[i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4',\r
-                        '$param': 'param'\r
-                    };\r
-                    var blockMapTensor = {\r
-                        '$RBlock': this._engine.generate(opTemplate.opR, symbolMapTensor, templateConfig),\r
-                        '$CBlock': realInputOnly\r
-                            ? undefined\r
-                            : this._engine.generate(opTemplate.opC, symbolMapTensor, templateConfig)\r
-                    };\r
-                    var blockMapScalar = {\r
-                        '$RBlock': this._engine.generate(opTemplate.opR, symbolMapScalar, templateConfig),\r
-                        '$CBlock': realInputOnly\r
-                            ? undefined\r
-                            : this._engine.generate(opTemplate.opC, symbolMapScalar, templateConfig)\r
-                    };\r
-                    var blockMap = {\r
-                        '$InlineFunctions': this._flattenInlineFunctions(opConfig && opConfig.inlineFunctions ? opConfig.inlineFunctions : {}),\r
-                        '$Dependencies': this._generateDependencyBlock(depNames),\r
-                        '$TBlock': this._engine.generate(unaryOpTemplates_1.T_BLOCK_TEMPLATE, blockMapTensor, templateConfig),\r
-                        '$SBlock': this._engine.generate(unaryOpTemplates_1.S_BLOCK_TEMPLATE, blockMapScalar, templateConfig)\r
-                    };\r
-                    return this._engine.generate(unaryOpTemplates_1.UNARY_OP_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype.makeBinaryOp = function (opTemplate, config) {\r
-                    var deps = this._getBinaryOpDependencies(config);\r
-                    var funcBody = this.generateBinaryOpFuncBody(opTemplate, objHelper_6.ObjectHelper.properties(deps), config);\r
-                    var fn = (new Function(this.DEP_OBJ_NAME, funcBody))(deps);\r
-                    return fn;\r
-                };\r
-                ElementWiseOpGenerator.prototype.makeRealOutputBinaryOp = function (opTemplate, config) {\r
-                    var deps = this._getBinaryOpDependencies(config);\r
-                    var funcBody = this.generateBinaryOpFuncBody(opTemplate, objHelper_6.ObjectHelper.properties(deps), config, true);\r
-                    var fn = (new Function(this.DEP_OBJ_NAME, funcBody))(deps);\r
-                    return fn;\r
-                };\r
-                ElementWiseOpGenerator.prototype._getBinaryOpDependencies = function (config) {\r
-                    var outputDTypeResolver = (config && config.outputDTypeResolver)\r
-                        ? config.outputDTypeResolver\r
-                        : dtype_2.OutputDTypeResolver.bWider;\r
-                    var base = {\r
-                        Tensor: tensor_1.Tensor,\r
-                        ComplexNumber: complexNumber_2.ComplexNumber,\r
-                        CMath: cmath_2.CMath,\r
-                        ShapeHelper: shapeHelper_3.ShapeHelper,\r
-                        DTypeHelper: dtype_2.DTypeHelper,\r
-                        outputDTypeResolver: outputDTypeResolver,\r
-                    };\r
-                    return config && config.extraDependencies\r
-                        ? objHelper_6.ObjectHelper.extend(base, config.extraDependencies)\r
-                        : base;\r
-                };\r
-                ElementWiseOpGenerator.prototype.generateBinaryOpFuncBody = function (opTemplate, depNames, opConfig, forceRealOutput) {\r
-                    var realInputOnly = false;\r
-                    if (opTemplate.opCR == undefined && opTemplate.opRC == undefined && opTemplate.opCC == undefined) {\r
-                        realInputOnly = true;\r
-                    }\r
-                    else if (!(opTemplate.opCR != undefined && opTemplate.opRC != undefined && opTemplate.opCC != undefined)) {\r
-                        throw new Error('Partially defined opCR, opRC, and opCC.');\r
-                    }\r
-                    var templateConfig = {\r
-                        NO_COMPLEX_INPUT: realInputOnly,\r
-                        NO_IN_PLACE: opConfig ? !!opConfig.noInPlaceOperation : false\r
-                    };\r
-                    var symbolSetRR = ['$reX', '$reY', '$reZ', '$imZ', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    var symbolSetRC = ['$reX', '$reY', '$imY', '$reZ', '$imZ', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    var symbolSetCR = ['$reX', '$imX', '$reY', '$reZ', '$imZ', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    var symbolSetCC = ['$reX', '$imX', '$reY', '$imY', '$reZ', '$imZ', '$tmp1', '$tmp2', '$tmp3', '$tmp4'];\r
-                    if (this._checkUsedSymbols(opTemplate.opRR, symbolSetRR).indexOf('$imZ') >= 0) {\r
-                        templateConfig['OUTPUT_RR_COMPLEX'] = true;\r
-                    }\r
-                    if (!realInputOnly) {\r
-                        if (this._checkUsedSymbols(opTemplate.opRC, symbolSetRC).indexOf('$imZ') >= 0) {\r
-                            templateConfig['OUTPUT_RC_COMPLEX'] = true;\r
-                        }\r
-                        if (this._checkUsedSymbols(opTemplate.opCR, symbolSetCR).indexOf('$imZ') >= 0) {\r
-                            templateConfig['OUTPUT_CR_COMPLEX'] = true;\r
-                        }\r
-                        if (this._checkUsedSymbols(opTemplate.opCC, symbolSetCC).indexOf('$imZ') >= 0) {\r
-                            templateConfig['OUTPUT_CC_COMPLEX'] = true;\r
-                        }\r
-                    }\r
-                    if (forceRealOutput) {\r
-                        if (templateConfig['OUTPUT_RR_COMPLEX'] || templateConfig['OUTPUT_RC_COMPLEX'] ||\r
-                            templateConfig['OUTPUT_CR_COMPLEX'] || templateConfig['OUTPUT_CC_COMPLEX']) {\r
-                            throw new Error('Specified templates generates complex outputs when only real outputs are allowed.');\r
-                        }\r
-                    }\r
-                    var blockMap = {\r
-                        '$InlineFunctions': this._flattenInlineFunctions(opConfig && opConfig.inlineFunctions ? opConfig.inlineFunctions : {}),\r
-                        '$Dependencies': this._generateDependencyBlock(depNames),\r
-                        '$SSBlock': this._compileSSBlock(opTemplate, templateConfig),\r
-                        '$STBlock': this._compileSTBlock(opTemplate, templateConfig),\r
-                        '$TSBlock': this._compileTSBlock(opTemplate, templateConfig),\r
-                        '$TTBlock': this._compileTTBlock(opTemplate, templateConfig)\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.BIN_EL_OP_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileSSBlock = function (opTemplate, templateConfig) {\r
-                    var symbolMap = {\r
-                        '$reX': 'reXScalar',\r
-                        '$imX': 'imXScalar',\r
-                        '$reY': 'reYScalar',\r
-                        '$imY': 'imYScalar',\r
-                        '$reZ': 'reZScalar',\r
-                        '$imZ': 'imZScalar',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var blockMap = {\r
-                        '$RRBlock': this._engine.generate(opTemplate.opRR, symbolMap, templateConfig),\r
-                        '$RCBlock': opTemplate.opRC != undefined\r
-                            ? this._engine.generate(opTemplate.opRC, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CRBlock': opTemplate.opCR != undefined\r
-                            ? this._engine.generate(opTemplate.opCR, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CCBlock': opTemplate.opCC != undefined\r
-                            ? this._engine.generate(opTemplate.opCC, symbolMap, templateConfig)\r
-                            : undefined\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.SS_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileSTBlock = function (opTemplate, templateConfig) {\r
-                    var symbolMap = {\r
-                        '$reX': 'reXScalar',\r
-                        '$imX': 'imXScalar',\r
-                        '$reY': 'reY[i]',\r
-                        '$imY': 'imY[i]',\r
-                        '$reZ': 'reZ[i]',\r
-                        '$imZ': 'imZ[i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var blockMap = {\r
-                        '$RRBlock': this._engine.generate(opTemplate.opRR, symbolMap, templateConfig),\r
-                        '$RCBlock': opTemplate.opRC != undefined\r
-                            ? this._engine.generate(opTemplate.opRC, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CRBlock': opTemplate.opCR != undefined\r
-                            ? this._engine.generate(opTemplate.opCR, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CCBlock': opTemplate.opCC != undefined\r
-                            ? this._engine.generate(opTemplate.opCC, symbolMap, templateConfig)\r
-                            : undefined\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.ST_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileTSBlock = function (opTemplate, templateConfig) {\r
-                    var symbolMap = {\r
-                        '$reX': 'reX[i]',\r
-                        '$imX': 'imX[i]',\r
-                        '$reY': 'reYScalar',\r
-                        '$imY': 'imYScalar',\r
-                        '$reZ': 'reZ[i]',\r
-                        '$imZ': 'imZ[i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var blockMap = {\r
-                        '$RRBlock': this._engine.generate(opTemplate.opRR, symbolMap, templateConfig),\r
-                        '$RCBlock': opTemplate.opRC != undefined\r
-                            ? this._engine.generate(opTemplate.opRC, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CRBlock': opTemplate.opCR != undefined\r
-                            ? this._engine.generate(opTemplate.opCR, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CCBlock': opTemplate.opCC != undefined\r
-                            ? this._engine.generate(opTemplate.opCC, symbolMap, templateConfig)\r
-                            : undefined\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.TS_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileTTBlock = function (opTemplate, templateConfig) {\r
-                    var blockMap = {\r
-                        '$TTNormalBlock': this._compileTTNormalBlock(opTemplate, templateConfig),\r
-                        '$TTBroadcastBlock': this._compileTTBroadcastBlock(opTemplate, templateConfig)\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.TT_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileTTNormalBlock = function (opTemplate, templateConfig) {\r
-                    var symbolMap = {\r
-                        '$reX': 'reX[i]',\r
-                        '$imX': 'imX[i]',\r
-                        '$reY': 'reY[i]',\r
-                        '$imY': 'imY[i]',\r
-                        '$reZ': 'reZ[i]',\r
-                        '$imZ': 'imZ[i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var blockMap = {\r
-                        '$RRBlock': this._engine.generate(opTemplate.opRR, symbolMap, templateConfig),\r
-                        '$RCBlock': opTemplate.opRC != undefined\r
-                            ? this._engine.generate(opTemplate.opRC, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CRBlock': opTemplate.opCR != undefined\r
-                            ? this._engine.generate(opTemplate.opCR, symbolMap, templateConfig)\r
-                            : undefined,\r
-                        '$CCBlock': opTemplate.opCC != undefined\r
-                            ? this._engine.generate(opTemplate.opCC, symbolMap, templateConfig)\r
-                            : undefined\r
-                    };\r
-                    return this._engine.generate(binaryOpTemplates_1.TT_NORMAL_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                ElementWiseOpGenerator.prototype._compileTTBroadcastBlock = function (opTemplate, templateConfig) {\r
-                    var _this = this;\r
-                    var symbolMapNormal = {\r
-                        '$reX': 'reX[offsetX + i]',\r
-                        '$imX': 'imX[offsetX + i]',\r
-                        '$reY': 'reY[offsetY + i]',\r
-                        '$imY': 'imY[offsetY + i]',\r
-                        '$reZ': 'reZ[offsetZ + i]',\r
-                        '$imZ': 'imZ[offsetZ + i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var symbolMapFixX = {\r
-                        '$reX': 'reX[offsetX]',\r
-                        '$imX': 'imX[offsetX]',\r
-                        '$reY': 'reY[offsetY + i]',\r
-                        '$imY': 'imY[offsetY + i]',\r
-                        '$reZ': 'reZ[offsetZ + i]',\r
-                        '$imZ': 'imZ[offsetZ + i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var symbolMapFixY = {\r
-                        '$reX': 'reX[offsetX + i]',\r
-                        '$imX': 'imX[offsetX + i]',\r
-                        '$reY': 'reY[offsetY]',\r
-                        '$imY': 'imY[offsetY]',\r
-                        '$reZ': 'reZ[offsetZ + i]',\r
-                        '$imZ': 'imZ[offsetZ + i]',\r
-                        '$tmp1': 'tmp1',\r
-                        '$tmp2': 'tmp2',\r
-                        '$tmp3': 'tmp3',\r
-                        '$tmp4': 'tmp4'\r
-                    };\r
-                    var blockMap = {};\r
-                    ['RR', 'RC', 'CR', 'CC'].forEach(function (s) {\r
-                        var opTemplateName = 'op' + s;\r
-                        if (opTemplate[opTemplateName] == undefined) {\r
-                            return;\r
-                        }\r
-                        var subBlockMap = {\r
-                            '$OpFixX': _this._engine.generate(opTemplate[opTemplateName], symbolMapFixX, templateConfig),\r
-                            '$OpFixY': _this._engine.generate(opTemplate[opTemplateName], symbolMapFixY, templateConfig),\r
-                            '$OpNormal': _this._engine.generate(opTemplate[opTemplateName], symbolMapNormal, templateConfig)\r
-                        };\r
-                        blockMap['$' + s + 'Block'] = _this._engine.generate(binaryOpTemplates_1.TT_BROADCAST_SUB_BLOCK_TEMPLATE, subBlockMap, templateConfig);\r
-                    });\r
-                    return this._engine.generate(binaryOpTemplates_1.TT_BROADCAST_BLOCK_TEMPLATE, blockMap, templateConfig);\r
-                };\r
-                return ElementWiseOpGenerator;\r
-            }(generatorBase_1.OpGeneratorBase));\r
-            exports_21("ElementWiseOpGenerator", ElementWiseOpGenerator);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/reduction/templates", [], function (exports_22, context_22) {\r
-    "use strict";\r
-    var __moduleName = context_22 && context_22.id;\r
-    var REDUCTION_OP_TEMPLATE, S_BLOCK_TEMPLATE, T_BLOCK_TEMPLATE, T_R_BLOCK_TEMPLATE, T_C_BLOCK_TEMPLATE;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            exports_22("REDUCTION_OP_TEMPLATE", REDUCTION_OP_TEMPLATE = "'use strict';\n$Dependencies\nreturn function(x, axis, keepDims) {\n    if (axis == undefined) axis = -1;\n    var keepDims = keepDims || false;\n    var X = x instanceof Tensor ? x : Tensor.toTensor(x);\n    if (axis !== -1 && ((axis | 0) !== axis || axis >= X.ndim)) {\n        throw new Error('Invalid axis number ' + axis + '.');\n    }\n    var isInputComplex = X.hasNonZeroComplexStorage();\n#if NO_COMPLEX_INPUT\n    if (isInputComplex) {\n        throw new Error('Complex input is not supported.');\n    }\n#endif\n    var tmp;\n    var outputDType = outputDTypeResolver(X.dtype, isInputComplex);\n    var indexDType = DTypeHelper.getDTypeOfIndices();\n    if (outputDType == undefined) {\n        throw new Error('Failed to determine the output dtype.');\n    }\n    if (axis === -1 || (axis === 0 && X.ndim === 1)) {\n        // reduce to a scalar\n        $S_BLOCK\n    } else {\n        // reduce to a tensor\n        $T_BLOCK\n    }\n};");\r
-            exports_22("S_BLOCK_TEMPLATE", S_BLOCK_TEMPLATE = "#ifnot NO_COMPLEX_INPUT\nif (isInputComplex) {\n    tmp = fComplex(X.realData, X.imagData, 0, 1, X.size);\n#if OUTPUT_C_COMPLEX\n#if OUTPUT_INDICES\n    if (keepDims) {\n        return [Tensor.scalar(tmp[0], tmp[1], outputDType, X.ndim), Tensor.scalar(tmp[2], 0, indexDType, X.ndim)];\n    } else {\n        return [tmp[1] === 0 ? tmp[0] : new ComplexNumber(tmp[0], tmp[1]), tmp[2]];\n    }\n#else\n    if (keepDims) {\n        return Tensor.scalar(tmp[0], tmp[1], outputDType, X.ndim);\n    } else {\n        return tmp[1] === 0 ? tmp[0] : new ComplexNumber(tmp[0], tmp[1]);\n    }\n#endif\n#else\n#if OUTPUT_INDICES\n    if (keepDims) {\n        return [Tensor.scalar(tmp[0], 0, outputDType, X.ndim), Tensor.scalar(tmp[1], 0, indexDType, X.ndim)];\n    } else {\n        return [tmp[0], tmp[1]];\n    }\n#else\n    return keepDims ? Tensor.scalar(tmp, 0, outputDType, X.ndim) : tmp;\n#endif\n#endif\n}\n#endif\ntmp = fReal(X.realData, 0, 1, X.size);\n#if OUTPUT_R_COMPLEX\n#if OUTPUT_INDICES\n    if (keepDims) {\n        return [Tensor.scalar(tmp[0], tmp[1], outputDType, X.ndim), Tensor.scalar(tmp[2], 0, indexDType, X.ndim)];\n    } else {\n        return [tmp[1] === 0 ? tmp[0] : new ComplexNumber(tmp[0], tmp[1]), tmp[2]];\n    }\n#else\n    if (keepDims) {\n        return Tensor.scalar(tmp[0], tmp[1], outputDType, X.ndim);\n    } else {\n        return tmp[1] === 0 ? tmp[0] : new ComplexNumber(tmp[0], tmp[1]);\n    }\n#endif\n#else\n#if OUTPUT_INDICES\n    if (keepDims) {\n        return [Tensor.scalar(tmp[0], 0, outputDType, X.ndim), Tensor.scalar(tmp[1], 0, indexDType, X.ndim)];\n    } else {\n        return [tmp[0], tmp[1]];\n    }\n#else\n    return keepDims ? Tensor.scalar(tmp, 0, outputDType, X.ndim) : tmp;\n#endif\n#endif");\r
-            exports_22("T_BLOCK_TEMPLATE", T_BLOCK_TEMPLATE = "var shapeX = X.shape;\nvar shapeY = shapeX.slice();\nshapeY[axis] = 1;\nvar Y = Tensor.zeros(shapeY, outputDType);\nvar stridesX = X.strides;\nvar stridesY = Y.strides;\nvar maxLevel = X.ndim - 1;\nvar stride = stridesX[axis];\nvar n = shapeX[axis];\nvar reX, reY, imX, imY;\n#if OUTPUT_INDICES\nvar Z = Tensor.zeros(shapeY, indexDType);\nvar reZ = Z.realData;\n#endif\n#if NO_COMPLEX_INPUT\n$T_R_BLOCK\n#else\nif (isInputComplex) {\n    $T_C_BLOCK\n} else {\n    $T_R_BLOCK\n}\n#endif\nif (!keepDims) {\n    shapeY.splice(axis, 1);\n    Y.reshape(shapeY);\n#if OUTPUT_INDICES\n    Z.reshape(shapeY);\n#endif\n}\n#if OUTPUT_INDICES\nreturn [Y, Z];\n#else\nreturn Y;\n#endif");\r
-            exports_22("T_R_BLOCK_TEMPLATE", T_R_BLOCK_TEMPLATE = "reX = X.realData;\nreY = Y.realData;\n#if OUTPUT_R_COMPLEX\nY.ensureComplexStorage();\nimY = Y.imagData;\nvar doReductionRICO = function (level, offsetX, offsetY) {\n    var tmp;\n    if (level === maxLevel) {\n        for (var j = 0;j < shapeY[level];j++) {\n            tmp = fReal(reX, offsetX, stride, n);\n            reY[offsetY] = tmp[0];\n            imY[offsetY] = tmp[1];\n#if OUTPUT_INDICES\n            reZ[offsetY] = tmp[2];\n#endif\n            offsetX++;\n            offsetY++;\n        }\n    } else {\n        for (var i = 0;i < shapeY[level];i++) {\n            doReductionRICO(level + 1, offsetX, offsetY);\n            offsetX += stridesX[level];\n            offsetY += stridesY[level];\n        }\n    }\n};\ndoReductionRICO(0, 0, 0);\n#else\nvar doReductionRIRO = function (level, offsetX, offsetY) {\n    var tmp;\n    if (level === maxLevel) {\n        for (var j = 0;j < shapeY[level];j++) {\n            tmp = fReal(reX, offsetX, stride, n);\n#if OUTPUT_INDICES\n            reY[offsetY] = tmp[0];\n            reZ[offsetY] = tmp[1];\n#else\n            reY[offsetY] = tmp;\n#endif\n            offsetX++;\n            offsetY++;\n        }\n    } else {\n        for (var i = 0;i < shapeY[level];i++) {\n            doReductionRIRO(level + 1, offsetX, offsetY);\n            offsetX += stridesX[level];\n            offsetY += stridesY[level];\n        }\n    }\n};\ndoReductionRIRO(0, 0, 0);\n#endif\n");\r
-            exports_22("T_C_BLOCK_TEMPLATE", T_C_BLOCK_TEMPLATE = "reX = X.realData;\nreY = Y.realData;\nimX = X.imagData;\n#if OUTPUT_C_COMPLEX\nY.ensureComplexStorage();\nimY = Y.imagData;\nvar doReductionCICO = function (level, offsetX, offsetY) {\n    var tmp;\n    if (level === maxLevel) {\n        for (var j = 0;j < shapeY[level];j++) {\n            tmp = fComplex(reX, imX, offsetX, stride, n);\n            reY[offsetY] = tmp[0];\n            imY[offsetY] = tmp[1];\n#if OUTPUT_INDICES\n            reZ[offsetY] = tmp[2];\n#endif\n            offsetX++;\n            offsetY++;\n        }\n    } else {\n        for (var i = 0;i < shapeY[level];i++) {\n            doReductionCICO(level + 1, offsetX, offsetY);\n            offsetX += stridesX[level];\n            offsetY += stridesY[level];\n        }\n    }\n};\ndoReductionCICO(0, 0, 0);\n#else\nvar doReductionCIRO = function (level, offsetX, offsetY) {\n    var tmp;\n    if (level === maxLevel) {\n        for (var j = 0;j < shapeY[level];j++) {\n            tmp = fComplex(reX, imX, offsetX, stride, n);\n#if OUTPUT_INDICES\n            reY[offsetY] = tmp[0];\n            reZ[offsetY] = tmp[1];\n#else\n            reY[offsetY] = tmp;\n#endif\n            offsetX++;\n            offsetY++;\n        }\n    } else {\n        for (var i = 0;i < shapeY[level];i++) {\n            doReductionCIRO(level + 1, offsetX, offsetY);\n            offsetX += stridesX[level];\n            offsetY += stridesY[level];\n        }\n    }\n};\ndoReductionCIRO(0, 0, 0);\n#endif\n");\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/reduction/generator", ["jasmal/lib/ops/generator/generatorBase", "jasmal/lib/dtype", "jasmal/lib/tensor", "jasmal/lib/complexNumber", "jasmal/lib/helper/shapeHelper", "jasmal/lib/helper/dataHelper", "jasmal/lib/ops/generator/reduction/templates", "jasmal/lib/helper/objHelper"], function (exports_23, context_23) {\r
-    "use strict";\r
-    var __moduleName = context_23 && context_23.id;\r
-    var generatorBase_2, dtype_3, tensor_2, complexNumber_3, shapeHelper_4, dataHelper_3, templates_1, objHelper_7, ReductionOpGenerator;\r
-    return {\r
-        setters: [\r
-            function (generatorBase_2_1) {\r
-                generatorBase_2 = generatorBase_2_1;\r
-            },\r
-            function (dtype_3_1) {\r
-                dtype_3 = dtype_3_1;\r
-            },\r
-            function (tensor_2_1) {\r
-                tensor_2 = tensor_2_1;\r
-            },\r
-            function (complexNumber_3_1) {\r
-                complexNumber_3 = complexNumber_3_1;\r
-            },\r
-            function (shapeHelper_4_1) {\r
-                shapeHelper_4 = shapeHelper_4_1;\r
-            },\r
-            function (dataHelper_3_1) {\r
-                dataHelper_3 = dataHelper_3_1;\r
-            },\r
-            function (templates_1_1) {\r
-                templates_1 = templates_1_1;\r
-            },\r
-            function (objHelper_7_1) {\r
-                objHelper_7 = objHelper_7_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            ReductionOpGenerator = (function (_super) {\r
-                __extends(ReductionOpGenerator, _super);\r
-                function ReductionOpGenerator() {\r
-                    return _super !== null && _super.apply(this, arguments) || this;\r
-                }\r
-                ReductionOpGenerator.getInstance = function () {\r
-                    if (!ReductionOpGenerator._instance) {\r
-                        ReductionOpGenerator._instance = new ReductionOpGenerator();\r
-                    }\r
-                    return ReductionOpGenerator._instance;\r
-                };\r
-                ReductionOpGenerator.prototype.makeRealOnlyOp = function (fReal, config) {\r
-                    if (config === void 0) { config = {}; }\r
-                    var deps = this._getDependencies(config);\r
-                    var funcBody = this.generateOpFuncBody({\r
-                        NO_COMPLEX_INPUT: true,\r
-                        OUTPUT_INDICES: false,\r
-                        OUTPUT_R_COMPLEX: false,\r
-                        OUTPUT_C_COMPLEX: false\r
-                    }, objHelper_7.ObjectHelper.properties(deps));\r
-                    var fn = new Function(this.DEP_OBJ_NAME, 'fReal', funcBody);\r
-                    return fn(deps, fReal);\r
-                };\r
-                ReductionOpGenerator.prototype.makeRealOnlyOpWithIndexOutput = function (fReal, config) {\r
-                    var deps = this._getDependencies(config);\r
-                    var funcBody = this.generateOpFuncBody({\r
-                        NO_COMPLEX_INPUT: true,\r
-                        OUTPUT_INDICES: true,\r
-                        OUTPUT_R_COMPLEX: false,\r
-                        OUTPUT_C_COMPLEX: false\r
-                    }, objHelper_7.ObjectHelper.properties(deps));\r
-                    var fn = new Function(this.DEP_OBJ_NAME, 'fReal', funcBody);\r
-                    return fn(deps, fReal);\r
-                };\r
-                ReductionOpGenerator.prototype.makeOp = function (fReal, fComplex, outputComplexWhenInputIsComplex, config) {\r
-                    var deps = this._getDependencies(config);\r
-                    var funcBody = this.generateOpFuncBody({\r
-                        NO_COMPLEX_INPUT: false,\r
-                        OUTPUT_INDICES: false,\r
-                        OUTPUT_R_COMPLEX: false,\r
-                        OUTPUT_C_COMPLEX: outputComplexWhenInputIsComplex\r
-                    }, objHelper_7.ObjectHelper.properties(deps));\r
-                    var fn = new Function(this.DEP_OBJ_NAME, 'fReal', 'fComplex', funcBody);\r
-                    return fn(deps, fReal, fComplex);\r
-                };\r
-                ReductionOpGenerator.prototype.generateOpFuncBody = function (config, depNames) {\r
-                    var tBlockMap = {\r
-                        '$T_R_BLOCK': this._engine.generate(templates_1.T_R_BLOCK_TEMPLATE, {}, config),\r
-                        '$T_C_BLOCK': config.NO_COMPLEX_INPUT ? '' : this._engine.generate(templates_1.T_C_BLOCK_TEMPLATE, {}, config)\r
-                    };\r
-                    var mainBlockMap = {\r
-                        '$Dependencies': this._generateDependencyBlock(depNames),\r
-                        '$S_BLOCK': this._engine.generate(templates_1.S_BLOCK_TEMPLATE, {}, config),\r
-                        '$T_BLOCK': this._engine.generate(templates_1.T_BLOCK_TEMPLATE, tBlockMap, config)\r
-                    };\r
-                    return this._engine.generate(templates_1.REDUCTION_OP_TEMPLATE, mainBlockMap, config);\r
-                };\r
-                ReductionOpGenerator.prototype._getDependencies = function (config) {\r
-                    return {\r
-                        Tensor: tensor_2.Tensor,\r
-                        ComplexNumber: complexNumber_3.ComplexNumber,\r
-                        ShapeHelper: shapeHelper_4.ShapeHelper,\r
-                        DataHelper: dataHelper_3.DataHelper,\r
-                        DTypeHelper: dtype_3.DTypeHelper,\r
-                        outputDTypeResolver: config && config.outputDTypeResolver\r
-                            ? config.outputDTypeResolver\r
-                            : dtype_3.OutputDTypeResolver.uNoChange\r
-                    };\r
-                };\r
-                return ReductionOpGenerator;\r
-            }(generatorBase_2.OpGeneratorBase));\r
-            exports_23("ReductionOpGenerator", ReductionOpGenerator);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/generator/index", ["jasmal/lib/ops/generator/el/generator", "jasmal/lib/ops/generator/reduction/generator"], function (exports_24, context_24) {\r
-    "use strict";\r
-    var __moduleName = context_24 && context_24.id;\r
-    return {\r
-        setters: [\r
-            function (generator_1_1) {\r
-                exports_24({\r
-                    "ElementWiseOpGenerator": generator_1_1["ElementWiseOpGenerator"]\r
-                });\r
-            },\r
-            function (generator_2_1) {\r
-                exports_24({\r
-                    "ReductionOpGenerator": generator_2_1["ReductionOpGenerator"]\r
-                });\r
-            }\r
-        ],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/basic", ["jasmal/lib/dtype"], function (exports_25, context_25) {\r
-    "use strict";\r
-    var __moduleName = context_25 && context_25.id;\r
-    var dtype_4, BasicMathOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_4_1) {\r
-                dtype_4 = dtype_4_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            BasicMathOpSetFactory = (function () {\r
-                function BasicMathOpSetFactory() {\r
-                }\r
-                BasicMathOpSetFactory.create = function (generator) {\r
-                    var opAbs = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.abs($reX);',\r
-                        opC: '$reY = CMath.length2($reX, $imX);',\r
-                    }, {\r
-                        outputDTypeResolver: function (t, isComplex) { return isComplex ? 3 : t; }\r
-                    });\r
-                    var opSign = generator.makeUnaryOp({\r
-                        opR: '$reY = $reX > 0 ? 1 : ($reX < 0 ? -1 : ($reX === 0 ? 0 : NaN));',\r
-                        opC: '$tmp1 = CMath.length2($reX, $imX);' +\r
-                            'if ($tmp1 === 0) { $reY = 0; $imY = 0; } else { $reY = $reX / $tmp1; $imY = $imX / $tmp1; }'\r
-                    }, {\r
-                        outputDTypeResolver: function (t, isComplex) { return isComplex ? 3 : t; }\r
-                    });\r
-                    var opMin2 = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = Math.min($reX, $reY);'\r
-                    });\r
-                    var opMax2 = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = Math.max($reX, $reY);'\r
-                    });\r
-                    var opConj = generator.makeUnaryOp({\r
-                        opR: '$reY = $reX;',\r
-                        opC: '$reY = $reX; $imY = -$imX;'\r
-                    });\r
-                    var opAngle = generator.makeUnaryOp({\r
-                        opR: '$reY = 0;',\r
-                        opC: '$reY = Math.atan2($imX, $reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_4.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opRad2Deg = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = 180 / Math.PI * $reX;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_4.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opDeg2Rad = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = Math.PI / 180 * $reX;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_4.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    return {\r
-                        abs: opAbs,\r
-                        sign: opSign,\r
-                        min2: opMin2,\r
-                        max2: opMax2,\r
-                        conj: opConj,\r
-                        angle: opAngle,\r
-                        rad2deg: opRad2Deg,\r
-                        deg2rad: opDeg2Rad\r
-                    };\r
-                };\r
-                return BasicMathOpSetFactory;\r
-            }());\r
-            exports_25("BasicMathOpSetFactory", BasicMathOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/math/hyptrig", [], function (exports_26, context_26) {\r
-    "use strict";\r
-    var __moduleName = context_26 && context_26.id;\r
-    var HyperbolicTrigonometry;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            HyperbolicTrigonometry = (function () {\r
-                function HyperbolicTrigonometry() {\r
-                }\r
-                HyperbolicTrigonometry.sinh = function (x) {\r
-                    return 0.5 * (Math.exp(x) - Math.exp(-x));\r
-                };\r
-                HyperbolicTrigonometry.cosh = function (x) {\r
-                    return 0.5 * (Math.exp(x) + Math.exp(-x));\r
-                };\r
-                HyperbolicTrigonometry.tanh = function (x) {\r
-                    var e2;\r
-                    if (x >= 0) {\r
-                        e2 = Math.exp(-x - x);\r
-                        return (1 - e2) / (1 + e2);\r
-                    }\r
-                    else {\r
-                        e2 = Math.exp(x + x);\r
-                        return (e2 - 1) / (e2 + 1);\r
-                    }\r
-                };\r
-                HyperbolicTrigonometry.coth = function (x) {\r
-                    var e2;\r
-                    if (x >= 0) {\r
-                        e2 = Math.exp(-x - x);\r
-                        return (1 + e2) / (1 - e2);\r
-                    }\r
-                    else {\r
-                        e2 = Math.exp(x + x);\r
-                        return (e2 + 1) / (e2 - 1);\r
-                    }\r
-                };\r
-                HyperbolicTrigonometry.asinh = function (x) {\r
-                    if (x === 0) {\r
-                        return 0;\r
-                    }\r
-                    var invX = 1 / x;\r
-                    return Math.log(x + Math.abs(x) * Math.sqrt(invX * invX + 1));\r
-                };\r
-                HyperbolicTrigonometry.acosh = function (x) {\r
-                    if (x < 1) {\r
-                        return NaN;\r
-                    }\r
-                    var invX = 1 / x;\r
-                    return Math.log(x + Math.abs(x) * Math.sqrt(1 - invX * invX));\r
-                };\r
-                HyperbolicTrigonometry.atanh = function (x) {\r
-                    if (x < -1 || x > 1) {\r
-                        return NaN;\r
-                    }\r
-                    return 0.5 * Math.log((1 + x) / (1 - x));\r
-                };\r
-                HyperbolicTrigonometry.acoth = function (x) {\r
-                    if (x > -1 && x < 1) {\r
-                        return NaN;\r
-                    }\r
-                    return 0.5 * Math.log((x + 1) / (x - 1));\r
-                };\r
-                return HyperbolicTrigonometry;\r
-            }());\r
-            exports_26("HyperbolicTrigonometry", HyperbolicTrigonometry);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/trigonometry", ["jasmal/lib/dtype", "jasmal/lib/math/hyptrig", "jasmal/lib/tensor", "jasmal/lib/complexNumber", "jasmal/lib/math/cmath", "jasmal/lib/constant"], function (exports_27, context_27) {\r
-    "use strict";\r
-    var __moduleName = context_27 && context_27.id;\r
-    var dtype_5, hyptrig_1, tensor_3, complexNumber_4, cmath_3, constant_2, InputRangeChecker, TrigMathOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_5_1) {\r
-                dtype_5 = dtype_5_1;\r
-            },\r
-            function (hyptrig_1_1) {\r
-                hyptrig_1 = hyptrig_1_1;\r
-            },\r
-            function (tensor_3_1) {\r
-                tensor_3 = tensor_3_1;\r
-            },\r
-            function (complexNumber_4_1) {\r
-                complexNumber_4 = complexNumber_4_1;\r
-            },\r
-            function (cmath_3_1) {\r
-                cmath_3 = cmath_3_1;\r
-            },\r
-            function (constant_2_1) {\r
-                constant_2 = constant_2_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            InputRangeChecker = (function () {\r
-                function InputRangeChecker() {\r
-                }\r
-                InputRangeChecker.anyAbsGreaterThanOne = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] > 1 || x[i] < -1) {\r
-                            return true;\r
-                        }\r
-                    }\r
-                    return false;\r
-                };\r
-                InputRangeChecker.anyAbsLessThanOne = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] < 1 && x[i] > -1) {\r
-                            return true;\r
-                        }\r
-                    }\r
-                    return false;\r
-                };\r
-                InputRangeChecker.anyLessThanOne = function (x) {\r
-                    for (var i = 0; i < x.length; i++) {\r
-                        if (x[i] < 1) {\r
-                            return true;\r
-                        }\r
-                    }\r
-                    return false;\r
-                };\r
-                return InputRangeChecker;\r
-            }());\r
-            TrigMathOpSetFactory = (function () {\r
-                function TrigMathOpSetFactory() {\r
-                }\r
-                TrigMathOpSetFactory.create = function (generator) {\r
-                    var opSin = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.sin($reX);',\r
-                        opC: '$tmp1 = CMath.csin($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opCos = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.cos($reX);',\r
-                        opC: '$tmp1 = CMath.ccos($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opTan = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.tan($reX);',\r
-                        opC: '$tmp1 = CMath.ctan($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opCot = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = Math.tan($reX); $reY = $tmp1 === 0.0 ? NaN : 1.0 / $tmp1;',\r
-                        opC: '$tmp2 = CMath.ccot($reX, $imX); $reY = $tmp2[0]; $imY = $tmp2[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAsinR = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.asin($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAsinC = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.casin($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.casin($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAsin = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_3.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isInputScalar) {\r
-                            if (inPlace) {\r
-                                throw new Error('Cannot perform in-place operation for a scalar input.');\r
-                            }\r
-                            var _a = cmath_3.CMath.casin(infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                            return im === 0 ? re : new complexNumber_4.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            if (infoX.isComplex || InputRangeChecker.anyAbsGreaterThanOne(infoX.reArr)) {\r
-                                return opAsinC(infoX, inPlace);\r
-                            }\r
-                            else {\r
-                                return opAsinR(infoX, inPlace);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opAcosR = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.acos($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAcosC = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.cacos($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.cacos($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAcos = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_3.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isInputScalar) {\r
-                            if (inPlace) {\r
-                                throw new Error('Cannot perform in-place operation for a scalar input.');\r
-                            }\r
-                            var _a = cmath_3.CMath.cacos(infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                            return im === 0 ? re : new complexNumber_4.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            if (infoX.isComplex || InputRangeChecker.anyAbsGreaterThanOne(infoX.reArr)) {\r
-                                return opAcosC(infoX, inPlace);\r
-                            }\r
-                            else {\r
-                                return opAcosR(infoX, inPlace);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opAtan = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.atan($reX);',\r
-                        opC: '$tmp1 = CMath.catan($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAcot = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = Math.atan($reX); $reY = ($tmp1 >= 0 ? M_PI_2 : -M_PI_2) - $tmp1; ',\r
-                        opC: '$tmp1 = CMath.cacot($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'M_PI_2': constant_2.M_PI_2 }\r
-                    });\r
-                    var opSinh = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.sinh($reX);',\r
-                        opC: '$tmp1 = CMath.csinh($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opCosh = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.cosh($reX);',\r
-                        opC: '$tmp1 = CMath.ccosh($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opTanh = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.tanh($reX);',\r
-                        opC: '$tmp3 = CMath.ctanh($reX, $imX); $reY = $tmp3[0]; $imY = $tmp3[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opCoth = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.coth($reX);',\r
-                        opC: '$tmp3 = CMath.ccoth($reX, $imX); $reY = $tmp3[0]; $imY = $tmp3[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opAsinh = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.asinh($reX);',\r
-                        opC: '$tmp1 = CMath.casinh($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opAcoshR = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.acosh($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opAcoshC = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.cacosh($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.cacosh($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAcosh = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_3.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isInputScalar) {\r
-                            if (inPlace) {\r
-                                throw new Error('Cannot perform in-place operation for a scalar input.');\r
-                            }\r
-                            var _a = cmath_3.CMath.cacosh(infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                            return im === 0 ? re : new complexNumber_4.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            if (infoX.isComplex || InputRangeChecker.anyLessThanOne(infoX.reArr)) {\r
-                                return opAcoshC(infoX, inPlace);\r
-                            }\r
-                            else {\r
-                                return opAcoshR(infoX, inPlace);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opAtanhR = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.atanh($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opAtanhC = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.catanh($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.catanh($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAtanh = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_3.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isInputScalar) {\r
-                            if (inPlace) {\r
-                                throw new Error('Cannot perform in-place operation for a scalar input.');\r
-                            }\r
-                            var _a = cmath_3.CMath.catanh(infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                            return im === 0 ? re : new complexNumber_4.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            if (infoX.isComplex || InputRangeChecker.anyAbsGreaterThanOne(infoX.reArr)) {\r
-                                return opAtanhC(infoX, inPlace);\r
-                            }\r
-                            else {\r
-                                return opAtanhR(infoX, inPlace);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opAcothR = generator.makeUnaryOp({\r
-                        opR: '$reY = HyperbolicTrigonometry.acoth($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'HyperbolicTrigonometry': hyptrig_1.HyperbolicTrigonometry }\r
-                    });\r
-                    var opAcothC = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.cacoth($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.cacoth($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_5.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opAcoth = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_3.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isInputScalar) {\r
-                            if (inPlace) {\r
-                                throw new Error('Cannot perform in-place operation for a scalar input.');\r
-                            }\r
-                            var _a = cmath_3.CMath.cacoth(infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                            return im === 0 ? re : new complexNumber_4.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            if (infoX.isComplex || InputRangeChecker.anyAbsLessThanOne(infoX.reArr)) {\r
-                                return opAcothC(infoX, inPlace);\r
-                            }\r
-                            else {\r
-                                return opAcothR(infoX, inPlace);\r
-                            }\r
-                        }\r
-                    };\r
-                    return {\r
-                        sin: opSin,\r
-                        cos: opCos,\r
-                        tan: opTan,\r
-                        cot: opCot,\r
-                        asin: opAsin,\r
-                        acos: opAcos,\r
-                        atan: opAtan,\r
-                        acot: opAcot,\r
-                        sinh: opSinh,\r
-                        cosh: opCosh,\r
-                        tanh: opTanh,\r
-                        coth: opCoth,\r
-                        asinh: opAsinh,\r
-                        acosh: opAcosh,\r
-                        atanh: opAtanh,\r
-                        acoth: opAcoth\r
-                    };\r
-                };\r
-                return TrigMathOpSetFactory;\r
-            }());\r
-            exports_27("TrigMathOpSetFactory", TrigMathOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/pow", ["jasmal/lib/dtype", "jasmal/lib/tensor", "jasmal/lib/helper/dataHelper"], function (exports_28, context_28) {\r
-    "use strict";\r
-    var __moduleName = context_28 && context_28.id;\r
-    var dtype_6, tensor_4, dataHelper_4, PowerMathOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_6_1) {\r
-                dtype_6 = dtype_6_1;\r
-            },\r
-            function (tensor_4_1) {\r
-                tensor_4 = tensor_4_1;\r
-            },\r
-            function (dataHelper_4_1) {\r
-                dataHelper_4 = dataHelper_4_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            PowerMathOpSetFactory = (function () {\r
-                function PowerMathOpSetFactory() {\r
-                }\r
-                PowerMathOpSetFactory.create = function (generator) {\r
-                    var opSqrtP = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.sqrt($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_6.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opSqrtA = generator.makeUnaryOp({\r
-                        opR: 'if ($reX >= 0) { $reY = Math.sqrt($reX); } else { $imY = Math.sqrt(-$reX); $reY = 0; }',\r
-                        opC: '$tmp1 = CMath.csqrt($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_6.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opSqrt = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_4.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isComplex || infoX.re < 0 || dataHelper_4.DataHelper.anyNegative(infoX.reArr)) {\r
-                            return opSqrtA(infoX, inPlace);\r
-                        }\r
-                        else {\r
-                            return opSqrtP(infoX, inPlace);\r
-                        }\r
-                    };\r
-                    var opSquare = generator.makeUnaryOp({\r
-                        opR: '$reY = $reX * $reX;',\r
-                        opC: '$tmp1 = $reX * $reX - $imX * $imX; $tmp2 = $reX * $imX; $reY = $tmp1; $imY = $tmp2 + $tmp2;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_6.OutputDTypeResolver.uOnlyLogicToFloat\r
-                    });\r
-                    var opPowR = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = Math.pow($reX, $reY);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_6.OutputDTypeResolver.bToFloat\r
-                    });\r
-                    var opPowCC = generator.makeBinaryOp({\r
-                        opRR: '$tmp1 = CMath.cpowRR($reX, $reY); $reZ = $tmp1[0]; $imZ = $tmp1[1];',\r
-                        opRC: '$tmp1 = CMath.cpow($reX, 0, $reY, $imY); $reZ = $tmp1[0]; $imZ = $tmp1[1];',\r
-                        opCR: '$tmp1 = CMath.cpow($reX, $imX, $reY, 0); $reZ = $tmp1[0]; $imZ = $tmp1[1];',\r
-                        opCC: '$tmp1 = CMath.cpow($reX, $imX, $reY, $imY); $reZ = $tmp1[0]; $imZ = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_6.OutputDTypeResolver.bToFloat\r
-                    });\r
-                    var opPow = function (x, y, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_4.Tensor.analyzeOpInput(x);\r
-                        var infoY = tensor_4.Tensor.analyzeOpInput(y);\r
-                        var Z;\r
-                        if (infoX.isComplex || infoY.isComplex) {\r
-                            Z = opPowCC(infoX, infoY, inPlace);\r
-                        }\r
-                        else {\r
-                            if ((infoX.re < 0 || dataHelper_4.DataHelper.anyNegative(infoX.reArr)) && infoY.originalDType === 3) {\r
-                                Z = opPowCC(infoX, infoY, inPlace);\r
-                            }\r
-                            else {\r
-                                Z = opPowR(infoX, infoY, inPlace);\r
-                            }\r
-                        }\r
-                        if (Z instanceof tensor_4.Tensor && Z.hasComplexStorage()) {\r
-                            if (dataHelper_4.DataHelper.isArrayAllZeros(Z.imagData)) {\r
-                                Z.trimImaginaryPart();\r
-                            }\r
-                        }\r
-                        return Z;\r
-                    };\r
-                    return {\r
-                        sqrt: opSqrt,\r
-                        square: opSquare,\r
-                        pow: opPow,\r
-                        realpow: opPowR\r
-                    };\r
-                };\r
-                return PowerMathOpSetFactory;\r
-            }());\r
-            exports_28("PowerMathOpSetFactory", PowerMathOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/logexp", ["jasmal/lib/dtype", "jasmal/lib/tensor", "jasmal/lib/helper/dataHelper"], function (exports_29, context_29) {\r
-    "use strict";\r
-    var __moduleName = context_29 && context_29.id;\r
-    var dtype_7, tensor_5, dataHelper_5, LogExpMathOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_7_1) {\r
-                dtype_7 = dtype_7_1;\r
-            },\r
-            function (tensor_5_1) {\r
-                tensor_5 = tensor_5_1;\r
-            },\r
-            function (dataHelper_5_1) {\r
-                dataHelper_5 = dataHelper_5_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            LogExpMathOpSetFactory = (function () {\r
-                function LogExpMathOpSetFactory() {\r
-                }\r
-                LogExpMathOpSetFactory.create = function (generator) {\r
-                    var opExp = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.exp($reX);',\r
-                        opC: '$tmp1 = CMath.cexp($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_7.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opLog = function (x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoX = tensor_5.Tensor.analyzeOpInput(x);\r
-                        if (infoX.isComplex || infoX.re < 0 || dataHelper_5.DataHelper.anyNegative(infoX.reArr)) {\r
-                            return opLogA(infoX, inPlace);\r
-                        }\r
-                        else {\r
-                            return opLogP(infoX, inPlace);\r
-                        }\r
-                    };\r
-                    var opLogP = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.log($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_7.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    var opLogA = generator.makeUnaryOp({\r
-                        opR: '$tmp1 = CMath.clog($reX, 0); $reY = $tmp1[0]; $imY = $tmp1[1];',\r
-                        opC: '$tmp1 = CMath.clog($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_7.OutputDTypeResolver.uToFloat\r
-                    });\r
-                    return {\r
-                        log: opLog,\r
-                        exp: opExp,\r
-                    };\r
-                };\r
-                return LogExpMathOpSetFactory;\r
-            }());\r
-            exports_29("LogExpMathOpSetFactory", LogExpMathOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/rounding", ["jasmal/lib/dtype"], function (exports_30, context_30) {\r
-    "use strict";\r
-    var __moduleName = context_30 && context_30.id;\r
-    var dtype_8, RoundingMathOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_8_1) {\r
-                dtype_8 = dtype_8_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            RoundingMathOpSetFactory = (function () {\r
-                function RoundingMathOpSetFactory() {\r
-                }\r
-                RoundingMathOpSetFactory.create = function (generator) {\r
-                    var opFloor = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.floor($reX);',\r
-                        opC: '$reY = Math.floor($reX); $imY = Math.floor($imX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_8.OutputDTypeResolver.uOnlyLogicToFloat\r
-                    });\r
-                    var opCeil = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.ceil($reX);',\r
-                        opC: '$reY = Math.ceil($reX); $imY = Math.ceil($imX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_8.OutputDTypeResolver.uOnlyLogicToFloat\r
-                    });\r
-                    var opRound = generator.makeUnaryOp({\r
-                        opR: '$reY = Math.round($reX);',\r
-                        opC: '$reY = Math.round($reX); $imY = Math.round($imX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_8.OutputDTypeResolver.uOnlyLogicToFloat\r
-                    });\r
-                    var opFix = generator.makeUnaryOp({\r
-                        opR: '$reY = ($reX >= 0) ? Math.floor($reX) : Math.ceil($reX);',\r
-                        opC: '$reY = ($reX >= 0) ? Math.floor($reX) : Math.ceil($reX);\n' +\r
-                            '$reX = ($imX >= 0) ? Math.floor($imX) : Math.ceil($imX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_8.OutputDTypeResolver.uOnlyLogicToFloat\r
-                    });\r
-                    return {\r
-                        floor: opFloor,\r
-                        ceil: opCeil,\r
-                        round: opRound,\r
-                        fix: opFix\r
-                    };\r
-                };\r
-                return RoundingMathOpSetFactory;\r
-            }());\r
-            exports_30("RoundingMathOpSetFactory", RoundingMathOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/math/special", [], function (exports_31, context_31) {\r
-    "use strict";\r
-    var __moduleName = context_31 && context_31.id;\r
-    var FactorialTable, SpecialFunction;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            FactorialTable = (function () {\r
-                function FactorialTable() {\r
-                }\r
-                FactorialTable._initTable = function () {\r
-                    FactorialTable._table[0] = 1;\r
-                    for (var i = 1; i <= FactorialTable.MAX_INTEGER; i++) {\r
-                        FactorialTable._table[i] = FactorialTable._table[i - 1] * i;\r
-                    }\r
-                };\r
-                FactorialTable.get = function (x) {\r
-                    if (!FactorialTable._inited) {\r
-                        FactorialTable._initTable();\r
-                        FactorialTable._inited = true;\r
-                    }\r
-                    var res = FactorialTable._table[x];\r
-                    return res == undefined ? NaN : res;\r
-                };\r
-                FactorialTable.MAX_INTEGER = 170;\r
-                FactorialTable._table = new Array(FactorialTable.MAX_INTEGER + 1);\r
-                FactorialTable._inited = false;\r
-                return FactorialTable;\r
-            }());\r
-            exports_31("FactorialTable", FactorialTable);\r
-            SpecialFunction = (function () {\r
-                function SpecialFunction() {\r
-                }\r
-                SpecialFunction.isPowerOfTwoN = function (n) {\r
-                    return ((n !== 0) && !(n & (n - 1)));\r
-                };\r
-                SpecialFunction.gammaln = function (x) {\r
-                    var D1 = -5.772156649015328605195174e-1;\r
-                    var P1 = [4.945235359296727046734888e0, 2.018112620856775083915565e2,\r
-                        2.290838373831346393026739e3, 1.131967205903380828685045e4,\r
-                        2.855724635671635335736389e4, 3.848496228443793359990269e4,\r
-                        2.637748787624195437963534e4, 7.225813979700288197698961e3];\r
-                    var Q1 = [6.748212550303777196073036e1, 1.113332393857199323513008e3,\r
-                        7.738757056935398733233834e3, 2.763987074403340708898585e4,\r
-                        5.499310206226157329794414e4, 6.161122180066002127833352e4,\r
-                        3.635127591501940507276287e4, 8.785536302431013170870835e3];\r
-                    var D2 = 4.227843350984671393993777e-1;\r
-                    var P2 = [4.974607845568932035012064e0, 5.424138599891070494101986e2,\r
-                        1.550693864978364947665077e4, 1.847932904445632425417223e5,\r
-                        1.088204769468828767498470e6, 3.338152967987029735917223e6,\r
-                        5.106661678927352456275255e6, 3.074109054850539556250927e6];\r
-                    var Q2 = [1.830328399370592604055942e2, 7.765049321445005871323047e3,\r
-                        1.331903827966074194402448e5, 1.136705821321969608938755e6,\r
-                        5.267964117437946917577538e6, 1.346701454311101692290052e7,\r
-                        1.782736530353274213975932e7, 9.533095591844353613395747e6];\r
-                    var D4 = 1.791759469228055000094023;\r
-                    var P4 = [1.474502166059939948905062e4, 2.426813369486704502836312e6,\r
-                        1.214755574045093227939592e8, 2.663432449630976949898078e9,\r
-                        2.940378956634553899906876e10, 1.702665737765398868392998e11,\r
-                        4.926125793377430887588120e11, 5.606251856223951465078242e11];\r
-                    var Q4 = [2.690530175870899333379843e3, 6.393885654300092398984238e5,\r
-                        4.135599930241388052042842e7, 1.120872109616147941376570e9,\r
-                        1.488613728678813811542398e10, 1.016803586272438228077304e11,\r
-                        3.417476345507377132798597e11, 4.463158187419713286462081e11];\r
-                    var C = [-1.910444077728e-03, 8.4171387781295e-04,\r
-                        -5.952379913043012e-04, 7.93650793500350248e-04,\r
-                        -2.777777777777681622553e-03, 8.333333333333333331554247e-02,\r
-                        5.7083835261e-03];\r
-                    var res, corr, tmp1, tmp2, xDen, xNum, i;\r
-                    if (x > 0 && x < 2.55e305) {\r
-                        if (x <= 2.22e-16) {\r
-                            res = -Math.log(x);\r
-                        }\r
-                        else if (x < 1.5) {\r
-                            if (x < 0.6796875) {\r
-                                corr = -Math.log(x);\r
-                                tmp1 = x;\r
-                            }\r
-                            else {\r
-                                corr = 0;\r
-                                tmp1 = (x - 0.5) - 0.5;\r
-                            }\r
-                            if (x <= 0.5 || x >= 0.6796875) {\r
-                                xDen = 1;\r
-                                xNum = 0;\r
-                                for (i = 0; i < 8; i++) {\r
-                                    xNum = xNum * tmp1 + P1[i];\r
-                                    xDen = xDen * tmp1 + Q1[i];\r
-                                }\r
-                                res = corr + (tmp1 * (D1 + tmp1 * (xNum / xDen)));\r
-                            }\r
-                            else {\r
-                                tmp1 = (x - 0.5) - 0.5;\r
-                                xDen = 1;\r
-                                xNum = 0;\r
-                                for (i = 0; i < 8; i++) {\r
-                                    xNum = xNum * tmp1 + P2[i];\r
-                                    xDen = xDen * tmp1 + Q2[i];\r
-                                }\r
-                                res = corr + tmp1 * (D2 + tmp1 * (xNum / xDen));\r
-                            }\r
-                        }\r
-                        else if (x <= 4) {\r
-                            tmp2 = x - 2;\r
-                            xDen = 1;\r
-                            xNum = 0;\r
-                            for (i = 0; i < 8; i++) {\r
-                                xNum = xNum * tmp2 + P2[i];\r
-                                xDen = xDen * tmp2 + Q2[i];\r
-                            }\r
-                            res = tmp2 * (D2 + tmp2 * (xNum / xDen));\r
-                        }\r
-                        else if (x <= 12) {\r
-                            tmp1 = x - 4;\r
-                            xDen = -1;\r
-                            xNum = 0;\r
-                            for (i = 0; i < 8; i++) {\r
-                                xNum = xNum * tmp1 + P4[i];\r
-                                xDen = xDen * tmp1 + Q4[i];\r
-                            }\r
-                            res = D4 + tmp1 * (xNum / xDen);\r
-                        }\r
-                        else {\r
-                            res = 0;\r
-                            if (x <= 2.25e76) {\r
-                                res = C[6];\r
-                                tmp2 = x * x;\r
-                                for (i = 0; i < 6; i++) {\r
-                                    res = res / tmp2 + C[i];\r
-                                }\r
-                            }\r
-                            res = res / x;\r
-                            corr = Math.log(x);\r
-                            res = res + 0.9189385332046727417803297 - 0.5 * corr;\r
-                            res = res + x * (corr - 1);\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (x < 0) {\r
-                            throw new Error('Input must be nonnegative.');\r
-                        }\r
-                        else {\r
-                            res = Infinity;\r
-                        }\r
-                    }\r
-                    return res;\r
-                };\r
-                SpecialFunction.gamma = function (x) {\r
-                    var P = [-1.71618513886549492533811e+0, 2.47656508055759199108314e+1,\r
-                        -3.79804256470945635097577e+2, 6.29331155312818442661052e+2,\r
-                        8.66966202790413211295064e+2, -3.14512729688483675254357e+4,\r
-                        -3.61444134186911729807069e+4, 6.64561438202405440627855e+4];\r
-                    var Q = [-3.08402300119738975254353e+1, 3.15350626979604161529144e+2,\r
-                        -1.01515636749021914166146e+3, -3.10777167157231109440444e+3,\r
-                        2.25381184209801510330112e+4, 4.75584627752788110767815e+3,\r
-                        -1.34659959864969306392456e+5, -1.15132259675553483497211e+5];\r
-                    var C = [-1.910444077728e-3, 8.4171387781295e-4,\r
-                        -5.952379913043012e-4, 7.93650793500350248e-4,\r
-                        -2.777777777777681622553e-3, 8.333333333333333331554247e-2,\r
-                        5.7083835261e-3];\r
-                    var parity = false;\r
-                    var fact = 1;\r
-                    var n = 0;\r
-                    var tmp, res, z, i;\r
-                    if (x <= 0) {\r
-                        x = -x;\r
-                        tmp = Math.floor(x);\r
-                        res = x - tmp;\r
-                        if (res !== 0) {\r
-                            if (tmp !== Math.floor(tmp * 0.5) * 2) {\r
-                                parity = true;\r
-                            }\r
-                            fact = -Math.PI / Math.sin(Math.PI * res);\r
-                            x += 1;\r
-                        }\r
-                        else {\r
-                            return Infinity;\r
-                        }\r
-                    }\r
-                    if (x < 2.22e-16) {\r
-                        if (x >= 2.23e-308) {\r
-                            res = 1 / x;\r
-                        }\r
-                        else {\r
-                            return Infinity;\r
-                        }\r
-                    }\r
-                    else if (x < 12) {\r
-                        tmp = x;\r
-                        if (x < 1) {\r
-                            z = x;\r
-                            x += 1;\r
-                        }\r
-                        else {\r
-                            n = Math.floor(x) - 1;\r
-                            x -= n;\r
-                            z = x - 1;\r
-                        }\r
-                        var xNum = 0;\r
-                        var xDen = 1;\r
-                        for (i = 0; i < 8; i++) {\r
-                            xNum = (xNum + P[i]) * z;\r
-                            xDen = xDen * z + Q[i];\r
-                        }\r
-                        res = xNum / xDen + 1;\r
-                        if (tmp < x) {\r
-                            res /= tmp;\r
-                        }\r
-                        else if (tmp > x) {\r
-                            for (i = 0; i < n; i++) {\r
-                                res *= x;\r
-                                x += 1;\r
-                            }\r
-                        }\r
-                    }\r
-                    else {\r
-                        if (x <= 171.624) {\r
-                            tmp = x * x;\r
-                            z = C[6];\r
-                            for (i = 0; i < 6; i++) {\r
-                                z = z / tmp + C[i];\r
-                            }\r
-                            z = z / x - x + 0.9189385332046727417803297;\r
-                            z = z + (x - 0.5) * Math.log(x);\r
-                            res = Math.exp(z);\r
-                        }\r
-                        else {\r
-                            return Infinity;\r
-                        }\r
-                    }\r
-                    if (parity) {\r
-                        res = -res;\r
-                    }\r
-                    if (fact !== 1) {\r
-                        res = fact / res;\r
-                    }\r
-                    return res;\r
-                };\r
-                SpecialFunction.factorial = function (x) {\r
-                    if (isNaN(x) || x < 0 || Math.floor(x) !== x) {\r
-                        throw new Error('Input must be a nonnegative integer.');\r
-                    }\r
-                    if (x <= FactorialTable.MAX_INTEGER) {\r
-                        return FactorialTable.get(x);\r
-                    }\r
-                    else {\r
-                        return Infinity;\r
-                    }\r
-                };\r
-                SpecialFunction.calerf = function (x, type) {\r
-                    var A = [3.16112374387056560, 1.13864154151050156e2,\r
-                        3.77485237685302021e02, 3.20937758913846947e3,\r
-                        1.85777706184603153e-1];\r
-                    var B = [2.36012909523441209e1, 2.44024637934444173e2,\r
-                        1.28261652607737228e3, 2.84423683343917062e3];\r
-                    var C = [5.64188496988670089e-1, 8.88314979438837594,\r
-                        6.61191906371416295e01, 2.98635138197400131e2,\r
-                        8.81952221241769090e02, 1.71204761263407058e3,\r
-                        2.05107837782607147e03, 1.23033935479799725e3,\r
-                        2.15311535474403846e-8];\r
-                    var D = [1.57449261107098347e1, 1.17693950891312499e2,\r
-                        5.37181101862009858e2, 1.62138957456669019e3,\r
-                        3.29079923573345963e3, 4.36261909014324716e3,\r
-                        3.43936767414372164e3, 1.23033935480374942e3];\r
-                    var P = [3.05326634961232344e-1, 3.60344899949804439e-1,\r
-                        1.25781726111229246e-1, 1.60837851487422766e-2,\r
-                        6.58749161529837803e-4, 1.63153871373020978e-2];\r
-                    var Q = [2.56852019228982242, 1.87295284992346047,\r
-                        5.27905102951428412e-1, 6.05183413124413191e-2,\r
-                        2.33520497626869185e-3];\r
-                    var SQRPI = 0.56418958354775628695;\r
-                    var y = Math.abs(x);\r
-                    var flag = false;\r
-                    var i, res, del;\r
-                    var ySq, xNum, xDen;\r
-                    if (y <= 0.46875) {\r
-                        ySq = y > 1.11e-16 ? y * y : 0;\r
-                        xNum = A[4] * ySq;\r
-                        xDen = ySq;\r
-                        for (i = 0; i < 3; i++) {\r
-                            xNum = (xNum + A[i]) * ySq;\r
-                            xDen = (xDen + B[i]) * ySq;\r
-                        }\r
-                        res = x * (xNum + A[3]) / (xDen + B[3]);\r
-                        if (type !== 0)\r
-                            res = 1 - res;\r
-                        if (type === 2)\r
-                            res = Math.exp(ySq) * res;\r
-                        return res;\r
-                    }\r
-                    else if (y <= 4) {\r
-                        xNum = C[8] * y;\r
-                        xDen = y;\r
-                        for (i = 0; i < 7; i++) {\r
-                            xNum = (xNum + C[i]) * y;\r
-                            xDen = (xDen + D[i]) * y;\r
-                        }\r
-                        res = (xNum + C[7]) / (xDen + D[7]);\r
-                        if (type !== 2) {\r
-                            ySq = Math.floor(y * 16) / 16;\r
-                            del = (y - ySq) * (y + ySq);\r
-                            res = Math.exp(-ySq * ySq) * Math.exp(-del) * res;\r
-                        }\r
-                    }\r
-                    else {\r
-                        res = 0;\r
-                        if (y >= 26.543) {\r
-                            if (type !== 2 || y >= 2.53e307) {\r
-                                flag = true;\r
-                            }\r
-                            else if (y >= 6.71e7) {\r
-                                res = SQRPI / y;\r
-                                flag = true;\r
-                            }\r
-                        }\r
-                        if (!flag) {\r
-                            ySq = 1 / (y * y);\r
-                            xNum = P[5] * ySq;\r
-                            xDen = ySq;\r
-                            for (i = 0; i < 4; i++) {\r
-                                xNum = (xNum + P[i]) * ySq;\r
-                                xDen = (xDen + Q[i]) * ySq;\r
-                            }\r
-                            res = ySq * (xNum + P[4]) / (xDen + Q[4]);\r
-                            res = (SQRPI - res) / y;\r
-                            if (type !== 2) {\r
-                                ySq = Math.floor(y * 16) / 16;\r
-                                del = (y - ySq) * (y + ySq);\r
-                                res = Math.exp(-ySq * ySq) * Math.exp(-del) * res;\r
-                            }\r
-                        }\r
-                    }\r
-                    if (type === 0) {\r
-                        res = (0.5 - res) + 0.5;\r
-                        if (x < 0)\r
-                            res = -res;\r
-                    }\r
-                    else if (type === 1) {\r
-                        if (x < 0)\r
-                            res = 2 - res;\r
-                    }\r
-                    else {\r
-                        if (x < 0) {\r
-                            if (x < -26.628) {\r
-                                res = Infinity;\r
-                            }\r
-                            else {\r
-                                ySq = Math.ceil(x * 16) / 16;\r
-                                del = (x - ySq) * (x + ySq);\r
-                                y = Math.exp(ySq * ySq) * Math.exp(del);\r
-                                res = (y + y) - res;\r
-                            }\r
-                        }\r
-                    }\r
-                    return res;\r
-                };\r
-                SpecialFunction.erf = function (x) {\r
-                    return SpecialFunction.calerf(x, 0);\r
-                };\r
-                SpecialFunction.erfc = function (x) {\r
-                    return SpecialFunction.calerf(x, 1);\r
-                };\r
-                SpecialFunction.erfcx = function (x) {\r
-                    return SpecialFunction.calerf(x, 2);\r
-                };\r
-                return SpecialFunction;\r
-            }());\r
-            exports_31("SpecialFunction", SpecialFunction);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/special", ["jasmal/lib/dtype", "jasmal/lib/math/special"], function (exports_32, context_32) {\r
-    "use strict";\r
-    var __moduleName = context_32 && context_32.id;\r
-    var dtype_9, special_1, SpecialFunctionOpSetFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_9_1) {\r
-                dtype_9 = dtype_9_1;\r
-            },\r
-            function (special_1_1) {\r
-                special_1 = special_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            SpecialFunctionOpSetFactory = (function () {\r
-                function SpecialFunctionOpSetFactory() {\r
-                }\r
-                SpecialFunctionOpSetFactory.create = function (generator) {\r
-                    var opGammaLn = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.gammaln($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    var opGamma = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.gamma($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    var opFactorial = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.factorial($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uOnlyLogicToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    var opErf = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.erf($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    var opErfc = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.erfc($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    var opErfcx = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = SpecialFunction.erfcx($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_9.OutputDTypeResolver.uToFloat,\r
-                        extraDependencies: { 'SpecialFunction': special_1.SpecialFunction }\r
-                    });\r
-                    return {\r
-                        gammaln: opGammaLn,\r
-                        gamma: opGamma,\r
-                        factorial: opFactorial,\r
-                        erf: opErf,\r
-                        erfc: opErfc,\r
-                        erfcx: opErfcx\r
-                    };\r
-                };\r
-                return SpecialFunctionOpSetFactory;\r
-            }());\r
-            exports_32("SpecialFunctionOpSetFactory", SpecialFunctionOpSetFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/definition", [], function (exports_33, context_33) {\r
-    "use strict";\r
-    var __moduleName = context_33 && context_33.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/logicComp/definition", [], function (exports_34, context_34) {\r
-    "use strict";\r
-    var __moduleName = context_34 && context_34.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/binary/definition", [], function (exports_35, context_35) {\r
-    "use strict";\r
-    var __moduleName = context_35 && context_35.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/data/definition", [], function (exports_36, context_36) {\r
-    "use strict";\r
-    var __moduleName = context_36 && context_36.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/poly/definition", [], function (exports_37, context_37) {\r
-    "use strict";\r
-    var __moduleName = context_37 && context_37.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/set/definition", [], function (exports_38, context_38) {\r
-    "use strict";\r
-    var __moduleName = context_38 && context_38.id;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/random/index", ["jasmal/lib/tensor", "jasmal/lib/ops/random/engine", "jasmal/lib/constant"], function (exports_39, context_39) {\r
-    "use strict";\r
-    var __moduleName = context_39 && context_39.id;\r
-    var tensor_6, engine_1, constant_3, RandomOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_6_1) {\r
-                tensor_6 = tensor_6_1;\r
-            },\r
-            function (engine_1_1) {\r
-                engine_1 = engine_1_1;\r
-            },\r
-            function (constant_3_1) {\r
-                constant_3 = constant_3_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            RandomOpProviderFactory = (function () {\r
-                function RandomOpProviderFactory() {\r
-                }\r
-                RandomOpProviderFactory.create = function (rngEngine) {\r
-                    if (rngEngine === void 0) { rngEngine = 'twister'; }\r
-                    var engine;\r
-                    if (Object.prototype.toString.call(rngEngine) === '[object String]') {\r
-                        switch (rngEngine) {\r
-                            case 'native':\r
-                                engine = new engine_1.NativeEngine();\r
-                                break;\r
-                            case 'twister':\r
-                            case 'MT19937Engine':\r
-                                engine = new engine_1.MT19937Engine();\r
-                                break;\r
-                            default:\r
-                                throw new Error("Unknown random engine name \"" + rngEngine + "\".");\r
-                        }\r
-                    }\r
-                    else {\r
-                        engine = rngEngine;\r
-                    }\r
-                    var randnNeedNewPair = true;\r
-                    var randnNumber2 = 0;\r
-                    function opSeed(s) {\r
-                        if (s == undefined) {\r
-                            return engine.getSeed();\r
-                        }\r
-                        else {\r
-                            engine.setSeed(s);\r
-                            return;\r
-                        }\r
-                    }\r
-                    function opRand(shape) {\r
-                        if (shape) {\r
-                            var t = tensor_6.Tensor.zeros(shape), re = t.realData, i = void 0, n = t.size;\r
-                            for (i = 0; i < n; i++) {\r
-                                re[i] = engine.nextDouble();\r
-                            }\r
-                            return t;\r
-                        }\r
-                        else {\r
-                            return engine.nextDouble();\r
-                        }\r
-                    }\r
-                    ;\r
-                    function opRandn(shape) {\r
-                        if (shape) {\r
-                            var t = tensor_6.Tensor.zeros(shape), re = t.realData, i = void 0, n = t.size;\r
-                            for (i = 0; i < n; i++) {\r
-                                re[i] = _nextRandn();\r
-                            }\r
-                            return t;\r
-                        }\r
-                        else {\r
-                            return _nextRandn();\r
-                        }\r
-                    }\r
-                    function _nextRandn() {\r
-                        if (randnNeedNewPair) {\r
-                            var v1 = void 0, v2 = void 0, rsq = void 0, fac = void 0;\r
-                            do {\r
-                                v1 = 2.0 * engine.nextDouble() - 1.0;\r
-                                v2 = 2.0 * engine.nextDouble() - 1.0;\r
-                                rsq = v1 * v1 + v2 * v2;\r
-                            } while (rsq >= 1.0 || rsq === 0.0);\r
-                            fac = Math.sqrt(-2.0 * Math.log(rsq) / rsq);\r
-                            randnNumber2 = v1 * fac;\r
-                            randnNeedNewPair = false;\r
-                            return v2 * fac;\r
-                        }\r
-                        else {\r
-                            randnNeedNewPair = true;\r
-                            return randnNumber2;\r
-                        }\r
-                    }\r
-                    function opRandi(low, high, shape) {\r
-                        if (high == undefined) {\r
-                            high = low;\r
-                            low = 0;\r
-                        }\r
-                        if ((low < 0) || (low > constant_3.MAX_SAFE_INTEGER) || (Math.floor(low) !== low)) {\r
-                            throw new Error('The value low must be a nonnegative integer that is less than 2^53.');\r
-                        }\r
-                        if ((high < 0) || (high > constant_3.MAX_SAFE_INTEGER) || (Math.floor(high) !== high)) {\r
-                            throw new Error('The value high must be a nonnegative integer that is less than 2^53.');\r
-                        }\r
-                        if (low > high) {\r
-                            throw new Error('The value low cannot be higher than high.');\r
-                        }\r
-                        var range = high - low;\r
-                        if (shape) {\r
-                            var t = tensor_6.Tensor.zeros(shape), re = t.realData;\r
-                            var i = void 0, n = t.size;\r
-                            if (range === 0) {\r
-                                for (i = 0; i < n; i++) {\r
-                                    re[i] = low;\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (i = 0; i < n; i++) {\r
-                                    re[i] = low + _nextRandi(range);\r
-                                }\r
-                            }\r
-                            return t;\r
-                        }\r
-                        else {\r
-                            return range === 0 ? low : low + _nextRandi(range);\r
-                        }\r
-                    }\r
-                    function _nextRandi(max) {\r
-                        var threshold = (constant_3.MAX_SAFE_INTEGER + 1) % (max + 1);\r
-                        var a, b, x;\r
-                        for (;;) {\r
-                            a = engine.nextUint32() >>> 5;\r
-                            b = engine.nextUint32() >>> 6;\r
-                            x = a * 67108864 + b;\r
-                            if (x >= threshold) {\r
-                                return x % (max + 1);\r
-                            }\r
-                        }\r
-                    }\r
-                    function opUnifrnd(low, high, shape) {\r
-                        if (!isFinite(low) || !isFinite(high)) {\r
-                            throw new Error('Lower bound and upper bound must be finite.');\r
-                        }\r
-                        if (low > high) {\r
-                            throw new Error('Lower bound cannot be greater than the upper bound.');\r
-                        }\r
-                        if (shape == undefined) {\r
-                            return low + (high - low) * engine.nextDouble();\r
-                        }\r
-                        else {\r
-                            var X = tensor_6.Tensor.zeros(shape);\r
-                            var reX = X.realData;\r
-                            for (var i = 0; i < reX.length; i++) {\r
-                                reX[i] = low + (high - low) * engine.nextDouble();\r
-                            }\r
-                            return X;\r
-                        }\r
-                    }\r
-                    return {\r
-                        seed: opSeed,\r
-                        rand: opRand,\r
-                        randi: opRandi,\r
-                        randn: opRandn,\r
-                        unifrnd: opUnifrnd\r
-                    };\r
-                };\r
-                return RandomOpProviderFactory;\r
-            }());\r
-            exports_39("RandomOpProviderFactory", RandomOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/arithmetic/index", ["jasmal/lib/dtype"], function (exports_40, context_40) {\r
-    "use strict";\r
-    var __moduleName = context_40 && context_40.id;\r
-    var dtype_10, ArithmeticOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_10_1) {\r
-                dtype_10 = dtype_10_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            ArithmeticOpProviderFactory = (function () {\r
-                function ArithmeticOpProviderFactory() {\r
-                }\r
-                ArithmeticOpProviderFactory.create = function (generator) {\r
-                    return {\r
-                        add: generator.makeBinaryOp({\r
-                            opRR: '$reZ = $reX + $reY;',\r
-                            opRC: '$reZ = $reX + $reY; $imZ = $imY;',\r
-                            opCR: '$reZ = $reX + $reY; $imZ = $imX;',\r
-                            opCC: '$reZ = $reX + $reY; $imZ = $imX + $imY;'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.bWiderWithLogicToInt\r
-                        }),\r
-                        sub: generator.makeBinaryOp({\r
-                            opRR: '$reZ = $reX - $reY;',\r
-                            opRC: '$reZ = $reX - $reY; $imZ = -$imY;',\r
-                            opCR: '$reZ = $reX - $reY; $imZ = $imX;',\r
-                            opCC: '$reZ = $reX - $reY; $imZ = $imX - $imY;'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.bWiderWithLogicToInt\r
-                        }),\r
-                        neg: generator.makeUnaryOp({\r
-                            opR: '$reY = -$reX;',\r
-                            opC: '$reY = -$reX; $imY = -$imX;'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.uOnlyLogicToFloat\r
-                        }),\r
-                        mul: generator.makeBinaryOp({\r
-                            opRR: '$reZ = $reX * $reY;',\r
-                            opRC: '$imZ = $reX * $imY; $reZ = $reX * $reY;',\r
-                            opCR: '$reZ = $reX * $reY; $imZ = $imX * $reY;',\r
-                            opCC: '$tmp1 = $reX; $tmp2 = $reY; $reZ = $tmp1 * $tmp2 - $imX * $imY; $imZ = $tmp1 * $imY + $imX * $tmp2;'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.bWiderWithLogicToInt\r
-                        }),\r
-                        div: generator.makeBinaryOp({\r
-                            opRR: '$reZ = $reX / $reY;',\r
-                            opRC: '$tmp1 = CMath.cdivRC($reX, $reY, $imY); $reZ = $tmp1[0]; $imZ = $tmp1[1];',\r
-                            opCR: '$reZ = $reX / $reY; $imZ = $imX / $reY;',\r
-                            opCC: '$tmp1 = CMath.cdivCC($reX, $imX, $reY, $imY); $reZ = $tmp1[0]; $imZ = $tmp1[1];'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.bToFloat\r
-                        }),\r
-                        reciprocal: generator.makeUnaryOp({\r
-                            opR: '$reY = 1 / $reX;',\r
-                            opC: '$tmp1 = CMath.cReciprocal($reX, $imX); $reY = $tmp1[0]; $imY = $tmp1[1];'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.uOnlyLogicToFloat\r
-                        }),\r
-                        rem: generator.makeRealOutputBinaryOp({\r
-                            opRR: '$reZ = $reX % $reY;'\r
-                        }, {\r
-                            outputDTypeResolver: dtype_10.OutputDTypeResolver.bWiderWithLogicToInt\r
-                        })\r
-                    };\r
-                };\r
-                return ArithmeticOpProviderFactory;\r
-            }());\r
-            exports_40("ArithmeticOpProviderFactory", ArithmeticOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/math/index", ["jasmal/lib/helper/objHelper", "jasmal/lib/ops/math/basic", "jasmal/lib/ops/math/trigonometry", "jasmal/lib/ops/math/pow", "jasmal/lib/ops/math/logexp", "jasmal/lib/ops/math/rounding", "jasmal/lib/ops/math/special"], function (exports_41, context_41) {\r
-    "use strict";\r
-    var __moduleName = context_41 && context_41.id;\r
-    var objHelper_8, basic_1, trigonometry_1, pow_1, logexp_1, rounding_1, special_2, MathOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (objHelper_8_1) {\r
-                objHelper_8 = objHelper_8_1;\r
-            },\r
-            function (basic_1_1) {\r
-                basic_1 = basic_1_1;\r
-            },\r
-            function (trigonometry_1_1) {\r
-                trigonometry_1 = trigonometry_1_1;\r
-            },\r
-            function (pow_1_1) {\r
-                pow_1 = pow_1_1;\r
-            },\r
-            function (logexp_1_1) {\r
-                logexp_1 = logexp_1_1;\r
-            },\r
-            function (rounding_1_1) {\r
-                rounding_1 = rounding_1_1;\r
-            },\r
-            function (special_2_1) {\r
-                special_2 = special_2_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            MathOpProviderFactory = (function () {\r
-                function MathOpProviderFactory() {\r
-                }\r
-                MathOpProviderFactory.create = function (generator) {\r
-                    var basicOps = basic_1.BasicMathOpSetFactory.create(generator);\r
-                    var trigOps = trigonometry_1.TrigMathOpSetFactory.create(generator);\r
-                    var powerOps = pow_1.PowerMathOpSetFactory.create(generator);\r
-                    var logExpOps = logexp_1.LogExpMathOpSetFactory.create(generator);\r
-                    var roundingOps = rounding_1.RoundingMathOpSetFactory.create(generator);\r
-                    var specialOps = special_2.SpecialFunctionOpSetFactory.create(generator);\r
-                    return objHelper_8.ObjectHelper.createExtendChain(basicOps)\r
-                        .extend(trigOps)\r
-                        .extend(powerOps)\r
-                        .extend(logExpOps)\r
-                        .extend(roundingOps)\r
-                        .extend(specialOps)\r
-                        .end();\r
-                };\r
-                return MathOpProviderFactory;\r
-            }());\r
-            exports_41("MathOpProviderFactory", MathOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/core/index", ["jasmal/lib/tensor", "jasmal/lib/helper/shapeHelper", "jasmal/lib/helper/dataHelper", "jasmal/lib/dtype", "jasmal/lib/complexNumber", "jasmal/lib/helper/objHelper"], function (exports_42, context_42) {\r
-    "use strict";\r
-    var __moduleName = context_42 && context_42.id;\r
-    var tensor_7, shapeHelper_5, dataHelper_6, dtype_11, complexNumber_5, objHelper_9, CoreOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_7_1) {\r
-                tensor_7 = tensor_7_1;\r
-            },\r
-            function (shapeHelper_5_1) {\r
-                shapeHelper_5 = shapeHelper_5_1;\r
-            },\r
-            function (dataHelper_6_1) {\r
-                dataHelper_6 = dataHelper_6_1;\r
-            },\r
-            function (dtype_11_1) {\r
-                dtype_11 = dtype_11_1;\r
-            },\r
-            function (complexNumber_5_1) {\r
-                complexNumber_5 = complexNumber_5_1;\r
-            },\r
-            function (objHelper_9_1) {\r
-                objHelper_9 = objHelper_9_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            CoreOpProviderFactory = (function () {\r
-                function CoreOpProviderFactory() {\r
-                }\r
-                CoreOpProviderFactory.create = function (generator) {\r
-                    var opReshape = function (x, shape) {\r
-                        if (x instanceof tensor_7.Tensor) {\r
-                            return x.getReshapedCopy(shape);\r
-                        }\r
-                        else {\r
-                            var X = tensor_7.Tensor.toTensor(x);\r
-                            return X.reshape(shape);\r
-                        }\r
-                    };\r
-                    var opSqueeze = function (x) {\r
-                        if (x instanceof tensor_7.Tensor) {\r
-                            return x.getReshapedCopy(shapeHelper_5.ShapeHelper.getSqueezedShape(x.shape));\r
-                        }\r
-                        else {\r
-                            var X = tensor_7.Tensor.toTensor(x);\r
-                            return X.reshape(shapeHelper_5.ShapeHelper.getSqueezedShape(X.shape));\r
-                        }\r
-                    };\r
-                    var opPrependAxis = function (x) {\r
-                        var X = x instanceof tensor_7.Tensor ? x : tensor_7.Tensor.toTensor(x);\r
-                        return X.copy().prependAxis();\r
-                    };\r
-                    var opAppendAxis = function (x) {\r
-                        var X = x instanceof tensor_7.Tensor ? x : tensor_7.Tensor.toTensor(x);\r
-                        return X.copy().appendAxis();\r
-                    };\r
-                    var opFlatten = function (x) {\r
-                        return x instanceof tensor_7.Tensor\r
-                            ? x.getReshapedCopy([-1])\r
-                            : tensor_7.Tensor.toTensor(x).reshape([-1]);\r
-                    };\r
-                    var opVec = function (x) {\r
-                        return x instanceof tensor_7.Tensor\r
-                            ? x.getReshapedCopy([-1, 1])\r
-                            : tensor_7.Tensor.toTensor(x).reshape([-1, 1]);\r
-                    };\r
-                    var opTile = function (x, repeats) {\r
-                        var X = x instanceof tensor_7.Tensor ? x : tensor_7.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (repeats.length < shapeX.length) {\r
-                            var repeatsOld = repeats;\r
-                            repeats = new Array(shapeX.length);\r
-                            var i_2 = 0, diff = shapeX.length - repeatsOld.length;\r
-                            for (; i_2 < diff; i_2++) {\r
-                                repeats[i_2] = 0;\r
-                            }\r
-                            for (; i_2 < shapeX.length; i_2++) {\r
-                                repeats[i_2] = repeatsOld[i_2 - diff];\r
-                            }\r
-                        }\r
-                        var nExtraDims = repeats.length - shapeX.length;\r
-                        var shapeY = new Array(repeats.length);\r
-                        var i = 0;\r
-                        for (; i < nExtraDims; i++) {\r
-                            shapeY[i] = repeats[i];\r
-                        }\r
-                        for (; i < repeats.length; i++) {\r
-                            shapeY[i] = repeats[i] * shapeX[i - nExtraDims];\r
-                        }\r
-                        var Y = tensor_7.Tensor.zeros(shapeY, X.dtype);\r
-                        if (X.isEmpty()) {\r
-                            return Y;\r
-                        }\r
-                        tileImpl(X.realData, shapeX, repeats, Y.realData, shapeY);\r
-                        if (X.hasComplexStorage()) {\r
-                            Y.ensureComplexStorage();\r
-                            tileImpl(X.imagData, shapeX, repeats, Y.imagData, shapeY);\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    var tileImpl = function (X, shapeX, repeats, Y, shapeY) {\r
-                        if (X.length === 1) {\r
-                            for (var i = 0; i < Y.length; i++) {\r
-                                Y[i] = X[0];\r
-                            }\r
-                            return;\r
-                        }\r
-                        var nExtraDims = shapeY.length - shapeX.length;\r
-                        var stridesY = shapeHelper_5.ShapeHelper.computeStrides(shapeY);\r
-                        var nCopy = repeats[nExtraDims];\r
-                        for (var i = 0; i < nExtraDims; i++) {\r
-                            nCopy *= repeats[i];\r
-                        }\r
-                        var directCopy = true;\r
-                        for (var i = nExtraDims + 1; i < repeats.length; i++) {\r
-                            if (repeats[i] !== 1) {\r
-                                directCopy = false;\r
-                                break;\r
-                            }\r
-                        }\r
-                        if (directCopy) {\r
-                            for (var i = 0; i < X.length; i++) {\r
-                                Y[i] = X[i];\r
-                            }\r
-                        }\r
-                        else {\r
-                            var stridesX_1 = shapeHelper_5.ShapeHelper.computeStrides(shapeX);\r
-                            var maxLevel_1 = shapeX.length - 1;\r
-                            var doTile_1 = function (level, offsetX, offsetY) {\r
-                                if (level === maxLevel_1) {\r
-                                    if (shapeX[level] === 1) {\r
-                                        for (var j = 0; j < repeats[nExtraDims + level]; j++) {\r
-                                            Y[offsetY + j] = X[offsetX];\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (var j = 0; j < repeats[nExtraDims + level]; j++) {\r
-                                            for (var i = 0; i < shapeX[level]; i++) {\r
-                                                Y[offsetY + i] = X[offsetX + i];\r
-                                            }\r
-                                            offsetY += stridesY[nExtraDims + level] * shapeX[level];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    var offsetX0 = offsetX;\r
-                                    for (var j = 0; j < repeats[nExtraDims + level]; j++) {\r
-                                        offsetX = offsetX0;\r
-                                        for (var i = 0; i < shapeX[level]; i++) {\r
-                                            doTile_1(level + 1, offsetX, offsetY);\r
-                                            offsetX += stridesX_1[level];\r
-                                            offsetY += stridesY[nExtraDims + level];\r
-                                        }\r
-                                    }\r
-                                }\r
-                            };\r
-                            var tmp = repeats[nExtraDims];\r
-                            repeats[nExtraDims] = 1;\r
-                            doTile_1(0, 0, 0);\r
-                            repeats[nExtraDims] = tmp;\r
-                        }\r
-                        var offsetY = stridesY[nExtraDims] * shapeX[0], strideCopy = offsetY;\r
-                        for (var i = 1; i < nCopy; i++) {\r
-                            for (var j = 0; j < strideCopy; j++) {\r
-                                Y[offsetY + j] = Y[j];\r
-                            }\r
-                            offsetY += strideCopy;\r
-                        }\r
-                    };\r
-                    var opConcat = function (inputs, axis) {\r
-                        if (axis === void 0) { axis = 0; }\r
-                        if (inputs.length === 0) {\r
-                            throw new Error('At least one input expected.');\r
-                        }\r
-                        var t = inputs[0];\r
-                        if (inputs.length === 1) {\r
-                            return t instanceof tensor_7.Tensor ? t.copy() : tensor_7.Tensor.toTensor(t);\r
-                        }\r
-                        var tensors = new Array(inputs.length);\r
-                        var shapes = new Array(inputs.length);\r
-                        var strides = new Array(inputs.length);\r
-                        var first = t instanceof tensor_7.Tensor ? t : tensor_7.Tensor.toTensor(t);\r
-                        tensors[0] = first;\r
-                        shapes[0] = first.shape;\r
-                        strides[0] = first.strides;\r
-                        var finalShape = first.shape;\r
-                        var finalDType = first.dtype;\r
-                        var needComplexStorage = first.hasComplexStorage();\r
-                        var ndim = finalShape.length;\r
-                        for (var i = 1; i < inputs.length; i++) {\r
-                            var curInput = inputs[i];\r
-                            var curTensor = curInput instanceof tensor_7.Tensor ? curInput : tensor_7.Tensor.toTensor(curInput);\r
-                            var curShape = curTensor.shape;\r
-                            if (curShape.length !== ndim) {\r
-                                throw new Error('Tensors being concatenated must share the same number of dimensions.');\r
-                            }\r
-                            for (var j = 0; j < ndim; j++) {\r
-                                if (j === axis) {\r
-                                    finalShape[axis] += curShape[axis];\r
-                                }\r
-                                else {\r
-                                    if (curShape[j] !== finalShape[j]) {\r
-                                        throw new Error('Tensors being concatenated must have matching dimensions ' +\r
-                                            'except the dimension being concatenated.');\r
-                                    }\r
-                                }\r
-                            }\r
-                            finalDType = dtype_11.DTypeHelper.getWiderType(finalDType, curTensor.dtype);\r
-                            needComplexStorage = needComplexStorage || curTensor.hasComplexStorage();\r
-                            tensors[i] = curTensor;\r
-                            shapes[i] = curShape;\r
-                            strides[i] = curTensor.strides;\r
-                        }\r
-                        var Y = tensor_7.Tensor.zeros(finalShape, finalDType);\r
-                        if (needComplexStorage) {\r
-                            Y.ensureComplexStorage();\r
-                        }\r
-                        if (axis === 0) {\r
-                            var offset = 0;\r
-                            for (var i = 0; i < tensors.length; i++) {\r
-                                if (!tensors[i].isEmpty()) {\r
-                                    dataHelper_6.DataHelper.copy(tensors[i].realData, Y.realData, offset);\r
-                                    if (tensors[i].hasComplexStorage()) {\r
-                                        dataHelper_6.DataHelper.copy(tensors[i].imagData, Y.imagData, offset);\r
-                                    }\r
-                                    offset += tensors[i].size;\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            var finalStrides = Y.strides;\r
-                            var axisOffset = 0;\r
-                            for (var i = 0; i < tensors.length; i++) {\r
-                                if (!tensors[i].isEmpty()) {\r
-                                    copyWithAxisOffset(tensors[i].realData, shapes[i], strides[i], Y.realData, finalStrides, axis, axisOffset);\r
-                                    if (tensors[i].hasComplexStorage()) {\r
-                                        copyWithAxisOffset(tensors[i].imagData, shapes[i], strides[i], Y.imagData, finalStrides, axis, axisOffset);\r
-                                    }\r
-                                    axisOffset += shapes[i][axis];\r
-                                }\r
-                            }\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    function copyWithAxisOffset(source, sourceShape, sourceStrides, target, targetStrides, axis, axisOffset) {\r
-                        var maxLevel = sourceShape.length - 1;\r
-                        var doCopy = function (level, offsetS, offsetT) {\r
-                            if (level === maxLevel) {\r
-                                for (var i = 0; i < sourceShape[level]; i++) {\r
-                                    target[offsetT + i] = source[offsetS + i];\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (var i = 0; i < sourceShape[level]; i++) {\r
-                                    doCopy(level + 1, offsetS, offsetT);\r
-                                    offsetS += sourceStrides[level];\r
-                                    offsetT += targetStrides[level];\r
-                                }\r
-                            }\r
-                        };\r
-                        doCopy(0, 0, targetStrides[axis] * axisOffset);\r
-                    }\r
-                    var opPermuteAxis = function (x, order) {\r
-                        var X = x instanceof tensor_7.Tensor ? x : tensor_7.Tensor.toTensor(x);\r
-                        var ndim = X.ndim;\r
-                        if (order.length !== ndim) {\r
-                            throw new Error('New ordering must have the same length of the original shape.');\r
-                        }\r
-                        var flags = new Array(ndim);\r
-                        for (var i = 0; i < order.length; i++) {\r
-                            if (order[i] < 0 || (order[i] | 0) !== order[i]) {\r
-                                throw new Error('Ordering must be specified using nonnegative integers.');\r
-                            }\r
-                            if (order[i] >= ndim) {\r
-                                throw new Error('Elements in order must be smaller than the number of dimensions.');\r
-                            }\r
-                            if (flags[order[i]]) {\r
-                                throw new Error('Order cannot contain duplicates.');\r
-                            }\r
-                            flags[order[i]] = true;\r
-                        }\r
-                        var shapeX = X.shape;\r
-                        var shapeY = new Array(ndim);\r
-                        for (var i = 0; i < ndim; i++) {\r
-                            shapeY[i] = shapeX[order[i]];\r
-                        }\r
-                        var Y = tensor_7.Tensor.zeros(shapeY, X.dtype);\r
-                        if (X.isEmpty()) {\r
-                            return Y;\r
-                        }\r
-                        var stridesX = X.strides;\r
-                        var stridesY = Y.strides;\r
-                        permuteAxis(X.realData, Y.realData, shapeX, order, stridesX, stridesY, 0, 0, 0);\r
-                        if (X.hasComplexStorage()) {\r
-                            Y.ensureComplexStorage();\r
-                            permuteAxis(X.imagData, Y.imagData, shapeX, order, stridesX, stridesY, 0, 0, 0);\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    var permuteAxis = function (source, target, sourceShape, order, sourceStrides, targetStrides, level, offsetSource, offsetTarget) {\r
-                        if (level === sourceShape.length - 1) {\r
-                            for (var i = 0; i < sourceShape[order[level]]; i++) {\r
-                                target[offsetTarget + i] = source[offsetSource];\r
-                                offsetSource += sourceStrides[order[level]];\r
-                            }\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < sourceShape[order[level]]; i++) {\r
-                                permuteAxis(source, target, sourceShape, order, sourceStrides, targetStrides, level + 1, offsetSource, offsetTarget);\r
-                                offsetTarget += targetStrides[level];\r
-                                offsetSource += sourceStrides[order[level]];\r
-                            }\r
-                        }\r
-                    };\r
-                    var opReal = function (x) {\r
-                        return x instanceof tensor_7.Tensor ? x.real() : tensor_7.Tensor.toTensor(x).real();\r
-                    };\r
-                    var opImag = function (x) {\r
-                        if (x instanceof tensor_7.Tensor) {\r
-                            return x.imag();\r
-                        }\r
-                        else if (x instanceof complexNumber_5.ComplexNumber) {\r
-                            return tensor_7.Tensor.scalar(x.im);\r
-                        }\r
-                        else if (typeof x === 'number') {\r
-                            return tensor_7.Tensor.scalar(0);\r
-                        }\r
-                        else {\r
-                            var shape = shapeHelper_5.ShapeHelper.inferShapeFromArray(x);\r
-                            shapeHelper_5.ShapeHelper.validateArrayShape(x, shape);\r
-                            return tensor_7.Tensor.zeros(shape);\r
-                        }\r
-                    };\r
-                    var opIsEmpty = function (x) {\r
-                        if (x instanceof tensor_7.Tensor) {\r
-                            return x.isEmpty();\r
-                        }\r
-                        else if (Array.isArray(x)) {\r
-                            if (x.length === 0) {\r
-                                return true;\r
-                            }\r
-                            var shape = shapeHelper_5.ShapeHelper.inferShapeFromArray(x);\r
-                            shapeHelper_5.ShapeHelper.validateArrayShape(x, shape);\r
-                            return shapeHelper_5.ShapeHelper.getSizeFromShape(shape) === 0;\r
-                        }\r
-                        else if (objHelper_9.ObjectHelper.isTypedArray(x)) {\r
-                            return x.length === 0;\r
-                        }\r
-                        else if (x instanceof complexNumber_5.ComplexNumber || typeof x === 'number') {\r
-                            return false;\r
-                        }\r
-                        else {\r
-                            throw new Error("Unsupported input type \"" + Object.prototype.toString.call(x) + "\".");\r
-                        }\r
-                    };\r
-                    var opIsReal = function (x) {\r
-                        if (x instanceof tensor_7.Tensor) {\r
-                            return !x.hasNonZeroComplexStorage();\r
-                        }\r
-                        else if (x instanceof complexNumber_5.ComplexNumber) {\r
-                            return x.im === 0;\r
-                        }\r
-                        else {\r
-                            return true;\r
-                        }\r
-                    };\r
-                    var opIsNaN = generator.makeUnaryOp({\r
-                        opR: '$reY = isNaN($reX) ? 1 : 0;',\r
-                        opC: '$reY = isNaN($reX) || isNaN($imX) ? 1 : 0'\r
-                    }, {\r
-                        noInPlaceOperation: true,\r
-                        outputDTypeResolver: dtype_11.OutputDTypeResolver.uToLogic\r
-                    });\r
-                    var opIsInf = generator.makeUnaryOp({\r
-                        opR: '$reY = !isFinite($reX) && !isNaN($reX) ? 1 : 0',\r
-                        opC: '$reY = (!isFinite($reX) && !isNaN($reX)) || (!isFinite($imX) && !isNaN($imX)) ? 1 : 0;'\r
-                    }, {\r
-                        noInPlaceOperation: true,\r
-                        outputDTypeResolver: dtype_11.OutputDTypeResolver.uToLogic\r
-                    });\r
-                    var opFind = function (x, f) {\r
-                        var t = x instanceof tensor_7.Tensor ? x : tensor_7.Tensor.toTensor(x);\r
-                        var indices;\r
-                        var reX = t.realData;\r
-                        var imX;\r
-                        if (f) {\r
-                            if (t.hasComplexStorage()) {\r
-                                imX = t.imagData;\r
-                                indices = dataHelper_6.DataHelper.findWithCallbackComplex(reX, imX, f);\r
-                            }\r
-                            else {\r
-                                indices = dataHelper_6.DataHelper.findWithCallbackReal(reX, f);\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (t.hasComplexStorage()) {\r
-                                imX = t.imagData;\r
-                                indices = dataHelper_6.DataHelper.findComplex(reX, imX);\r
-                            }\r
-                            else {\r
-                                indices = dataHelper_6.DataHelper.findReal(reX);\r
-                            }\r
-                        }\r
-                        return indices;\r
-                    };\r
-                    var opLinspace = function (x1, x2, n) {\r
-                        if (n < 1) {\r
-                            throw new Error('Number of samples n must be greater or equal to 1.');\r
-                        }\r
-                        if (!isFinite(x1) || !isFinite(x2) || !isFinite(n)) {\r
-                            throw new Error('Inputs must be finite.');\r
-                        }\r
-                        n = Math.floor(n);\r
-                        var y;\r
-                        if (n === 1) {\r
-                            y = tensor_7.Tensor.scalar(x2);\r
-                        }\r
-                        else {\r
-                            y = tensor_7.Tensor.zeros([n]);\r
-                            var n1 = n - 1;\r
-                            var delta = x2 / n1 - x1 / n1;\r
-                            y.realData[0] = x1;\r
-                            y.realData[n1] = x2;\r
-                            for (var i = 1; i < n - 1; i++) {\r
-                                y.realData[i] = x1 + i * delta;\r
-                            }\r
-                        }\r
-                        return y;\r
-                    };\r
-                    var opLogspace = function (x1, x2, n, base) {\r
-                        if (base === void 0) { base = 10; }\r
-                        if (base <= 0 || !isFinite(base)) {\r
-                            throw new Error('Base must be a finite nonnegative real number.');\r
-                        }\r
-                        var Y = opLinspace(x1, x2, n);\r
-                        var re = Y.realData;\r
-                        for (var i = 0; i < n; i++) {\r
-                            re[i] = Math.pow(base, re[i]);\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    var opMeshgrid = function (x, y) {\r
-                        var xv = opFlatten(x);\r
-                        var yv = opVec(y);\r
-                        return [opTile(xv, [yv.size, 1]), opTile(yv, [1, xv.size])];\r
-                    };\r
-                    return {\r
-                        reshape: opReshape,\r
-                        flatten: opFlatten,\r
-                        vec: opVec,\r
-                        squeeze: opSqueeze,\r
-                        tile: opTile,\r
-                        concat: opConcat,\r
-                        permuteAxis: opPermuteAxis,\r
-                        prependAxis: opPrependAxis,\r
-                        appendAxis: opAppendAxis,\r
-                        linspace: opLinspace,\r
-                        logspace: opLogspace,\r
-                        meshgrid: opMeshgrid,\r
-                        real: opReal,\r
-                        imag: opImag,\r
-                        isempty: opIsEmpty,\r
-                        isreal: opIsReal,\r
-                        isnan: opIsNaN,\r
-                        isinf: opIsInf,\r
-                        find: opFind\r
-                    };\r
-                };\r
-                return CoreOpProviderFactory;\r
-            }());\r
-            exports_42("CoreOpProviderFactory", CoreOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/logicComp/index", ["jasmal/lib/dtype", "jasmal/lib/tensor", "jasmal/lib/helper/dataHelper"], function (exports_43, context_43) {\r
-    "use strict";\r
-    var __moduleName = context_43 && context_43.id;\r
-    var dtype_12, tensor_8, dataHelper_7, LogicComparisonOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_12_1) {\r
-                dtype_12 = dtype_12_1;\r
-            },\r
-            function (tensor_8_1) {\r
-                tensor_8 = tensor_8_1;\r
-            },\r
-            function (dataHelper_7_1) {\r
-                dataHelper_7 = dataHelper_7_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            LogicComparisonOpProviderFactory = (function () {\r
-                function LogicComparisonOpProviderFactory() {\r
-                }\r
-                LogicComparisonOpProviderFactory.create = function (generator) {\r
-                    var opEq = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX === $reY) ? 1 : 0;',\r
-                        opRC: '$reZ = ($reX === $reY && $imY === 0) ? 1 : 0;',\r
-                        opCR: '$reZ = ($reX === $reY && $imX === 0) ? 1 : 0;',\r
-                        opCC: '$reZ = ($reX === $reY && $imX === $imY) ? 1 : 0'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogic,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opNeq = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX !== $reY) ? 1 : 0;',\r
-                        opRC: '$reZ = ($reX !== $reY || $imY !== 0) ? 1 : 0;',\r
-                        opCR: '$reZ = ($reX !== $reY || $imX !== 0) ? 1 : 0;',\r
-                        opCC: '$reZ = ($reX !== $reY || $imX !== $imY) ? 1 : 0'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogic,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opGt = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX > $reY) ? 1 : 0;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opGe = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX >= $reY) ? 1 : 0;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opLt = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX < $reY) ? 1 : 0;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opLe = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX <= $reY) ? 1 : 0;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                        noInPlaceOperation: true\r
-                    });\r
-                    var opAnd = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX !== 0) & ($reY !== 0);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                    });\r
-                    var opOr = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX !== 0) | ($reY !== 0);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                    });\r
-                    var opXor = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX !== 0) ^ ($reY !== 0);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.bToLogicRealOnly,\r
-                    });\r
-                    var opNot = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = ($reX !== 0) ? 0 : 1;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_12.OutputDTypeResolver.uToLogicRealOnly,\r
-                    });\r
-                    var opAll = function (x) {\r
-                        var v = tensor_8.Tensor.analyzeOpInput(x);\r
-                        if (v.hasOnlyOneElement) {\r
-                            return v.re !== 0 || v.im !== 0;\r
-                        }\r
-                        else {\r
-                            var re = v.reArr;\r
-                            if (v.isComplex) {\r
-                                var im = v.imArr;\r
-                                for (var i = 0; i < re.length; i++) {\r
-                                    if (re[i] === 0 && im[i] === 0) {\r
-                                        return false;\r
-                                    }\r
-                                }\r
-                                return true;\r
-                            }\r
-                            else {\r
-                                return dataHelper_7.DataHelper.isArrayAllNonZeros(re);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opAny = function (x) {\r
-                        var v = tensor_8.Tensor.analyzeOpInput(x);\r
-                        if (v.hasOnlyOneElement) {\r
-                            return v.re !== 0 || v.im !== 0;\r
-                        }\r
-                        else {\r
-                            var re = v.reArr;\r
-                            if (v.isComplex) {\r
-                                var im = v.imArr;\r
-                                for (var i = 0; i < re.length; i++) {\r
-                                    if (re[i] !== 0 || im[i] !== 0) {\r
-                                        return true;\r
-                                    }\r
-                                }\r
-                                return false;\r
-                            }\r
-                            else {\r
-                                return !dataHelper_7.DataHelper.isArrayAllZeros(re);\r
-                            }\r
-                        }\r
-                    };\r
-                    return {\r
-                        eq: opEq,\r
-                        neq: opNeq,\r
-                        gt: opGt,\r
-                        ge: opGe,\r
-                        lt: opLt,\r
-                        le: opLe,\r
-                        and: opAnd,\r
-                        or: opOr,\r
-                        xor: opXor,\r
-                        not: opNot,\r
-                        all: opAll,\r
-                        any: opAny\r
-                    };\r
-                };\r
-                return LogicComparisonOpProviderFactory;\r
-            }());\r
-            exports_43("LogicComparisonOpProviderFactory", LogicComparisonOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/binary/index", ["jasmal/lib/dtype"], function (exports_44, context_44) {\r
-    "use strict";\r
-    var __moduleName = context_44 && context_44.id;\r
-    var dtype_13, BinaryOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (dtype_13_1) {\r
-                dtype_13 = dtype_13_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            BinaryOpProviderFactory = (function () {\r
-                function BinaryOpProviderFactory() {\r
-                }\r
-                BinaryOpProviderFactory.create = function (generator) {\r
-                    var opBitwiseAnd = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = $reX & $reY;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt,\r
-                    });\r
-                    var opBitwiseOr = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = $reX | $reY;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt,\r
-                    });\r
-                    var opBitwiseXor = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = $reX ^ $reY;'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt,\r
-                    });\r
-                    var opBitwiseNot = generator.makeRealOutputUnaryOp({\r
-                        opR: '$reY = ~($reX);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.uNoChangeExceptLogicToInt,\r
-                    });\r
-                    var opLeftShift = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX) << ($reY);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt\r
-                    });\r
-                    var opRightShiftSP = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX) >> ($reY);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt\r
-                    });\r
-                    var opRightShiftZF = generator.makeRealOutputBinaryOp({\r
-                        opRR: '$reZ = ($reX) >>> ($reY);'\r
-                    }, {\r
-                        outputDTypeResolver: dtype_13.OutputDTypeResolver.bWiderWithLogicToInt\r
-                    });\r
-                    return {\r
-                        bitwiseAnd: opBitwiseAnd,\r
-                        bitwiseOr: opBitwiseOr,\r
-                        bitwiseXor: opBitwiseXor,\r
-                        bitwiseNot: opBitwiseNot,\r
-                        leftShift: opLeftShift,\r
-                        rightShiftSP: opRightShiftSP,\r
-                        rightShiftZF: opRightShiftZF,\r
-                    };\r
-                };\r
-                return BinaryOpProviderFactory;\r
-            }());\r
-            exports_44("BinaryOpProviderFactory", BinaryOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/matmul", [], function (exports_45, context_45) {\r
-    "use strict";\r
-    var __moduleName = context_45 && context_45.id;\r
-    var BuiltInMMB;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            BuiltInMMB = (function () {\r
-                function BuiltInMMB() {\r
-                }\r
-                BuiltInMMB.prototype.mulmm = function (m, n, p, modB, A, B, C) {\r
-                    if (n === 1) {\r
-                        this._mulvv(m, p, A, B, C);\r
-                    }\r
-                    else if (m === 1) {\r
-                        this._mulvm(n, p, modB, A, B, C);\r
-                    }\r
-                    else {\r
-                        this._mulmm(m, n, p, modB, A, B, C);\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._mulvv = function (m, p, A, B, C) {\r
-                    for (var i = 0; i < m; i++) {\r
-                        for (var j = 0; j < p; j++) {\r
-                            C[i * p + j] = A[i] * B[j];\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._mulvm = function (n, p, mobB, A, B, C) {\r
-                    if (mobB === 0) {\r
-                        for (var j = 0; j < p; j++) {\r
-                            C[j] = A[0] * B[j];\r
-                        }\r
-                        for (var i = 1; i < n; i++) {\r
-                            for (var j = 0; j < p; j++) {\r
-                                C[j] += A[i] * B[i * p + j];\r
-                            }\r
-                        }\r
-                    }\r
-                    else if (mobB === 1 || mobB === 2) {\r
-                        for (var i = 0; i < p; i++) {\r
-                            var acc = A[0] * B[i * n];\r
-                            for (var j = 1; j < n; j++) {\r
-                                acc += A[j] * B[i * n + j];\r
-                            }\r
-                            C[i] = acc;\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._mulmm = function (m, n, p, modB, A, B, C) {\r
-                    var i, j, k, acc;\r
-                    if (modB === 0) {\r
-                        if (n < 16 && p < 16) {\r
-                            for (j = 0; j < p; j++) {\r
-                                for (i = 0; i < m; i++) {\r
-                                    acc = 0;\r
-                                    for (k = 0; k < n; k++) {\r
-                                        acc += A[i * n + k] * B[k * p + j];\r
-                                    }\r
-                                    C[i * p + j] = acc;\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            var columnCache = p === 1 ? B : new Array(n);\r
-                            for (j = 0; j < p; j++) {\r
-                                if (p !== 1) {\r
-                                    for (k = 0; k < n; k++) {\r
-                                        columnCache[k] = B[k * p + j];\r
-                                    }\r
-                                }\r
-                                for (i = 0; i < m; i++) {\r
-                                    var offset = i * n;\r
-                                    var acc_1 = A[offset] * columnCache[0];\r
-                                    k = 1;\r
-                                    for (; k < n - 1; k += 2) {\r
-                                        acc_1 += A[offset + k] * columnCache[k] +\r
-                                            A[offset + k + 1] * columnCache[k + 1];\r
-                                    }\r
-                                    if (k === n - 1) {\r
-                                        acc_1 += A[offset + k] * columnCache[k];\r
-                                    }\r
-                                    C[i * p + j] = acc_1;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    else if (modB === 1 || modB === 2) {\r
-                        for (i = 0; i < m; i++) {\r
-                            for (j = 0; j < p; j++) {\r
-                                var offsetA = i * n, offsetB = j * n;\r
-                                var acc_2 = A[offsetA] * B[offsetB];\r
-                                for (k = 1; k < n; k++) {\r
-                                    acc_2 += A[offsetA + k] * B[offsetB + k];\r
-                                }\r
-                                C[i * p + j] = acc_2;\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype.cmulmm = function (m, n, p, modB, reA, imA, reB, imB, reC, imC) {\r
-                    if (n === 1) {\r
-                        this._cmulvv(m, p, modB, reA, imA, reB, imB, reC, imC);\r
-                    }\r
-                    else if (m === 1) {\r
-                        this._cmulvm(n, p, modB, reA, imA, reB, imB, reC, imC);\r
-                    }\r
-                    else {\r
-                        this._cmulmm(m, n, p, modB, reA, imA, reB, imB, reC, imC);\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._cmulvv = function (m, p, modB, reA, imA, reB, imB, reC, imC) {\r
-                    if (modB === 0 || modB === 1) {\r
-                        for (var i = 0; i < m; i++) {\r
-                            for (var j = 0; j < p; j++) {\r
-                                reC[i * p + j] = reA[i] * reB[j] - imA[i] * imB[j];\r
-                                imC[i * p + j] = reA[i] * imB[j] + imA[i] * reB[j];\r
-                            }\r
-                        }\r
-                    }\r
-                    else if (modB === 2) {\r
-                        for (var i = 0; i < m; i++) {\r
-                            for (var j = 0; j < p; j++) {\r
-                                reC[i * p + j] = reA[i] * reB[j] + imA[i] * imB[j];\r
-                                imC[i * p + j] = -reA[i] * imB[j] + imA[i] * reB[j];\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._cmulvm = function (n, p, modB, reA, imA, reB, imB, reC, imC) {\r
-                    var i, j;\r
-                    var accRe, accIm;\r
-                    if (modB === 0) {\r
-                        for (j = 0; j < p; j++) {\r
-                            reC[j] = reA[0] * reB[j] - imA[0] * imB[j];\r
-                            imC[j] = reA[0] * imB[j] + imA[0] * reB[j];\r
-                        }\r
-                        for (i = 1; i < n; i++) {\r
-                            for (j = 0; j < p; j++) {\r
-                                reC[j] += reA[i] * reB[i * p + j] - imA[i] * imB[i * p + j];\r
-                                imC[j] += reA[i] * imB[i * p + j] + imA[i] * reB[i * p + j];\r
-                            }\r
-                        }\r
-                    }\r
-                    else if (modB === 1) {\r
-                        for (j = 0; j < p; j++) {\r
-                            accRe = reA[0] * reB[j * n] - imA[0] * imB[j * n];\r
-                            accIm = reA[0] * imB[j * n] + imA[0] * reB[j * n];\r
-                            for (i = 1; i < n; i++) {\r
-                                accRe += reA[i] * reB[j * n + i] - imA[i] * imB[j * n + i];\r
-                                accIm += reA[i] * imB[j * n + i] + imA[i] * reB[j * n + i];\r
-                            }\r
-                            reC[j] = accRe;\r
-                            imC[j] = accIm;\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (j = 0; j < p; j++) {\r
-                            accRe = reA[0] * reB[j * n] + imA[0] * imB[j * n];\r
-                            accIm = -reA[0] * imB[j * n] + imA[0] * reB[j * n];\r
-                            for (i = 1; i < n; i++) {\r
-                                accRe += reA[i] * reB[j * n + i] + imA[i] * imB[j * n + i];\r
-                                accIm += -reA[i] * imB[j * n + i] + imA[i] * reB[j * n + i];\r
-                            }\r
-                            reC[j] = accRe;\r
-                            imC[j] = accIm;\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMMB.prototype._cmulmm = function (m, n, p, modB, reA, imA, reB, imB, reC, imC) {\r
-                    var i, j, k;\r
-                    var accRe, accIm;\r
-                    if (modB === 0) {\r
-                        if (n < 16 && p < 16) {\r
-                            for (j = 0; j < p; j++) {\r
-                                for (i = 0; i < m; i++) {\r
-                                    accRe = 0;\r
-                                    accIm = 0;\r
-                                    for (k = 0; k < n; k++) {\r
-                                        accRe += reA[i * n + k] * reB[k * p + j] - imA[i * n + k] * imB[k * p + j];\r
-                                        accIm += reA[i * n + k] * imB[k * p + j] + imA[i * n + k] * reB[k * p + j];\r
-                                    }\r
-                                    reC[i * p + j] = accRe;\r
-                                    imC[i * p + j] = accIm;\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            var columnCacheRe = p === 1 ? reB : new Array(n);\r
-                            var columnCacheIm = p === 1 ? imB : new Array(n);\r
-                            for (j = 0; j < p; j++) {\r
-                                if (p !== 1) {\r
-                                    for (k = 0; k < n; k++) {\r
-                                        columnCacheRe[k] = reB[k * p + j];\r
-                                        columnCacheIm[k] = imB[k * p + j];\r
-                                    }\r
-                                }\r
-                                for (i = 0; i < m; i++) {\r
-                                    accRe = reA[i * n] * columnCacheRe[0] - imA[i * n] * columnCacheIm[0];\r
-                                    accIm = reA[i * n] * columnCacheIm[0] + imA[i * n] * columnCacheRe[0];\r
-                                    for (k = 1; k < n; k++) {\r
-                                        accRe += reA[i * n + k] * columnCacheRe[k] - imA[i * n + k] * columnCacheIm[k];\r
-                                        accIm += reA[i * n + k] * columnCacheIm[k] + imA[i * n + k] * columnCacheRe[k];\r
-                                    }\r
-                                    reC[i * p + j] = accRe;\r
-                                    imC[i * p + j] = accIm;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    else if (modB === 1) {\r
-                        for (i = 0; i < m; i++) {\r
-                            for (j = 0; j < p; j++) {\r
-                                accRe = reA[i * n] * reB[j * n] - imA[i * n] * imB[j * n];\r
-                                accIm = reA[i * n] * imB[j * n] + imA[i * n] * reB[j * n];\r
-                                for (k = 1; k < n; k++) {\r
-                                    accRe += reA[i * n + k] * reB[j * n + k] - imA[i * n + k] * imB[j * n + k];\r
-                                    accIm += reA[i * n + k] * imB[j * n + k] + imA[i * n + k] * reB[j * n + k];\r
-                                }\r
-                                reC[i * p + j] = accRe;\r
-                                imC[i * p + j] = accIm;\r
-                            }\r
-                        }\r
-                    }\r
-                    else {\r
-                        for (i = 0; i < m; i++) {\r
-                            for (j = 0; j < p; j++) {\r
-                                accRe = reA[i * n] * reB[j * n] + imA[i * n] * imB[j * n];\r
-                                accIm = -reA[i * n] * imB[j * n] + imA[i * n] * reB[j * n];\r
-                                for (k = 1; k < n; k++) {\r
-                                    accRe += reA[i * n + k] * reB[j * n + k] + imA[i * n + k] * imB[j * n + k];\r
-                                    accIm += -reA[i * n + k] * imB[j * n + k] + imA[i * n + k] * reB[j * n + k];\r
-                                }\r
-                                reC[i * p + j] = accRe;\r
-                                imC[i * p + j] = accIm;\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                return BuiltInMMB;\r
-            }());\r
-            exports_45("BuiltInMMB", BuiltInMMB);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/transpose", [], function (exports_46, context_46) {\r
-    "use strict";\r
-    var __moduleName = context_46 && context_46.id;\r
-    var BuiltInMTB;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            BuiltInMTB = (function () {\r
-                function BuiltInMTB(chunkSize) {\r
-                    if (chunkSize === void 0) { chunkSize = 32; }\r
-                    this._chunkSize = chunkSize;\r
-                }\r
-                BuiltInMTB.prototype.transpose = function (dims, A, B) {\r
-                    if (B === A) {\r
-                        throw new Error('In-place transpose is not supported.');\r
-                    }\r
-                    var nr = dims[0], nc = dims[1], blockSize = this._chunkSize;\r
-                    for (var ii = 0; ii < nr; ii += blockSize) {\r
-                        for (var jj = 0; jj < nc; jj += blockSize) {\r
-                            var iMax = ii + Math.min(blockSize, nr - ii);\r
-                            var jMax = jj + Math.min(blockSize, nc - jj);\r
-                            for (var i = ii; i < iMax; i++) {\r
-                                for (var j = jj; j < jMax; j++) {\r
-                                    B[j * nr + i] = A[i * nc + j];\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                BuiltInMTB.prototype.hermitian = function (dims, reA, imA, reB, imB) {\r
-                    var nr = dims[0];\r
-                    var nc = dims[1];\r
-                    var blockSize = this._chunkSize;\r
-                    this.transpose(dims, reA, reB);\r
-                    if (imA === imB) {\r
-                        throw new Error('In-place Hermitian is not supported.');\r
-                    }\r
-                    for (var ii = 0; ii < nr; ii += blockSize) {\r
-                        for (var jj = 0; jj < nc; jj += blockSize) {\r
-                            var iMax = ii + Math.min(blockSize, nr - ii);\r
-                            var jMax = jj + Math.min(blockSize, nc - jj);\r
-                            for (var i = ii; i < iMax; i++) {\r
-                                for (var j = jj; j < jMax; j++) {\r
-                                    imB[nr * j + i] = -imA[nc * i + j];\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                return BuiltInMTB;\r
-            }());\r
-            exports_46("BuiltInMTB", BuiltInMTB);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/decomp/lu", ["jasmal/lib/math/cmath", "jasmal/lib/helper/dataHelper"], function (exports_47, context_47) {\r
-    "use strict";\r
-    var __moduleName = context_47 && context_47.id;\r
-    var cmath_4, dataHelper_8, LU;\r
-    return {\r
-        setters: [\r
-            function (cmath_4_1) {\r
-                cmath_4 = cmath_4_1;\r
-            },\r
-            function (dataHelper_8_1) {\r
-                dataHelper_8 = dataHelper_8_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            LU = (function () {\r
-                function LU() {\r
-                }\r
-                LU.lu = function (m, reX, p) {\r
-                    LU._fillIndexVector(p);\r
-                    var scales = dataHelper_8.DataHelper.allocateFloat64Array(m);\r
-                    var sign = 1;\r
-                    for (var i = 0; i < m; i++) {\r
-                        var maxAbs = 0.0;\r
-                        for (var j = 0; j < m; j++) {\r
-                            var curAbs = Math.abs(reX[i * m + j]);\r
-                            if (curAbs > maxAbs) {\r
-                                maxAbs = curAbs;\r
-                            }\r
-                        }\r
-                        scales[i] = maxAbs > 0 ? 1.0 / maxAbs : 1.0;\r
-                    }\r
-                    var acc, tmp;\r
-                    for (var j = 0; j < m; j++) {\r
-                        for (var i = 0; i < j; i++) {\r
-                            acc = reX[i * m + j];\r
-                            for (var k = 0; k < i; k++) {\r
-                                acc -= reX[i * m + k] * reX[k * m + j];\r
-                            }\r
-                            reX[i * m + j] = acc;\r
-                        }\r
-                        var maxAbs = 0.0, idxMax = -1;\r
-                        for (var i = j; i < m; i++) {\r
-                            acc = reX[i * m + j];\r
-                            for (var k = 0; k < j; k++) {\r
-                                acc -= reX[i * m + k] * reX[k * m + j];\r
-                            }\r
-                            reX[i * m + j] = acc;\r
-                            var curAbs = Math.abs(acc) * scales[i];\r
-                            if (curAbs >= maxAbs) {\r
-                                maxAbs = curAbs;\r
-                                idxMax = i;\r
-                            }\r
-                        }\r
-                        if (idxMax !== j) {\r
-                            for (var k = 0; k < m; k++) {\r
-                                tmp = reX[idxMax * m + k];\r
-                                reX[idxMax * m + k] = reX[j * m + k];\r
-                                reX[j * m + k] = tmp;\r
-                            }\r
-                            sign = -sign;\r
-                            scales[idxMax] = scales[j];\r
-                            tmp = p[j];\r
-                            p[j] = p[idxMax];\r
-                            p[idxMax] = tmp;\r
-                        }\r
-                        if (j !== m - 1) {\r
-                            var c = reX[j * m + j];\r
-                            if (c !== 0) {\r
-                                c = 1.0 / c;\r
-                                for (var i = j + 1; i < m; i++) {\r
-                                    reX[i * m + j] *= c;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    return sign;\r
-                };\r
-                LU.clu = function (m, reX, imX, p) {\r
-                    LU._fillIndexVector(p);\r
-                    var scales = dataHelper_8.DataHelper.allocateFloat64Array(m);\r
-                    var sign = 1;\r
-                    for (var i = 0; i < m; i++) {\r
-                        var maxAbs = 0.0;\r
-                        for (var j = 0; j < m; j++) {\r
-                            var curAbs = cmath_4.CMath.length2(reX[i * m + j], imX[i * m + j]);\r
-                            if (curAbs > maxAbs) {\r
-                                maxAbs = curAbs;\r
-                            }\r
-                        }\r
-                        scales[i] = maxAbs > 0 ? 1.0 / maxAbs : 1.0;\r
-                    }\r
-                    var accRe, accIm, tmpRe, tmpIm;\r
-                    for (var j = 0; j < m; j++) {\r
-                        for (var i = 0; i < j; i++) {\r
-                            accRe = reX[i * m + j];\r
-                            accIm = imX[i * m + j];\r
-                            for (var k = 0; k < i; k++) {\r
-                                accRe -= reX[i * m + k] * reX[k * m + j] - imX[i * m + k] * imX[k * m + j];\r
-                                accIm -= reX[i * m + k] * imX[k * m + j] + imX[i * m + k] * reX[k * m + j];\r
-                            }\r
-                            reX[i * m + j] = accRe;\r
-                            imX[i * m + j] = accIm;\r
-                        }\r
-                        var maxAbs = 0.0, idxMax = -1;\r
-                        for (var i = j; i < m; i++) {\r
-                            accRe = reX[i * m + j];\r
-                            accIm = imX[i * m + j];\r
-                            for (var k = 0; k < j; k++) {\r
-                                accRe -= reX[i * m + k] * reX[k * m + j] - imX[i * m + k] * imX[k * m + j];\r
-                                accIm -= reX[i * m + k] * imX[k * m + j] + imX[i * m + k] * reX[k * m + j];\r
-                            }\r
-                            reX[i * m + j] = accRe;\r
-                            imX[i * m + j] = accIm;\r
-                            var curAbs = cmath_4.CMath.length2(accRe, accIm) * scales[i];\r
-                            if (curAbs >= maxAbs) {\r
-                                maxAbs = curAbs;\r
-                                idxMax = i;\r
-                            }\r
-                        }\r
-                        if (idxMax !== j) {\r
-                            for (var k = 0; k < m; k++) {\r
-                                tmpRe = reX[idxMax * m + k];\r
-                                tmpIm = imX[idxMax * m + k];\r
-                                reX[idxMax * m + k] = reX[j * m + k];\r
-                                imX[idxMax * m + k] = imX[j * m + k];\r
-                                reX[j * m + k] = tmpRe;\r
-                                imX[j * m + k] = tmpIm;\r
-                            }\r
-                            sign = -sign;\r
-                            scales[idxMax] = scales[j];\r
-                            tmpRe = p[j];\r
-                            p[j] = p[idxMax];\r
-                            p[idxMax] = tmpRe;\r
-                        }\r
-                        if (j !== m - 1) {\r
-                            var reC = reX[j * m + j];\r
-                            var imC = imX[j * m + j];\r
-                            if (reC !== 0 || imC !== 0) {\r
-                                _a = cmath_4.CMath.cReciprocal(reC, imC), reC = _a[0], imC = _a[1];\r
-                                for (var i = j + 1; i < m; i++) {\r
-                                    var tmp = reX[i * m + j];\r
-                                    reX[i * m + j] = tmp * reC - imX[i * m + j] * imC;\r
-                                    imX[i * m + j] = tmp * imC + imX[i * m + j] * reC;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    return sign;\r
-                    var _a;\r
-                };\r
-                LU.luSolve = function (m, n, reLU, p, reB) {\r
-                    if (n === 1) {\r
-                        LU._luSolveColumn(n, reLU, reB);\r
-                    }\r
-                    else {\r
-                        var columnCache = dataHelper_8.DataHelper.allocateFloat64Array(m);\r
-                        for (var j = 0; j < n; j++) {\r
-                            for (var i = 0; i < m; i++) {\r
-                                columnCache[i] = reB[p[i] * n + j];\r
-                            }\r
-                            LU._luSolveColumn(m, reLU, columnCache);\r
-                            for (var i = 0; i < m; i++) {\r
-                                reB[i * n + j] = columnCache[i];\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                LU.cluSolve = function (m, n, reLU, imLU, p, reB, imB) {\r
-                    if (n === 1) {\r
-                        LU._cluSolveColumn(n, reLU, imLU, reB, imB);\r
-                    }\r
-                    else {\r
-                        var columnCacheRe = dataHelper_8.DataHelper.allocateFloat64Array(m);\r
-                        var columnCacheIm = dataHelper_8.DataHelper.allocateFloat64Array(m);\r
-                        for (var j = 0; j < n; j++) {\r
-                            for (var i = 0; i < m; i++) {\r
-                                columnCacheRe[i] = reB[p[i] * n + j];\r
-                                columnCacheIm[i] = imB[p[i] * n + j];\r
-                            }\r
-                            LU._cluSolveColumn(m, reLU, imLU, columnCacheRe, columnCacheIm);\r
-                            for (var i = 0; i < m; i++) {\r
-                                reB[i * n + j] = columnCacheRe[i];\r
-                                imB[i * n + j] = columnCacheIm[i];\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                LU._luSolveColumn = function (n, reLU, reB) {\r
-                    var idxNz = -1;\r
-                    var acc;\r
-                    for (var i = 0; i < n; i++) {\r
-                        acc = reB[i];\r
-                        if (idxNz >= 0) {\r
-                            for (var k = idxNz; k < i; k++) {\r
-                                acc -= reLU[i * n + k] * reB[k];\r
-                            }\r
-                        }\r
-                        else if (acc !== 0) {\r
-                            idxNz = i;\r
-                        }\r
-                        reB[i] = acc;\r
-                    }\r
-                    for (var i = n - 1; i >= 0; i--) {\r
-                        acc = reB[i];\r
-                        for (var j = i + 1; j < n; j++) {\r
-                            acc -= reLU[i * n + j] * reB[j];\r
-                        }\r
-                        reB[i] = acc / reLU[i * n + i];\r
-                    }\r
-                };\r
-                LU._cluSolveColumn = function (n, reLU, imLU, reB, imB) {\r
-                    var idxNz = -1;\r
-                    var accRe, accIm;\r
-                    for (var i = 0; i < n; i++) {\r
-                        accRe = reB[i];\r
-                        accIm = imB[i];\r
-                        if (idxNz >= 0) {\r
-                            for (var k = idxNz; k < i; k++) {\r
-                                accRe -= reLU[i * n + k] * reB[k] - imLU[i * n + k] * imB[k];\r
-                                accIm -= reLU[i * n + k] * imB[k] + imLU[i * n + k] * reB[k];\r
-                            }\r
-                        }\r
-                        else if (accRe !== 0 || accIm !== 0) {\r
-                            idxNz = i;\r
-                        }\r
-                        reB[i] = accRe;\r
-                        imB[i] = accIm;\r
-                    }\r
-                    for (var i = n - 1; i >= 0; i--) {\r
-                        accRe = reB[i];\r
-                        accIm = imB[i];\r
-                        for (var j = i + 1; j < n; j++) {\r
-                            accRe -= reLU[i * n + j] * reB[j] - imLU[i * n + j] * imB[j];\r
-                            accIm -= reLU[i * n + j] * imB[j] + imLU[i * n + j] * reB[j];\r
-                        }\r
-                        _a = cmath_4.CMath.cdivCC(accRe, accIm, reLU[i * n + i], imLU[i * n + i]), reB[i] = _a[0], imB[i] = _a[1];\r
-                    }\r
-                    var _a;\r
-                };\r
-                LU.compactToFull = function (m, isImaginaryPart, LU, L, U) {\r
-                    if (!isImaginaryPart) {\r
-                        for (var i = 0; i < m; i++) {\r
-                            L[i * m + i] = 1;\r
-                        }\r
-                    }\r
-                    for (var i = 0; i < m; i++) {\r
-                        var j = 0;\r
-                        for (; j < i; j++) {\r
-                            L[i * m + j] = LU[i * m + j];\r
-                        }\r
-                        for (; j < m; j++) {\r
-                            U[i * m + j] = LU[i * m + j];\r
-                        }\r
-                    }\r
-                };\r
-                LU.permutationToFull = function (p, P) {\r
-                    for (var i = 0, n = p.length; i < n; i++) {\r
-                        P[i * n + p[i]] = 1;\r
-                    }\r
-                };\r
-                LU._fillIndexVector = function (p) {\r
-                    for (var i = 0; i < p.length; i++) {\r
-                        p[i] = i;\r
-                    }\r
-                };\r
-                return LU;\r
-            }());\r
-            exports_47("LU", LU);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/decomp/svd", ["jasmal/lib/math/cmath", "jasmal/lib/helper/dataHelper"], function (exports_48, context_48) {\r
-    "use strict";\r
-    var __moduleName = context_48 && context_48.id;\r
-    var cmath_5, dataHelper_9, SVD;\r
-    return {\r
-        setters: [\r
-            function (cmath_5_1) {\r
-                cmath_5 = cmath_5_1;\r
-            },\r
-            function (dataHelper_9_1) {\r
-                dataHelper_9 = dataHelper_9_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            SVD = (function () {\r
-                function SVD() {\r
-                }\r
-                SVD.svd = function (m, n, computeUV, reA, reS, reV) {\r
-                    var flag, i, j, jj, k, l = 0;\r
-                    var its, nm = 0;\r
-                    var f, g = 0, h, c;\r
-                    var x, y, z;\r
-                    var rv1 = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    var scale = 0, anorm = 0;\r
-                    var s = 0;\r
-                    for (i = 0; i < n; i++) {\r
-                        l = i + 1;\r
-                        rv1[i] = scale * g;\r
-                        g = 0;\r
-                        s = 0;\r
-                        scale = 0;\r
-                        if (i < m) {\r
-                            for (k = i; k < m; k++) {\r
-                                scale += Math.abs(reA[k * n + i]);\r
-                            }\r
-                            if (scale) {\r
-                                for (k = i; k < m; k++) {\r
-                                    reA[k * n + i] /= scale;\r
-                                    s += reA[k * n + i] * reA[k * n + i];\r
-                                }\r
-                                f = reA[i * n + i];\r
-                                g = f >= 0 ? -Math.sqrt(s) : Math.sqrt(s);\r
-                                h = f * g - s;\r
-                                reA[i * n + i] = f - g;\r
-                                for (j = l; j < n; j++) {\r
-                                    s = 0.0;\r
-                                    for (k = i; k < m; k++) {\r
-                                        s += reA[k * n + i] * reA[k * n + j];\r
-                                    }\r
-                                    f = s / h;\r
-                                    for (k = i; k < m; k++) {\r
-                                        reA[k * n + j] += f * reA[k * n + i];\r
-                                    }\r
-                                }\r
-                                for (k = i; k < m; k++) {\r
-                                    reA[k * n + i] *= scale;\r
-                                }\r
-                            }\r
-                        }\r
-                        reS[i] = scale * g;\r
-                        g = 0;\r
-                        s = 0;\r
-                        scale = 0;\r
-                        if (i < m && i !== n - 1) {\r
-                            for (k = l; k < n; k++) {\r
-                                scale += Math.abs(reA[i * n + k]);\r
-                            }\r
-                            if (scale) {\r
-                                for (k = l; k < n; k++) {\r
-                                    reA[i * n + k] /= scale;\r
-                                    s += reA[i * n + k] * reA[i * n + k];\r
-                                }\r
-                                f = reA[i * n + l];\r
-                                g = f >= 0 ? -Math.sqrt(s) : Math.sqrt(s);\r
-                                h = f * g - s;\r
-                                reA[i * n + l] = f - g;\r
-                                for (k = l; k < n; k++) {\r
-                                    rv1[k] = reA[i * n + k] / h;\r
-                                }\r
-                                for (j = l; j < m; j++) {\r
-                                    s = 0;\r
-                                    for (k = l; k < n; k++) {\r
-                                        s += reA[j * n + k] * reA[i * n + k];\r
-                                    }\r
-                                    for (k = l; k < n; k++) {\r
-                                        reA[j * n + k] += s * rv1[k];\r
-                                    }\r
-                                }\r
-                                for (k = l; k < n; k++) {\r
-                                    reA[i * n + k] *= scale;\r
-                                }\r
-                            }\r
-                        }\r
-                        anorm = Math.max(anorm, Math.abs(reS[i]) + Math.abs(rv1[i]));\r
-                    }\r
-                    if (computeUV) {\r
-                        for (i = n - 1; i >= 0; i--) {\r
-                            if (i < n - 1) {\r
-                                if (g) {\r
-                                    for (j = l; j < n; j++) {\r
-                                        reV[j * n + i] = (reA[i * n + j] / reA[i * n + l]) / g;\r
-                                    }\r
-                                    for (j = l; j < n; j++) {\r
-                                        s = 0;\r
-                                        for (k = l; k < n; k++) {\r
-                                            s += reA[i * n + k] * reV[k * n + j];\r
-                                        }\r
-                                        for (k = l; k < n; k++) {\r
-                                            reV[k * n + j] += s * reV[k * n + i];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                for (j = l; j < n; j++) {\r
-                                    reV[i * n + j] = 0;\r
-                                    reV[j * n + i] = 0;\r
-                                }\r
-                            }\r
-                            reV[i * n + i] = 1.0;\r
-                            g = rv1[i];\r
-                            l = i;\r
-                        }\r
-                        for (i = Math.min(m, n) - 1; i >= 0; i--) {\r
-                            l = i + 1;\r
-                            g = reS[i];\r
-                            for (j = l; j < n; j++) {\r
-                                reA[i * n + j] = 0;\r
-                            }\r
-                            if (g) {\r
-                                g = 1.0 / g;\r
-                                for (j = l; j < n; j++) {\r
-                                    s = 0;\r
-                                    for (k = l; k < m; k++) {\r
-                                        s += reA[k * n + i] * reA[k * n + j];\r
-                                    }\r
-                                    f = (s / reA[i * n + i]) * g;\r
-                                    for (k = i; k < m; k++) {\r
-                                        reA[k * n + j] += f * reA[k * n + i];\r
-                                    }\r
-                                }\r
-                                for (j = i; j < m; j++) {\r
-                                    reA[j * n + i] *= g;\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (j = i; j < m; j++) {\r
-                                    reA[j * n + i] = 0;\r
-                                }\r
-                            }\r
-                            reA[i * n + i]++;\r
-                        }\r
-                    }\r
-                    for (k = n - 1; k >= 0; k--) {\r
-                        for (its = 0; its < 30; its++) {\r
-                            flag = 1;\r
-                            for (l = k; l >= 0; l--) {\r
-                                nm = l - 1;\r
-                                if (Math.abs(rv1[l]) + anorm === anorm) {\r
-                                    flag = 0;\r
-                                    break;\r
-                                }\r
-                                if (Math.abs(reS[nm]) + anorm === anorm) {\r
-                                    break;\r
-                                }\r
-                            }\r
-                            if (flag) {\r
-                                c = 0;\r
-                                s = 1;\r
-                                for (i = l; i <= k; i++) {\r
-                                    f = s * rv1[i];\r
-                                    rv1[i] = c * rv1[i];\r
-                                    if (Math.abs(f) + anorm === anorm) {\r
-                                        break;\r
-                                    }\r
-                                    g = reS[i];\r
-                                    h = cmath_5.CMath.length2(f, g);\r
-                                    reS[i] = h;\r
-                                    h = 1.0 / h;\r
-                                    c = g * h;\r
-                                    s = -f * h;\r
-                                    if (computeUV) {\r
-                                        for (j = 0; j < m; j++) {\r
-                                            y = reA[j * n + nm];\r
-                                            z = reA[j * n + i];\r
-                                            reA[j * n + nm] = y * c + z * s;\r
-                                            reA[j * n + i] = z * c - y * s;\r
-                                        }\r
-                                    }\r
-                                }\r
-                            }\r
-                            z = reS[k];\r
-                            if (l === k) {\r
-                                if (z < 0) {\r
-                                    reS[k] = -z;\r
-                                    if (computeUV) {\r
-                                        for (j = 0; j < n; j++) {\r
-                                            reV[j * n + k] = -reV[j * n + k];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                break;\r
-                            }\r
-                            if (its === 29) {\r
-                                throw new Error('Failed to converge.');\r
-                            }\r
-                            x = reS[l];\r
-                            nm = k - 1;\r
-                            y = reS[nm];\r
-                            g = rv1[nm];\r
-                            h = rv1[k];\r
-                            f = ((y - z) * (y + z) + (g - h) * (g + h)) / (2.0 * h * y);\r
-                            g = cmath_5.CMath.length2(f, 1.0);\r
-                            f = ((x - z) * (x + z) + h * ((y / (f + f >= 0 ? g : -g)) - h)) / x;\r
-                            c = 1.0;\r
-                            s = 1.0;\r
-                            for (j = l; j <= nm; j++) {\r
-                                i = j + 1;\r
-                                g = rv1[i];\r
-                                y = reS[i];\r
-                                h = s * g;\r
-                                g = c * g;\r
-                                z = cmath_5.CMath.length2(f, h);\r
-                                rv1[j] = z;\r
-                                c = f / z;\r
-                                s = h / z;\r
-                                f = x * c + g * s;\r
-                                g = g * c - x * s;\r
-                                h = y * s;\r
-                                y *= c;\r
-                                if (computeUV) {\r
-                                    for (jj = 0; jj < n; jj++) {\r
-                                        x = reV[jj * n + j];\r
-                                        z = reV[jj * n + i];\r
-                                        reV[jj * n + j] = x * c + z * s;\r
-                                        reV[jj * n + i] = z * c - x * s;\r
-                                    }\r
-                                }\r
-                                z = cmath_5.CMath.length2(f, h);\r
-                                reS[j] = z;\r
-                                if (z) {\r
-                                    z = 1.0 / z;\r
-                                    c = f * z;\r
-                                    s = h * z;\r
-                                }\r
-                                f = c * g + s * y;\r
-                                x = c * y - s * g;\r
-                                if (computeUV) {\r
-                                    for (jj = 0; jj < m; jj++) {\r
-                                        y = reA[jj * n + j];\r
-                                        z = reA[jj * n + i];\r
-                                        reA[jj * n + j] = y * c + z * s;\r
-                                        reA[jj * n + i] = z * c - y * s;\r
-                                    }\r
-                                }\r
-                            }\r
-                            rv1[l] = 0.0;\r
-                            rv1[k] = f;\r
-                            reS[k] = x;\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n - 1; i++) {\r
-                        x = reS[i];\r
-                        jj = i;\r
-                        for (j = i + 1; j < n; j++) {\r
-                            if (reS[j] > x) {\r
-                                x = reS[j];\r
-                                jj = j;\r
-                            }\r
-                        }\r
-                        if (jj !== i) {\r
-                            y = reS[i];\r
-                            reS[i] = reS[jj];\r
-                            reS[jj] = y;\r
-                            if (computeUV) {\r
-                                for (k = 0; k < m; k++) {\r
-                                    y = reA[k * n + i];\r
-                                    reA[k * n + i] = reA[k * n + jj];\r
-                                    reA[k * n + jj] = y;\r
-                                }\r
-                                for (k = 0; k < n; k++) {\r
-                                    y = reV[k * n + i];\r
-                                    reV[k * n + i] = reV[k * n + jj];\r
-                                    reV[k * n + jj] = y;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                SVD.csvd = function (m, n, computeUV, reA, imA, reS, reV, imV) {\r
-                    var flag, i, j, jj, k, l = 0;\r
-                    var its, nm = 0;\r
-                    var f, g = 0, h, c;\r
-                    var accRe, accIm;\r
-                    var x, y, z;\r
-                    var rv1 = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    var phaseRe = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    var phaseIm = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    var phase2Re = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    var phase2Im = dataHelper_9.DataHelper.allocateFloat64Array(n);\r
-                    for (i = 0; i < n; i++) {\r
-                        phaseRe[i] = 1;\r
-                        phaseIm[i] = 0;\r
-                        phase2Re[i] = 1;\r
-                        phase2Im[i] = 0;\r
-                    }\r
-                    phase2Re[0] = -1;\r
-                    phase2Im[0] = 0;\r
-                    var scale = 0, anorm = 0;\r
-                    var s = 0;\r
-                    for (i = 0; i < n; i++) {\r
-                        l = i + 1;\r
-                        rv1[i] = scale * g;\r
-                        g = 0;\r
-                        s = 0;\r
-                        scale = 0;\r
-                        if (i < m) {\r
-                            for (k = i; k < m; k++) {\r
-                                scale += cmath_5.CMath.length2(reA[k * n + i], imA[k * n + i]);\r
-                            }\r
-                            if (scale) {\r
-                                for (k = i; k < m; k++) {\r
-                                    reA[k * n + i] /= scale;\r
-                                    imA[k * n + i] /= scale;\r
-                                    s += reA[k * n + i] * reA[k * n + i] + imA[k * n + i] * imA[k * n + i];\r
-                                }\r
-                                f = cmath_5.CMath.length2(reA[i * n + i], imA[i * n + i]);\r
-                                g = Math.sqrt(s);\r
-                                h = -f * g - s;\r
-                                if (f) {\r
-                                    phaseRe[i] = reA[i * n + i] / f;\r
-                                    phaseIm[i] = imA[i * n + i] / f;\r
-                                    reA[i * n + i] += phaseRe[i] * g;\r
-                                    imA[i * n + i] += phaseIm[i] * g;\r
-                                }\r
-                                else {\r
-                                    phaseRe[i] = 1;\r
-                                    phaseIm[i] = 0;\r
-                                    reA[i * n + i] = g;\r
-                                    imA[i * n + i] = 0;\r
-                                }\r
-                                for (j = l; j < n; j++) {\r
-                                    accRe = 0.0;\r
-                                    accIm = 0.0;\r
-                                    for (k = i; k < m; k++) {\r
-                                        accRe += reA[k * n + i] * reA[k * n + j] + imA[k * n + i] * imA[k * n + j];\r
-                                        accIm += reA[k * n + i] * imA[k * n + j] - imA[k * n + i] * reA[k * n + j];\r
-                                    }\r
-                                    accRe /= h;\r
-                                    accIm /= h;\r
-                                    for (k = i; k < m; k++) {\r
-                                        reA[k * n + j] += accRe * reA[k * n + i] - accIm * imA[k * n + i];\r
-                                        imA[k * n + j] += accRe * imA[k * n + i] + accIm * reA[k * n + i];\r
-                                    }\r
-                                }\r
-                                for (k = i; k < m; k++) {\r
-                                    reA[k * n + i] *= scale;\r
-                                    imA[k * n + i] *= scale;\r
-                                }\r
-                                for (k = l; k < n; k++) {\r
-                                    x = reA[i * n + k];\r
-                                    y = imA[i * n + k];\r
-                                    reA[i * n + k] = -x * phaseRe[i] - y * phaseIm[i];\r
-                                    imA[i * n + k] = x * phaseIm[i] - y * phaseRe[i];\r
-                                }\r
-                            }\r
-                            else {\r
-                                phaseRe[i] = 1;\r
-                                phaseIm[i] = 0;\r
-                            }\r
-                        }\r
-                        reS[i] = scale * g;\r
-                        g = 0;\r
-                        s = 0;\r
-                        scale = 0;\r
-                        if (i < m && i !== n - 1) {\r
-                            for (k = l; k < n; k++) {\r
-                                scale += cmath_5.CMath.length2(reA[i * n + k], imA[i * n + k]);\r
-                            }\r
-                            if (scale) {\r
-                                for (k = l; k < n; k++) {\r
-                                    reA[i * n + k] /= scale;\r
-                                    imA[i * n + k] /= scale;\r
-                                    s += reA[i * n + k] * reA[i * n + k] + imA[i * n + k] * imA[i * n + k];\r
-                                }\r
-                                for (k = l; k < n; k++) {\r
-                                    imA[i * n + k] = -imA[i * n + k];\r
-                                }\r
-                                f = cmath_5.CMath.length2(reA[i * n + l], imA[i * n + l]);\r
-                                g = Math.sqrt(s);\r
-                                h = -f * g - s;\r
-                                if (f) {\r
-                                    phase2Re[l] = reA[i * n + l] / f;\r
-                                    phase2Im[l] = -imA[i * n + l] / f;\r
-                                    reA[i * n + l] += phase2Re[l] * g;\r
-                                    imA[i * n + l] += -phase2Im[l] * g;\r
-                                }\r
-                                else {\r
-                                    phase2Re[l] = 1;\r
-                                    phase2Im[l] = 0;\r
-                                    reA[i * n + l] = g;\r
-                                    imA[i * n + l] = 0;\r
-                                }\r
-                                for (j = l; j < m; j++) {\r
-                                    accRe = 0;\r
-                                    accIm = 0;\r
-                                    for (k = l; k < n; k++) {\r
-                                        accRe += reA[j * n + k] * reA[i * n + k] - imA[j * n + k] * imA[i * n + k];\r
-                                        accIm += reA[j * n + k] * imA[i * n + k] + imA[j * n + k] * reA[i * n + k];\r
-                                    }\r
-                                    accRe /= h;\r
-                                    accIm /= h;\r
-                                    for (k = l; k < n; k++) {\r
-                                        reA[j * n + k] += accRe * reA[i * n + k] + accIm * imA[i * n + k];\r
-                                        imA[j * n + k] += -accRe * imA[i * n + k] + accIm * reA[i * n + k];\r
-                                    }\r
-                                }\r
-                                for (k = l; k < n; k++) {\r
-                                    reA[i * n + k] *= scale;\r
-                                    imA[i * n + k] *= scale;\r
-                                }\r
-                                for (k = l; k < m; k++) {\r
-                                    x = reA[k * n + l];\r
-                                    y = imA[k * n + l];\r
-                                    reA[k * n + l] = -x * phase2Re[l] - y * phase2Im[l];\r
-                                    imA[k * n + l] = x * phase2Im[l] - y * phase2Re[l];\r
-                                }\r
-                            }\r
-                            else {\r
-                                phase2Re[l] = 1.0;\r
-                                phase2Im[l] = 0.0;\r
-                            }\r
-                        }\r
-                        anorm = Math.max(anorm, Math.abs(reS[i]) + Math.abs(rv1[i]));\r
-                    }\r
-                    if (computeUV) {\r
-                        for (i = n - 1; i >= 0; i--) {\r
-                            if (i < n - 1) {\r
-                                if (g) {\r
-                                    h = -1.0 / cmath_5.CMath.length2(reA[i * n + l], imA[i * n + l]) / g;\r
-                                    for (j = l; j < n; j++) {\r
-                                        accRe = 0;\r
-                                        accIm = 0;\r
-                                        for (k = l; k < n; k++) {\r
-                                            accRe += reA[i * n + k] * reV[k * n + j] + imA[i * n + k] * imV[k * n + j];\r
-                                            accIm += reA[i * n + k] * imV[k * n + j] - imA[i * n + k] * reV[k * n + j];\r
-                                        }\r
-                                        accRe *= h;\r
-                                        accIm *= h;\r
-                                        for (k = l; k < n; k++) {\r
-                                            reV[k * n + j] += accRe * reA[i * n + k] - accIm * imA[i * n + k];\r
-                                            imV[k * n + j] += accRe * imA[i * n + k] + accIm * reA[i * n + k];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                for (j = l; j < n; j++) {\r
-                                    reV[i * n + j] = 0;\r
-                                    reV[j * n + i] = 0;\r
-                                    imV[i * n + j] = 0;\r
-                                    imV[j * n + i] = 0;\r
-                                }\r
-                            }\r
-                            reV[i * n + i] = -phase2Re[i];\r
-                            imV[i * n + i] = phase2Im[i];\r
-                            g = rv1[i];\r
-                            l = i;\r
-                        }\r
-                        for (i = Math.min(m, n) - 1; i >= 0; i--) {\r
-                            l = i + 1;\r
-                            g = reS[i];\r
-                            for (j = l; j < n; j++) {\r
-                                reA[i * n + j] = 0;\r
-                                imA[i * n + j] = 0;\r
-                            }\r
-                            if (g) {\r
-                                h = -1.0 / cmath_5.CMath.length2(reA[i * n + i], imA[i * n + i]) / g;\r
-                                for (j = l; j < n; j++) {\r
-                                    accRe = 0;\r
-                                    accIm = 0;\r
-                                    for (k = l; k < m; k++) {\r
-                                        accRe += reA[k * n + i] * reA[k * n + j] + imA[k * n + i] * imA[k * n + j];\r
-                                        accIm += reA[k * n + i] * imA[k * n + j] - imA[k * n + i] * reA[k * n + j];\r
-                                    }\r
-                                    accRe *= h;\r
-                                    accIm *= h;\r
-                                    for (k = i; k < m; k++) {\r
-                                        reA[k * n + j] += accRe * reA[k * n + i] - accIm * imA[k * n + i];\r
-                                        imA[k * n + j] += accRe * imA[k * n + i] + accIm * reA[k * n + i];\r
-                                    }\r
-                                }\r
-                                accRe = reA[i * n + i] * h;\r
-                                accIm = imA[i * n + i] * h;\r
-                                for (k = i; k < m; k++) {\r
-                                    x = reA[k * n + i];\r
-                                    y = imA[k * n + i];\r
-                                    reA[k * n + i] = accRe * x + accIm * y;\r
-                                    imA[k * n + i] = accRe * y - accIm * x;\r
-                                }\r
-                                reA[i * n + i]++;\r
-                                for (k = i; k < m; k++) {\r
-                                    x = reA[k * n + i];\r
-                                    y = imA[k * n + i];\r
-                                    reA[k * n + i] = -phaseRe[i] * x + phaseIm[i] * y;\r
-                                    imA[k * n + i] = -phaseRe[i] * y - phaseIm[i] * x;\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (j = i; j < m; j++) {\r
-                                    reA[j * n + i] = 0;\r
-                                    imA[j * n + i] = 0;\r
-                                }\r
-                                reA[i * n + i] = 1;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (k = n - 1; k >= 0; k--) {\r
-                        for (its = 0; its < 30; its++) {\r
-                            flag = 1;\r
-                            for (l = k; l >= 0; l--) {\r
-                                nm = l - 1;\r
-                                if (Math.abs(rv1[l]) + anorm === anorm) {\r
-                                    flag = 0;\r
-                                    break;\r
-                                }\r
-                                if (Math.abs(reS[nm]) + anorm === anorm) {\r
-                                    break;\r
-                                }\r
-                            }\r
-                            if (flag) {\r
-                                c = 0;\r
-                                s = 1;\r
-                                for (i = l; i <= k; i++) {\r
-                                    f = s * rv1[i];\r
-                                    rv1[i] = c * rv1[i];\r
-                                    if (Math.abs(f) + anorm === anorm) {\r
-                                        break;\r
-                                    }\r
-                                    g = reS[i];\r
-                                    h = cmath_5.CMath.length2(f, g);\r
-                                    reS[i] = h;\r
-                                    h = 1.0 / h;\r
-                                    c = g * h;\r
-                                    s = -f * h;\r
-                                    if (computeUV) {\r
-                                        for (j = 0; j < m; j++) {\r
-                                            y = reA[j * n + nm];\r
-                                            z = reA[j * n + i];\r
-                                            reA[j * n + nm] = y * c + z * s;\r
-                                            reA[j * n + i] = z * c - y * s;\r
-                                            y = imA[j * n + nm];\r
-                                            z = imA[j * n + i];\r
-                                            imA[j * n + nm] = y * c + z * s;\r
-                                            imA[j * n + i] = z * c - y * s;\r
-                                        }\r
-                                    }\r
-                                }\r
-                            }\r
-                            z = reS[k];\r
-                            if (l === k) {\r
-                                if (z < 0) {\r
-                                    reS[k] = -z;\r
-                                    if (computeUV) {\r
-                                        for (j = 0; j < n; j++) {\r
-                                            reV[j * n + k] = -reV[j * n + k];\r
-                                            imV[j * n + k] = -imV[j * n + k];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                break;\r
-                            }\r
-                            if (its === 29) {\r
-                                throw new Error('Failed to converge.');\r
-                            }\r
-                            x = reS[l];\r
-                            nm = k - 1;\r
-                            y = reS[nm];\r
-                            g = rv1[nm];\r
-                            h = rv1[k];\r
-                            f = ((y - z) * (y + z) + (g - h) * (g + h)) / (2.0 * h * y);\r
-                            g = cmath_5.CMath.length2(f, 1.0);\r
-                            f = ((x - z) * (x + z) + h * ((y / (f + f >= 0 ? g : -g)) - h)) / x;\r
-                            c = 1.0;\r
-                            s = 1.0;\r
-                            for (j = l; j <= nm; j++) {\r
-                                i = j + 1;\r
-                                g = rv1[i];\r
-                                y = reS[i];\r
-                                h = s * g;\r
-                                g = c * g;\r
-                                z = cmath_5.CMath.length2(f, h);\r
-                                rv1[j] = z;\r
-                                c = f / z;\r
-                                s = h / z;\r
-                                f = x * c + g * s;\r
-                                g = g * c - x * s;\r
-                                h = y * s;\r
-                                y *= c;\r
-                                if (computeUV) {\r
-                                    for (jj = 0; jj < n; jj++) {\r
-                                        x = reV[jj * n + j];\r
-                                        z = reV[jj * n + i];\r
-                                        reV[jj * n + j] = x * c + z * s;\r
-                                        reV[jj * n + i] = z * c - x * s;\r
-                                        x = imV[jj * n + j];\r
-                                        z = imV[jj * n + i];\r
-                                        imV[jj * n + j] = x * c + z * s;\r
-                                        imV[jj * n + i] = z * c - x * s;\r
-                                    }\r
-                                }\r
-                                z = cmath_5.CMath.length2(f, h);\r
-                                reS[j] = z;\r
-                                if (z) {\r
-                                    z = 1.0 / z;\r
-                                    c = f * z;\r
-                                    s = h * z;\r
-                                }\r
-                                f = c * g + s * y;\r
-                                x = c * y - s * g;\r
-                                if (computeUV) {\r
-                                    for (jj = 0; jj < m; jj++) {\r
-                                        y = reA[jj * n + j];\r
-                                        z = reA[jj * n + i];\r
-                                        reA[jj * n + j] = y * c + z * s;\r
-                                        reA[jj * n + i] = z * c - y * s;\r
-                                        y = imA[jj * n + j];\r
-                                        z = imA[jj * n + i];\r
-                                        imA[jj * n + j] = y * c + z * s;\r
-                                        imA[jj * n + i] = z * c - y * s;\r
-                                    }\r
-                                }\r
-                            }\r
-                            rv1[l] = 0.0;\r
-                            rv1[k] = f;\r
-                            reS[k] = x;\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n - 1; i++) {\r
-                        x = reS[i];\r
-                        jj = i;\r
-                        for (j = i + 1; j < n; j++) {\r
-                            if (reS[j] > x) {\r
-                                x = reS[j];\r
-                                jj = j;\r
-                            }\r
-                        }\r
-                        if (jj !== i) {\r
-                            y = reS[i];\r
-                            reS[i] = reS[jj];\r
-                            reS[jj] = y;\r
-                            if (computeUV) {\r
-                                for (k = 0; k < m; k++) {\r
-                                    y = reA[k * n + i];\r
-                                    reA[k * n + i] = reA[k * n + jj];\r
-                                    reA[k * n + jj] = y;\r
-                                    y = imA[k * n + i];\r
-                                    imA[k * n + i] = imA[k * n + jj];\r
-                                    imA[k * n + jj] = y;\r
-                                }\r
-                                for (k = 0; k < n; k++) {\r
-                                    y = reV[k * n + i];\r
-                                    reV[k * n + i] = reV[k * n + jj];\r
-                                    reV[k * n + jj] = y;\r
-                                    y = imV[k * n + i];\r
-                                    imV[k * n + i] = imV[k * n + jj];\r
-                                    imV[k * n + jj] = y;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                return SVD;\r
-            }());\r
-            exports_48("SVD", SVD);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/decomp/eigen", ["jasmal/lib/math/cmath", "jasmal/lib/helper/dataHelper", "jasmal/lib/constant"], function (exports_49, context_49) {\r
-    "use strict";\r
-    var __moduleName = context_49 && context_49.id;\r
-    var cmath_6, dataHelper_10, constant_4, Eigen;\r
-    return {\r
-        setters: [\r
-            function (cmath_6_1) {\r
-                cmath_6 = cmath_6_1;\r
-            },\r
-            function (dataHelper_10_1) {\r
-                dataHelper_10 = dataHelper_10_1;\r
-            },\r
-            function (constant_4_1) {\r
-                constant_4 = constant_4_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            Eigen = (function () {\r
-                function Eigen() {\r
-                }\r
-                Eigen.tred1 = function (n, a, d, e, e2) {\r
-                    var i, j, k, l;\r
-                    var f, g, h, scale;\r
-                    for (i = 0; i < n; i++) {\r
-                        d[i] = a[(n - 1) * n + i];\r
-                        a[(n - 1) * n + i] = a[i * n + i];\r
-                    }\r
-                    for (i = n - 1; i >= 0; i--) {\r
-                        l = i - 1;\r
-                        h = 0.0;\r
-                        scale = 0.0;\r
-                        if (l >= 0) {\r
-                            for (k = 0; k <= l; k++) {\r
-                                scale += Math.abs(d[k]);\r
-                            }\r
-                            if (scale === 0.0) {\r
-                                for (j = 0; j <= l; j++) {\r
-                                    d[j] = a[l * n + j];\r
-                                    a[l * n + j] = a[i * n + j];\r
-                                    a[i * n + j] = 0.0;\r
-                                }\r
-                                e[i] = 0.0;\r
-                                e2[i] = 0.0;\r
-                                continue;\r
-                            }\r
-                        }\r
-                        else {\r
-                            e[i] = 0.0;\r
-                            e2[i] = 0.0;\r
-                            continue;\r
-                        }\r
-                        for (k = 0; k <= l; k++) {\r
-                            d[k] /= scale;\r
-                            h += d[k] * d[k];\r
-                        }\r
-                        e2[i] = scale * scale * h;\r
-                        f = d[l];\r
-                        g = f >= 0 ? -Math.sqrt(h) : Math.sqrt(h);\r
-                        e[i] = scale * g;\r
-                        h = h - f * g;\r
-                        d[l] = f - g;\r
-                        if (l !== 0) {\r
-                            for (j = 0; j <= l; j++) {\r
-                                e[j] = 0.0;\r
-                            }\r
-                            for (j = 0; j <= l; j++) {\r
-                                f = d[j];\r
-                                g = e[j] + a[j * n + j] * f;\r
-                                if (l >= j + 1) {\r
-                                    for (k = j + 1; k <= l; k++) {\r
-                                        g = g + a[k * n + j] * d[k];\r
-                                        e[k] = e[k] + a[k * n + j] * f;\r
-                                    }\r
-                                }\r
-                                e[j] = g;\r
-                            }\r
-                            f = 0.0;\r
-                            for (j = 0; j <= l; j++) {\r
-                                e[j] /= h;\r
-                                f += e[j] * d[j];\r
-                            }\r
-                            h = f / (h + h);\r
-                            for (j = 0; j <= l; j++) {\r
-                                e[j] -= h * d[j];\r
-                            }\r
-                            for (j = 0; j <= l; j++) {\r
-                                f = d[j];\r
-                                g = e[j];\r
-                                for (k = j; k <= l; k++) {\r
-                                    a[k * n + j] += -f * e[k] - g * d[k];\r
-                                }\r
-                            }\r
-                        }\r
-                        for (j = 0; j <= l; j++) {\r
-                            f = d[j];\r
-                            d[j] = a[l * n + j];\r
-                            a[l * n + j] = a[i * n + j];\r
-                            a[i * n + j] = f * scale;\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.tred2 = function (n, reA, diag, sub, reE) {\r
-                    var i, j, k, l, ii, jp1;\r
-                    var f, g, h, hh, scale;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = 0; j <= i; j++) {\r
-                            reE[i * n + j] = reA[i * n + j];\r
-                        }\r
-                        diag[i] = reA[(n - 1) * n + i];\r
-                    }\r
-                    if (n !== 1) {\r
-                        for (ii = 1; ii < n; ii++) {\r
-                            i = n - ii;\r
-                            l = i - 1;\r
-                            h = 0.0;\r
-                            scale = 0.0;\r
-                            if (l >= 1) {\r
-                                for (k = 0; k <= l; k++) {\r
-                                    scale += Math.abs(diag[k]);\r
-                                }\r
-                            }\r
-                            if (scale === 0.0) {\r
-                                sub[i] = diag[l];\r
-                                for (j = 0; j <= l; j++) {\r
-                                    diag[j] = reE[l * n + j];\r
-                                    reE[i * n + j] = 0.0;\r
-                                    reE[j * n + i] = 0.0;\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (k = 0; k <= l; k++) {\r
-                                    diag[k] /= scale;\r
-                                    h = h + diag[k] * diag[k];\r
-                                }\r
-                                f = diag[l];\r
-                                g = f >= 0 ? -Math.sqrt(h) : Math.sqrt(h);\r
-                                sub[i] = scale * g;\r
-                                h = h - f * g;\r
-                                diag[l] = f - g;\r
-                                for (j = 0; j <= l; j++) {\r
-                                    sub[j] = 0.0;\r
-                                }\r
-                                for (j = 0; j <= l; j++) {\r
-                                    f = diag[j];\r
-                                    reE[j * n + i] = f;\r
-                                    g = sub[j] + reE[j * n + j] * f;\r
-                                    jp1 = j + 1;\r
-                                    if (l >= jp1) {\r
-                                        for (k = jp1; k <= l; k++) {\r
-                                            g += reE[k * n + j] * diag[k];\r
-                                            sub[k] += reE[k * n + j] * f;\r
-                                        }\r
-                                    }\r
-                                    sub[j] = g;\r
-                                }\r
-                                f = 0.0;\r
-                                for (j = 0; j <= l; j++) {\r
-                                    sub[j] /= h;\r
-                                    f += sub[j] * diag[j];\r
-                                }\r
-                                hh = f / (h + h);\r
-                                for (j = 0; j <= l; j++) {\r
-                                    sub[j] -= hh * diag[j];\r
-                                }\r
-                                for (j = 0; j <= l; j++) {\r
-                                    f = diag[j];\r
-                                    g = sub[j];\r
-                                    for (k = j; k <= l; k++) {\r
-                                        reE[k * n + j] -= f * sub[k] + g * diag[k];\r
-                                    }\r
-                                    diag[j] = reE[l * n + j];\r
-                                    reE[i * n + j] = 0.0;\r
-                                }\r
-                            }\r
-                            diag[i] = h;\r
-                        }\r
-                        for (i = 1; i < n; i++) {\r
-                            l = i - 1;\r
-                            reE[(n - 1) * n + l] = reE[l * n + l];\r
-                            reE[l * n + l] = 1.0;\r
-                            h = diag[i];\r
-                            if (h !== 0.0) {\r
-                                for (k = 0; k <= l; k++) {\r
-                                    diag[k] = reE[k * n + i] / h;\r
-                                }\r
-                                for (j = 0; j <= l; j++) {\r
-                                    g = 0.0;\r
-                                    for (k = 0; k <= l; k++) {\r
-                                        g += reE[k * n + i] * reE[k * n + j];\r
-                                    }\r
-                                    for (k = 0; k <= l; k++) {\r
-                                        reE[k * n + j] -= g * diag[k];\r
-                                    }\r
-                                }\r
-                            }\r
-                            for (k = 0; k <= l; k++) {\r
-                                reE[k * n + i] = 0.0;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        diag[i] = reE[(n - 1) * n + i];\r
-                        reE[(n - 1) * n + i] = 0.0;\r
-                    }\r
-                    reE[(n - 1) * n + n - 1] = 1.0;\r
-                    sub[0] = 0.0;\r
-                };\r
-                Eigen.tqlrat = function (n, d, e2) {\r
-                    if (n === 1) {\r
-                        return;\r
-                    }\r
-                    var i, j, l, l1, m;\r
-                    var b, c, f, g, h;\r
-                    var p, r, s, t;\r
-                    var flag;\r
-                    for (i = 1; i < n; i++) {\r
-                        e2[i - 1] = e2[i];\r
-                    }\r
-                    f = 0.0;\r
-                    t = 0.0;\r
-                    b = 0.0;\r
-                    c = 0.0;\r
-                    e2[n - 1] = 0.0;\r
-                    for (l = 0; l < n; l++) {\r
-                        j = 0;\r
-                        h = Math.abs(d[l]) + Math.sqrt(e2[l]);\r
-                        if (t <= h) {\r
-                            t = h;\r
-                            b = Math.abs(t) * constant_4.EPSILON;\r
-                            c = b * b;\r
-                            if (c === 0) {\r
-                                for (i = l; i < n; i++) {\r
-                                    h = Math.abs(d[i]) + Math.sqrt(e2[i]);\r
-                                    if (h > t) {\r
-                                        t = h;\r
-                                    }\r
-                                }\r
-                                b = Math.abs(t) * constant_4.EPSILON;\r
-                                c = b * b;\r
-                            }\r
-                        }\r
-                        for (m = l; m < n; m++) {\r
-                            if (e2[m] <= c) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        if (m !== l) {\r
-                            do {\r
-                                if (j === 30) {\r
-                                    throw new Error('Maximum iteration reached.');\r
-                                }\r
-                                j++;\r
-                                l1 = l + 1;\r
-                                s = Math.sqrt(e2[l]);\r
-                                g = d[l];\r
-                                p = (d[l1] - g) / (2.0 * s);\r
-                                r = cmath_6.CMath.length2(p, 1.0);\r
-                                d[l] = s / (p + (p >= 0 ? Math.abs(r) : -Math.abs(r)));\r
-                                h = g - d[l];\r
-                                for (i = l1; i < n; i++) {\r
-                                    d[i] -= h;\r
-                                }\r
-                                f += h;\r
-                                g = d[m];\r
-                                if (g === 0) {\r
-                                    g = b;\r
-                                }\r
-                                h = g;\r
-                                s = 0.0;\r
-                                for (i = m - 1; i >= l; i--) {\r
-                                    p = g * h;\r
-                                    r = p + e2[i];\r
-                                    e2[i + 1] = s * r;\r
-                                    s = e2[i] / r;\r
-                                    d[i + 1] = h + s * (h + d[i]);\r
-                                    g = d[i] - e2[i] / g;\r
-                                    if (g === 0.0) {\r
-                                        g = Math.abs(d[i]) * constant_4.EPSILON;\r
-                                    }\r
-                                    h = g * (p / r);\r
-                                }\r
-                                e2[l] = s * g;\r
-                                d[l] = h;\r
-                                if (h !== 0.0) {\r
-                                    if (Math.abs(e2[l]) > Math.abs(c / h)) {\r
-                                        e2[l] *= h;\r
-                                        if (e2[l] !== 0.0) {\r
-                                            flag = true;\r
-                                            continue;\r
-                                        }\r
-                                    }\r
-                                }\r
-                                flag = false;\r
-                            } while (flag);\r
-                        }\r
-                        p = d[l] + f;\r
-                        if (l !== 0) {\r
-                            for (i = l; i >= 1; i--) {\r
-                                if (p >= d[i - 1]) {\r
-                                    break;\r
-                                }\r
-                                d[i] = d[i - 1];\r
-                            }\r
-                        }\r
-                        else {\r
-                            i = 0;\r
-                        }\r
-                        d[i] = p;\r
-                    }\r
-                };\r
-                Eigen.tql2 = function (n, diag, sub, reE) {\r
-                    var i, j, k, l, l1, l2, m;\r
-                    var ii, mml;\r
-                    var f, g, h, tst1, tst2;\r
-                    var s = 0, s2 = 0;\r
-                    var c, c2, c3 = 0, p, r, dl1, el1;\r
-                    if (n !== 1) {\r
-                        for (i = 1; i < n; i++) {\r
-                            sub[i - 1] = sub[i];\r
-                        }\r
-                        f = 0.0;\r
-                        tst1 = 0.0;\r
-                        sub[n - 1] = 0.0;\r
-                        for (l = 0; l < n; l++) {\r
-                            j = 0;\r
-                            h = Math.abs(diag[l]) + Math.abs(sub[l]);\r
-                            if (tst1 < h) {\r
-                                tst1 = h;\r
-                            }\r
-                            for (m = l; m < n; m++) {\r
-                                tst2 = tst1 + Math.abs(sub[m]);\r
-                                if (tst2 === tst1) {\r
-                                    break;\r
-                                }\r
-                            }\r
-                            if (m !== l) {\r
-                                do {\r
-                                    if (j === 30) {\r
-                                        throw new Error('Failed to converge!');\r
-                                    }\r
-                                    j++;\r
-                                    l1 = l + 1;\r
-                                    l2 = l1 + 1;\r
-                                    g = diag[l];\r
-                                    p = (diag[l1] - g) / (2.0 * sub[l]);\r
-                                    r = cmath_6.CMath.length2(p, 1.0);\r
-                                    diag[l] = sub[l] / (p + (p >= 0 ? r : -r));\r
-                                    diag[l1] = sub[l] * (p + (p >= 0 ? r : -r));\r
-                                    dl1 = diag[l1];\r
-                                    h = g - diag[l];\r
-                                    if (l2 < n) {\r
-                                        for (i = l2; i < n; i++) {\r
-                                            diag[i] -= h;\r
-                                        }\r
-                                    }\r
-                                    f += h;\r
-                                    p = diag[m];\r
-                                    c = 1.0;\r
-                                    c2 = c;\r
-                                    el1 = sub[l1];\r
-                                    s = 0.0;\r
-                                    mml = m - l;\r
-                                    for (i = m - 1; i >= l; i--) {\r
-                                        c3 = c2;\r
-                                        c2 = c;\r
-                                        s2 = s;\r
-                                        g = c * sub[i];\r
-                                        h = c * p;\r
-                                        r = cmath_6.CMath.length2(p, sub[i]);\r
-                                        sub[i + 1] = s * r;\r
-                                        s = sub[i] / r;\r
-                                        c = p / r;\r
-                                        p = c * diag[i] - s * g;\r
-                                        diag[i + 1] = h + s * (c * g + s * diag[i]);\r
-                                        for (k = 0; k < n; k++) {\r
-                                            h = reE[k * n + i + 1];\r
-                                            reE[k * n + i + 1] = s * reE[k * n + i] + c * h;\r
-                                            reE[k * n + i] = c * reE[k * n + i] - s * h;\r
-                                        }\r
-                                    }\r
-                                    p = -s * s2 * c3 * el1 * sub[l] / dl1;\r
-                                    sub[l] = s * p;\r
-                                    diag[l] = c * p;\r
-                                    tst2 = tst1 + Math.abs(sub[l]);\r
-                                } while (tst2 > tst1);\r
-                            }\r
-                            diag[l] += f;\r
-                        }\r
-                        for (ii = 1; ii < n; ii++) {\r
-                            i = ii - 1;\r
-                            k = i;\r
-                            p = diag[i];\r
-                            for (j = ii; j < n; j++) {\r
-                                if (diag[j] < p) {\r
-                                    k = j;\r
-                                    p = diag[j];\r
-                                }\r
-                            }\r
-                            if (k !== i) {\r
-                                diag[k] = diag[i];\r
-                                diag[i] = p;\r
-                                for (j = 0; j < n; j++) {\r
-                                    p = reE[j * n + i];\r
-                                    reE[j * n + i] = reE[j * n + k];\r
-                                    reE[j * n + k] = p;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.rs = function (n, reA, lambda, matz, reE) {\r
-                    var tmpArr = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    if (matz) {\r
-                        Eigen.tred2(n, reA, lambda, tmpArr, reE);\r
-                        Eigen.tql2(n, lambda, tmpArr, reE);\r
-                    }\r
-                    else {\r
-                        var tmpArr2 = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                        Eigen.tred1(n, reA, lambda, tmpArr, tmpArr2);\r
-                        Eigen.tqlrat(n, lambda, tmpArr2);\r
-                    }\r
-                };\r
-                Eigen.htridi = function (n, ar, ai, d, e, e2, tau) {\r
-                    var i, j, k, l, jp1;\r
-                    var f, fi, g, gi, h, hh;\r
-                    var scale, si;\r
-                    tau[n - 1] = 1.0;\r
-                    tau[n + n - 1] = 0.0;\r
-                    for (i = 0; i < n; i++) {\r
-                        d[i] = ar[i * n + i];\r
-                    }\r
-                    for (i = n - 1; i >= 0; i--) {\r
-                        l = i - 1;\r
-                        h = 0.0;\r
-                        scale = 0.0;\r
-                        if (l >= 0) {\r
-                            for (k = 0; k <= l; k++) {\r
-                                scale += Math.abs(ar[i * n + k]) + Math.abs(ai[i * n + k]);\r
-                            }\r
-                            if (scale === 0) {\r
-                                tau[l] = 1.0;\r
-                                tau[n + l] = 0.0;\r
-                                e[i] = 0.0;\r
-                                e2[i] = 0.0;\r
-                            }\r
-                            else {\r
-                                for (k = 0; k <= l; k++) {\r
-                                    ar[i * n + k] /= scale;\r
-                                    ai[i * n + k] /= scale;\r
-                                    h += ar[i * n + k] * ar[i * n + k] + ai[i * n + k] * ai[i * n + k];\r
-                                }\r
-                                e2[i] = scale * scale * h;\r
-                                g = Math.sqrt(h);\r
-                                e[i] = scale * g;\r
-                                f = cmath_6.CMath.length2(ar[i * n + l], ai[i * n + l]);\r
-                                if (f !== 0) {\r
-                                    tau[l] = (ai[i * n + l] * tau[n + i] - ar[i * n + l] * tau[i]) / f;\r
-                                    si = (ar[i * n + l] * tau[n + i] + ai[i * n + l] * tau[i]) / f;\r
-                                    h += f * g;\r
-                                    g = 1.0 + g / f;\r
-                                    ar[i * n + l] *= g;\r
-                                    ai[i * n + l] *= g;\r
-                                }\r
-                                else {\r
-                                    tau[l] = -tau[i];\r
-                                    si = tau[n + i];\r
-                                    ar[i * n + l] = g;\r
-                                }\r
-                                if (l !== 0) {\r
-                                    f = 0.0;\r
-                                    for (j = 0; j <= l; j++) {\r
-                                        g = 0.0;\r
-                                        gi = 0.0;\r
-                                        for (k = 0; k <= j; k++) {\r
-                                            g = g + ar[j * n + k] * ar[i * n + k] + ai[j * n + k] * ai[i * n + k];\r
-                                            gi = gi - ar[j * n + k] * ai[i * n + k] + ai[j * n + k] * ar[i * n + k];\r
-                                        }\r
-                                        jp1 = j + 1;\r
-                                        if (l >= jp1) {\r
-                                            for (k = jp1; k <= l; k++) {\r
-                                                g = g + ar[k * n + j] * ar[i * n + k] - ai[k * n + j] * ai[i * n + k];\r
-                                                gi = gi - ar[k * n + j] * ai[i * n + k] - ai[k * n + j] * ar[i * n + k];\r
-                                            }\r
-                                        }\r
-                                        e[j] = g / h;\r
-                                        tau[n + j] = gi / h;\r
-                                        f += e[j] * ar[i * n + j] - tau[n + j] * ai[i * n + j];\r
-                                    }\r
-                                    hh = f / (h + h);\r
-                                    for (j = 0; j <= l; j++) {\r
-                                        f = ar[i * n + j];\r
-                                        g = e[j] - hh * f;\r
-                                        e[j] = g;\r
-                                        fi = -ai[i * n + j];\r
-                                        gi = tau[n + j] - hh * fi;\r
-                                        tau[n + j] = -gi;\r
-                                        for (k = 0; k <= j; k++) {\r
-                                            ar[j * n + k] += -f * e[k] - g * ar[i * n + k]\r
-                                                + fi * tau[n + k] + gi * ai[i * n + k];\r
-                                            ai[j * n + k] += -f * tau[n + k] - g * ai[i * n + k]\r
-                                                - fi * e[k] - gi * ar[i * n + k];\r
-                                        }\r
-                                    }\r
-                                }\r
-                                for (k = 0; k <= l; k++) {\r
-                                    ar[i * n + k] *= scale;\r
-                                    ai[i * n + k] *= scale;\r
-                                }\r
-                                tau[n + l] = -si;\r
-                            }\r
-                        }\r
-                        else {\r
-                            e[i] = 0.0;\r
-                            e2[i] = 0.0;\r
-                        }\r
-                        hh = d[i];\r
-                        d[i] = ar[i * n + i];\r
-                        ar[i * n + i] = hh;\r
-                        ai[i * n + i] = scale * Math.sqrt(h);\r
-                    }\r
-                };\r
-                Eigen.htribk = function (n, ar, ai, tau, m, zr, zi) {\r
-                    var i, j, k, l;\r
-                    var h, s, si;\r
-                    if (m > 0) {\r
-                        for (k = 0; k < n; k++) {\r
-                            for (j = 0; j < m; j++) {\r
-                                zi[k * n + j] = -zr[k * n + j] * tau[n + k];\r
-                                zr[k * n + j] = zr[k * n + j] * tau[k];\r
-                            }\r
-                        }\r
-                        if (n === 1) {\r
-                            return;\r
-                        }\r
-                        for (i = 1; i < n; i++) {\r
-                            l = i - 1;\r
-                            h = ai[i * n + i];\r
-                            if (h === 0) {\r
-                                continue;\r
-                            }\r
-                            for (j = 0; j < m; j++) {\r
-                                s = 0.0;\r
-                                si = 0.0;\r
-                                for (k = 0; k <= l; k++) {\r
-                                    s += ar[i * n + k] * zr[k * n + j] - ai[i * n + k] * zi[k * n + j];\r
-                                    si += ar[i * n + k] * zi[k * n + j] + ai[i * n + k] * zr[k * n + j];\r
-                                }\r
-                                s = (s / h) / h;\r
-                                si = (si / h) / h;\r
-                                for (k = 0; k <= l; k++) {\r
-                                    zr[k * n + j] += -s * ar[i * n + k] - si * ai[i * n + k];\r
-                                    zi[k * n + j] += -si * ar[i * n + k] + s * ai[i * n + k];\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.ch = function (n, ar, ai, w, matz, zr, zi) {\r
-                    var tmpArr1 = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var tmpArr2 = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var tmpArr3 = dataHelper_10.DataHelper.allocateFloat64Array(2 * n);\r
-                    Eigen.htridi(n, ar, ai, w, tmpArr1, tmpArr2, tmpArr3);\r
-                    if (matz) {\r
-                        for (var i = 0; i < n; i++) {\r
-                            zr[i * n + i] = 1.0;\r
-                        }\r
-                        Eigen.tql2(n, w, tmpArr1, zr);\r
-                        Eigen.htribk(n, ar, ai, tmpArr3, n, zr, zi);\r
-                    }\r
-                    else {\r
-                        Eigen.tqlrat(n, w, tmpArr2);\r
-                    }\r
-                };\r
-                Eigen.balanc = function (n, a, scale) {\r
-                    var radix = 16.0;\r
-                    var b2 = radix * radix;\r
-                    var k = 0;\r
-                    var l = n - 1;\r
-                    var i, j;\r
-                    var m = 0, c, r, f, g, s;\r
-                    var flag = true;\r
-                    while (flag) {\r
-                        flag = false;\r
-                        rowLoop: for (j = l; j >= 0; j--) {\r
-                            for (i = 0; i <= l; i++) {\r
-                                if (i === j) {\r
-                                    continue;\r
-                                }\r
-                                if (a[j * n + i] !== 0.0) {\r
-                                    continue rowLoop;\r
-                                }\r
-                            }\r
-                            m = l;\r
-                            scale[m] = j;\r
-                            if (j !== m) {\r
-                                for (i = 0; i <= l; i++) {\r
-                                    f = a[i * n + j];\r
-                                    a[i * n + j] = a[i * n + m];\r
-                                    a[i * n + m] = f;\r
-                                }\r
-                                for (i = k; i < n; i++) {\r
-                                    f = a[j * n + i];\r
-                                    a[j * n + i] = a[m * n + i];\r
-                                    a[m * n + i] = f;\r
-                                }\r
-                            }\r
-                            if (l === 0) {\r
-                                return [k, l];\r
-                            }\r
-                            l--;\r
-                            flag = true;\r
-                            break;\r
-                        }\r
-                    }\r
-                    flag = true;\r
-                    while (flag) {\r
-                        flag = false;\r
-                        colLoop: for (j = k; j <= l; j++) {\r
-                            for (i = k; i <= l; i++) {\r
-                                if (i === j) {\r
-                                    continue;\r
-                                }\r
-                                if (a[i * n + j] !== 0.0) {\r
-                                    continue colLoop;\r
-                                }\r
-                            }\r
-                            m = k;\r
-                            scale[m] = j;\r
-                            if (j !== m) {\r
-                                for (i = 0; i <= l; i++) {\r
-                                    f = a[i * n + j];\r
-                                    a[i * n + j] = a[i * n + m];\r
-                                    a[i * n + m] = f;\r
-                                }\r
-                                for (i = k; i < n; i++) {\r
-                                    f = a[j * n + i];\r
-                                    a[j * n + i] = a[m * n + i];\r
-                                    a[m * n + i] = f;\r
-                                }\r
-                            }\r
-                            k++;\r
-                            flag = true;\r
-                            break;\r
-                        }\r
-                    }\r
-                    for (i = k; i <= l; i++) {\r
-                        scale[i] = 1.0;\r
-                    }\r
-                    do {\r
-                        flag = false;\r
-                        for (i = k; i <= l; i++) {\r
-                            c = 0.0;\r
-                            r = 0.0;\r
-                            for (j = k; j <= l; j++) {\r
-                                if (j === i) {\r
-                                    continue;\r
-                                }\r
-                                c += Math.abs(a[j * n + i]);\r
-                                r += Math.abs(a[i * n + j]);\r
-                            }\r
-                            if (c === 0.0 || r === 0.0) {\r
-                                continue;\r
-                            }\r
-                            g = r / radix;\r
-                            f = 1.0;\r
-                            s = c + r;\r
-                            while (c < g) {\r
-                                f *= radix;\r
-                                c *= b2;\r
-                            }\r
-                            g = r * radix;\r
-                            while (c >= g) {\r
-                                f /= radix;\r
-                                c /= b2;\r
-                            }\r
-                            if ((c + r) / f >= 0.95 * s) {\r
-                                continue;\r
-                            }\r
-                            g = 1.0 / f;\r
-                            scale[i] *= f;\r
-                            flag = true;\r
-                            for (j = k; j < n; j++) {\r
-                                a[i * n + j] *= g;\r
-                            }\r
-                            for (j = 0; j <= l; j++) {\r
-                                a[j * n + i] *= f;\r
-                            }\r
-                        }\r
-                    } while (flag);\r
-                    return [k, l];\r
-                };\r
-                Eigen.elmhes = function (n, low, igh, a, int) {\r
-                    var i, j, m, la, kp1, mm1, mp1;\r
-                    var x, y;\r
-                    la = igh - 1;\r
-                    kp1 = low + 1;\r
-                    if (la < kp1) {\r
-                        return;\r
-                    }\r
-                    for (m = kp1; m <= la; m++) {\r
-                        mm1 = m - 1;\r
-                        x = 0.0;\r
-                        i = m;\r
-                        for (j = m; j <= igh; j++) {\r
-                            if (Math.abs(a[j * n + mm1]) > Math.abs(x)) {\r
-                                x = a[j * n + mm1];\r
-                                i = j;\r
-                            }\r
-                        }\r
-                        int[m] = i;\r
-                        if (i !== m) {\r
-                            for (j = mm1; j < n; j++) {\r
-                                y = a[i * n + j];\r
-                                a[i * n + j] = a[m * n + j];\r
-                                a[m * n + j] = y;\r
-                            }\r
-                            for (j = 0; j <= igh; j++) {\r
-                                y = a[j * n + i];\r
-                                a[j * n + i] = a[j * n + m];\r
-                                a[j * n + m] = y;\r
-                            }\r
-                        }\r
-                        if (x === 0.0) {\r
-                            continue;\r
-                        }\r
-                        mp1 = m + 1;\r
-                        for (i = mp1; i <= igh; i++) {\r
-                            y = a[i * n + mm1];\r
-                            if (y === 0.0) {\r
-                                continue;\r
-                            }\r
-                            y = y / x;\r
-                            a[i * n + mm1] = y;\r
-                            for (j = m; j < n; j++) {\r
-                                a[i * n + j] -= y * a[m * n + j];\r
-                            }\r
-                            for (j = 0; j <= igh; j++) {\r
-                                a[j * n + m] += y * a[j * n + i];\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.eltran = function (n, low, igh, a, int, z) {\r
-                    var i, j, kl, mp, mp1;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = 0; j < n; j++) {\r
-                            z[i * n + j] = 0.0;\r
-                        }\r
-                        z[i * n + i] = 1.0;\r
-                    }\r
-                    kl = igh - low + 1;\r
-                    if (kl < 1) {\r
-                        return;\r
-                    }\r
-                    for (mp = igh - 1; mp >= low + 1; mp--) {\r
-                        mp1 = mp + 1;\r
-                        for (i = mp1; i <= igh; i++) {\r
-                            z[i * n + mp] = a[i * n + mp - 1];\r
-                        }\r
-                        i = int[mp];\r
-                        if (i !== mp) {\r
-                            for (j = mp; j <= igh; j++) {\r
-                                z[mp * n + j] = z[i * n + j];\r
-                                z[i * n + j] = 0.0;\r
-                            }\r
-                            z[i * n + mp] = 1.0;\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.hqr = function (n, low, igh, h, wr, wi) {\r
-                    var i, j, k, l, m, en;\r
-                    var na = 0, itn, its = 0;\r
-                    var mp2, enm2 = 0;\r
-                    var p = 0, q = 0, r = 0, s = 0, t, w;\r
-                    var x, y;\r
-                    var zz = 0, norm, tst1, tst2;\r
-                    var notlas, skip = false;\r
-                    norm = 0.0;\r
-                    k = 0;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = k; j < n; j++) {\r
-                            norm += Math.abs(h[i * n + j]);\r
-                        }\r
-                        k = i;\r
-                        if (i < low || i > igh) {\r
-                            wr[i] = h[i * n + i];\r
-                            wi[i] = 0.0;\r
-                        }\r
-                    }\r
-                    en = igh;\r
-                    t = 0.0;\r
-                    itn = 30 * n;\r
-                    while (true) {\r
-                        if (!skip) {\r
-                            if (en < low) {\r
-                                break;\r
-                            }\r
-                            its = 0;\r
-                            na = en - 1;\r
-                            enm2 = na - 1;\r
-                        }\r
-                        for (l = en; l > low; l--) {\r
-                            s = Math.abs(h[(l - 1) * n + l - 1]) + Math.abs(h[l * n + l]);\r
-                            if (s === 0.0) {\r
-                                s = norm;\r
-                            }\r
-                            tst1 = s;\r
-                            tst2 = tst1 + Math.abs(h[l * n + l - 1]);\r
-                            if (tst2 === tst1) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        x = h[en * n + en];\r
-                        if (l !== en) {\r
-                            y = h[na * n + na];\r
-                            w = h[en * n + na] * h[na * n + en];\r
-                            if (l !== na) {\r
-                                if (itn === 0) {\r
-                                    throw new Error('Maximum number of iterations reached.');\r
-                                }\r
-                                if (its === 10 || its === 20) {\r
-                                    t += x;\r
-                                    for (i = low; i <= en; i++) {\r
-                                        h[i * n + i] -= x;\r
-                                    }\r
-                                    s = Math.abs(h[en * n + na]) + Math.abs(h[na * n + enm2]);\r
-                                    x = 0.75 * s;\r
-                                    y = x;\r
-                                    w = -0.4375 * s * s;\r
-                                }\r
-                                its++;\r
-                                itn--;\r
-                                for (m = en - 2; m >= l; m--) {\r
-                                    zz = h[m * n + m];\r
-                                    r = x - zz;\r
-                                    s = y - zz;\r
-                                    p = (r * s - w) / h[(m + 1) * n + m] + h[m * n + m + 1];\r
-                                    q = h[(m + 1) * n + (m + 1)] - zz - r - s;\r
-                                    r = h[(m + 2) * n + (m + 1)];\r
-                                    s = Math.abs(p) + Math.abs(q) + Math.abs(r);\r
-                                    p /= s;\r
-                                    q /= s;\r
-                                    r /= s;\r
-                                    if (m === l) {\r
-                                        break;\r
-                                    }\r
-                                    tst1 = Math.abs(p) * (Math.abs(h[(m - 1) * n + (m - 1)]) + Math.abs(zz)\r
-                                        + Math.abs(h[(m + 1) * n + (m + 1)]));\r
-                                    tst2 = tst1 + Math.abs(h[m * n + (m - 1)]) * (Math.abs(q) + Math.abs(r));\r
-                                    if (tst2 === tst1) {\r
-                                        break;\r
-                                    }\r
-                                }\r
-                                mp2 = m + 2;\r
-                                for (i = mp2; i <= en; i++) {\r
-                                    h[i * n + (i - 2)] = 0.0;\r
-                                    if (i === mp2) {\r
-                                        continue;\r
-                                    }\r
-                                    h[i * n + (i - 3)] = 0.0;\r
-                                }\r
-                                for (k = m; k <= na; k++) {\r
-                                    notlas = k !== na;\r
-                                    if (k !== m) {\r
-                                        p = h[k * n + (k - 1)];\r
-                                        q = h[(k + 1) * n + (k - 1)];\r
-                                        r = notlas ? h[(k + 2) * n + (k - 1)] : 0.0;\r
-                                        x = Math.abs(p) + Math.abs(q) + Math.abs(r);\r
-                                        if (x === 0) {\r
-                                            continue;\r
-                                        }\r
-                                        p /= x;\r
-                                        q /= x;\r
-                                        r /= x;\r
-                                    }\r
-                                    s = p >= 0 ? Math.sqrt(p * p + q * q + r * r) : -Math.sqrt(p * p + q * q + r * r);\r
-                                    if (k !== m) {\r
-                                        h[k * n + (k - 1)] = -s * x;\r
-                                    }\r
-                                    else {\r
-                                        if (l !== m) {\r
-                                            h[k * n + (k - 1)] = -h[k * n + (k - 1)];\r
-                                        }\r
-                                    }\r
-                                    p += s;\r
-                                    x = p / s;\r
-                                    y = q / s;\r
-                                    zz = r / s;\r
-                                    q = q / p;\r
-                                    r = r / p;\r
-                                    if (notlas) {\r
-                                        for (j = k; j <= en; j++) {\r
-                                            p = h[k * n + j] + q * h[(k + 1) * n + j] + r * h[(k + 2) * n + j];\r
-                                            h[k * n + j] -= p * x;\r
-                                            h[(k + 1) * n + j] -= p * y;\r
-                                            h[(k + 2) * n + j] -= p * zz;\r
-                                        }\r
-                                        j = Math.min(en, k + 3);\r
-                                        for (i = l; i <= j; i++) {\r
-                                            p = x * h[i * n + k] + y * h[i * n + (k + 1)] + zz * h[i * n + (k + 2)];\r
-                                            h[i * n + k] -= p;\r
-                                            h[i * n + (k + 1)] -= p * q;\r
-                                            h[i * n + (k + 2)] -= p * r;\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (j = k; j <= en; j++) {\r
-                                            p = h[k * n + j] + q * h[(k + 1) * n + j];\r
-                                            h[k * n + j] -= p * x;\r
-                                            h[(k + 1) * n + j] -= p * y;\r
-                                        }\r
-                                        j = Math.min(en, k + 3);\r
-                                        for (i = l; i <= j; i++) {\r
-                                            p = x * h[i * n + k] + y * h[i * n + (k + 1)];\r
-                                            h[i * n + k] -= p;\r
-                                            h[i * n + (k + 1)] -= p * q;\r
-                                        }\r
-                                    }\r
-                                }\r
-                                skip = true;\r
-                            }\r
-                            else {\r
-                                p = (y - x) / 2.0;\r
-                                q = p * p + w;\r
-                                zz = Math.sqrt(Math.abs(q));\r
-                                x = x + t;\r
-                                if (q >= 0.0) {\r
-                                    zz = p + (p >= 0 ? Math.abs(zz) : -Math.abs(zz));\r
-                                    wr[na] = x + zz;\r
-                                    wr[en] = wr[na];\r
-                                    if (zz !== 0) {\r
-                                        wr[en] = x - w / zz;\r
-                                    }\r
-                                    wi[na] = 0.0;\r
-                                    wi[en] = 0.0;\r
-                                }\r
-                                else {\r
-                                    wr[na] = x + p;\r
-                                    wr[en] = x + p;\r
-                                    wi[na] = zz;\r
-                                    wi[en] = -zz;\r
-                                }\r
-                                en = enm2;\r
-                                skip = false;\r
-                            }\r
-                        }\r
-                        else {\r
-                            wr[en] = x + t;\r
-                            wi[en] = 0.0;\r
-                            en = na;\r
-                            skip = false;\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.hqr2 = function (n, low, igh, h, wr, wi, z) {\r
-                    var i, j, k, l, m, en;\r
-                    var na = 0, itn, its = 0;\r
-                    var mp2, enm2 = 0;\r
-                    var p = 0, q = 0, r = 0, s = 0, t, w;\r
-                    var x, y, ra, sa, vi, vr;\r
-                    var zz = 0, norm, tst1, tst2;\r
-                    var notlas, skip = false;\r
-                    norm = 0.0;\r
-                    k = 0;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = k; j <= n; j++) {\r
-                            norm += Math.abs(h[i * n + j]);\r
-                        }\r
-                        k = i;\r
-                        if (i < low || i > igh) {\r
-                            wr[i] = h[i * n + i];\r
-                            wi[i] = 0.0;\r
-                        }\r
-                    }\r
-                    en = igh;\r
-                    t = 0.0;\r
-                    itn = 30 * n;\r
-                    while (true) {\r
-                        if (!skip) {\r
-                            if (en < low) {\r
-                                break;\r
-                            }\r
-                            its = 0;\r
-                            na = en - 1;\r
-                            enm2 = na - 1;\r
-                        }\r
-                        for (l = en; l > low; l--) {\r
-                            s = Math.abs(h[(l - 1) * n + l - 1]) + Math.abs(h[l * n + l]);\r
-                            if (s === 0.0) {\r
-                                s = norm;\r
-                            }\r
-                            tst1 = s;\r
-                            tst2 = tst1 + Math.abs(h[l * n + l - 1]);\r
-                            if (tst2 === tst1) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        x = h[en * n + en];\r
-                        if (l !== en) {\r
-                            y = h[na * n + na];\r
-                            w = h[en * n + na] * h[na * n + en];\r
-                            if (l !== na) {\r
-                                if (itn === 0) {\r
-                                    throw new Error('Maximum number of iterations reached.');\r
-                                }\r
-                                if (its === 10 || its === 20) {\r
-                                    t += x;\r
-                                    for (i = low; i <= en; i++) {\r
-                                        h[i * n + i] -= x;\r
-                                    }\r
-                                    s = Math.abs(h[en * n + na]) + Math.abs(h[na * n + enm2]);\r
-                                    x = 0.75 * s;\r
-                                    y = x;\r
-                                    w = -0.4375 * s * s;\r
-                                }\r
-                                its++;\r
-                                itn--;\r
-                                for (m = en - 2; m >= l; m--) {\r
-                                    zz = h[m * n + m];\r
-                                    r = x - zz;\r
-                                    s = y - zz;\r
-                                    p = (r * s - w) / h[(m + 1) * n + m] + h[m * n + m + 1];\r
-                                    q = h[(m + 1) * n + (m + 1)] - zz - r - s;\r
-                                    r = h[(m + 2) * n + (m + 1)];\r
-                                    s = Math.abs(p) + Math.abs(q) + Math.abs(r);\r
-                                    p /= s;\r
-                                    q /= s;\r
-                                    r /= s;\r
-                                    if (m === l) {\r
-                                        break;\r
-                                    }\r
-                                    tst1 = Math.abs(p) * (Math.abs(h[(m - 1) * n + (m - 1)]) + Math.abs(zz)\r
-                                        + Math.abs(h[(m + 1) * n + (m + 1)]));\r
-                                    tst2 = tst1 + Math.abs(h[m * n + (m - 1)]) * (Math.abs(q) + Math.abs(r));\r
-                                    if (tst2 === tst1) {\r
-                                        break;\r
-                                    }\r
-                                }\r
-                                mp2 = m + 2;\r
-                                for (i = mp2; i <= en; i++) {\r
-                                    h[i * n + (i - 2)] = 0.0;\r
-                                    if (i === mp2) {\r
-                                        continue;\r
-                                    }\r
-                                    h[i * n + (i - 3)] = 0.0;\r
-                                }\r
-                                for (k = m; k <= na; k++) {\r
-                                    notlas = k !== na;\r
-                                    if (k !== m) {\r
-                                        p = h[k * n + (k - 1)];\r
-                                        q = h[(k + 1) * n + (k - 1)];\r
-                                        r = notlas ? h[(k + 2) * n + (k - 1)] : 0.0;\r
-                                        x = Math.abs(p) + Math.abs(q) + Math.abs(r);\r
-                                        if (x === 0) {\r
-                                            continue;\r
-                                        }\r
-                                        p /= x;\r
-                                        q /= x;\r
-                                        r /= x;\r
-                                    }\r
-                                    s = p >= 0 ? Math.sqrt(p * p + q * q + r * r) : -Math.sqrt(p * p + q * q + r * r);\r
-                                    if (k !== m) {\r
-                                        h[k * n + (k - 1)] = -s * x;\r
-                                    }\r
-                                    else {\r
-                                        if (l !== m) {\r
-                                            h[k * n + (k - 1)] = -h[k * n + (k - 1)];\r
-                                        }\r
-                                    }\r
-                                    p += s;\r
-                                    x = p / s;\r
-                                    y = q / s;\r
-                                    zz = r / s;\r
-                                    q = q / p;\r
-                                    r = r / p;\r
-                                    if (notlas) {\r
-                                        for (j = k; j < n; j++) {\r
-                                            p = h[k * n + j] + q * h[(k + 1) * n + j] + r * h[(k + 2) * n + j];\r
-                                            h[k * n + j] -= p * x;\r
-                                            h[(k + 1) * n + j] -= p * y;\r
-                                            h[(k + 2) * n + j] -= p * zz;\r
-                                        }\r
-                                        j = Math.min(en, k + 3);\r
-                                        for (i = 0; i <= j; i++) {\r
-                                            p = x * h[i * n + k] + y * h[i * n + (k + 1)] + zz * h[i * n + (k + 2)];\r
-                                            h[i * n + k] -= p;\r
-                                            h[i * n + (k + 1)] -= p * q;\r
-                                            h[i * n + (k + 2)] -= p * r;\r
-                                        }\r
-                                        for (i = low; i <= igh; i++) {\r
-                                            p = x * z[i * n + k] + y * z[i * n + (k + 1)] + zz * z[i * n + (k + 2)];\r
-                                            z[i * n + k] -= p;\r
-                                            z[i * n + (k + 1)] -= p * q;\r
-                                            z[i * n + (k + 2)] -= p * r;\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (j = k; j < n; j++) {\r
-                                            p = h[k * n + j] + q * h[(k + 1) * n + j];\r
-                                            h[k * n + j] -= p * x;\r
-                                            h[(k + 1) * n + j] -= p * y;\r
-                                        }\r
-                                        j = Math.min(en, k + 3);\r
-                                        for (i = 0; i <= j; i++) {\r
-                                            p = x * h[i * n + k] + y * h[i * n + (k + 1)];\r
-                                            h[i * n + k] -= p;\r
-                                            h[i * n + (k + 1)] -= p * q;\r
-                                        }\r
-                                        for (i = low; i <= igh; i++) {\r
-                                            p = x * z[i * n + k] + y * z[i * n + (k + 1)];\r
-                                            z[i * n + k] -= p;\r
-                                            z[i * n + (k + 1)] -= p * q;\r
-                                        }\r
-                                    }\r
-                                }\r
-                                skip = true;\r
-                            }\r
-                            else {\r
-                                p = (y - x) / 2.0;\r
-                                q = p * p + w;\r
-                                zz = Math.sqrt(Math.abs(q));\r
-                                h[en * n + en] = x + t;\r
-                                x = h[en * n + en];\r
-                                h[na * n + na] = y + t;\r
-                                if (q >= 0.0) {\r
-                                    zz = p + (p >= 0 ? Math.abs(zz) : -Math.abs(zz));\r
-                                    wr[na] = x + zz;\r
-                                    wr[en] = wr[na];\r
-                                    if (zz !== 0) {\r
-                                        wr[en] = x - w / zz;\r
-                                    }\r
-                                    wi[na] = 0.0;\r
-                                    wi[en] = 0.0;\r
-                                    x = h[en * n + na];\r
-                                    s = Math.abs(x) + Math.abs(zz);\r
-                                    p = x / s;\r
-                                    q = zz / s;\r
-                                    r = Math.sqrt(p * p + q * q);\r
-                                    p /= r;\r
-                                    q /= r;\r
-                                    for (j = na; j < n; j++) {\r
-                                        zz = h[na * n + j];\r
-                                        h[na * n + j] = q * zz + p * h[en * n + j];\r
-                                        h[en * n + j] = q * h[en * n + j] - p * zz;\r
-                                    }\r
-                                    for (i = 0; i <= en; i++) {\r
-                                        zz = h[i * n + na];\r
-                                        h[i * n + na] = q * zz + p * h[i * n + en];\r
-                                        h[i * n + en] = q * h[i * n + en] - p * zz;\r
-                                    }\r
-                                    for (i = low; i <= igh; i++) {\r
-                                        zz = z[i * n + na];\r
-                                        z[i * n + na] = q * zz + p * z[i * n + en];\r
-                                        z[i * n + en] = q * z[i * n + en] - p * zz;\r
-                                    }\r
-                                    en = enm2;\r
-                                    skip = false;\r
-                                }\r
-                                else {\r
-                                    wr[na] = x + p;\r
-                                    wr[en] = x + p;\r
-                                    wi[na] = zz;\r
-                                    wi[en] = -zz;\r
-                                    en = enm2;\r
-                                    skip = false;\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            h[en * n + en] = x + t;\r
-                            wr[en] = h[en * n + en];\r
-                            wi[en] = 0.0;\r
-                            en = na;\r
-                            skip = false;\r
-                        }\r
-                    }\r
-                    if (norm === 0) {\r
-                        return;\r
-                    }\r
-                    for (en = n - 1; en >= 0; en--) {\r
-                        p = wr[en];\r
-                        q = wi[en];\r
-                        na = en - 1;\r
-                        if (q < 0.0) {\r
-                            m = na;\r
-                            if (Math.abs(h[en * n + na]) <= Math.abs(h[na * n + en])) {\r
-                                _a = cmath_6.CMath.cdivCC(0.0, -h[na * n + en], h[na * n + na] - p, q), h[na * n + na] = _a[0], h[na * n + en] = _a[1];\r
-                            }\r
-                            else {\r
-                                h[na * n + na] = q / h[en * n + na];\r
-                                h[na * n + en] = -(h[en * n + en] - p) / h[en * n + na];\r
-                            }\r
-                            h[en * n + na] = 0.0;\r
-                            h[en * n + en] = 1.0;\r
-                            enm2 = na - 1;\r
-                            if (enm2 === -1) {\r
-                                continue;\r
-                            }\r
-                            for (i = en - 2; i >= 0; i--) {\r
-                                w = h[i * n + i] - p;\r
-                                ra = 0.0;\r
-                                sa = 0.0;\r
-                                for (j = m; j <= en; j++) {\r
-                                    ra += h[i * n + j] * h[j * n + na];\r
-                                    sa += h[i * n + j] * h[j * n + en];\r
-                                }\r
-                                if (wi[i] >= 0.0) {\r
-                                    m = i;\r
-                                    if (wi[i] !== 0.0) {\r
-                                        x = h[i * n + (i + 1)];\r
-                                        y = h[(i + 1) * n + i];\r
-                                        vr = (wr[i] - p) * (wr[i] - p) + wi[i] * wi[i] - q * q;\r
-                                        vi = (wr[i] - p) * 2 * q;\r
-                                        if (vr === 0.0 && vi === 0.0) {\r
-                                            tst1 = norm * (Math.abs(w) + Math.abs(q) + Math.abs(x)\r
-                                                + Math.abs(y) + Math.abs(zz));\r
-                                            vr = tst1;\r
-                                            do {\r
-                                                vr = 0.01 * vr;\r
-                                                tst2 = tst1 + vr;\r
-                                            } while (tst2 > tst1);\r
-                                        }\r
-                                        _b = cmath_6.CMath.cdivCC(x * r - zz * ra + q * sa, x * s - zz * sa - q * ra, vr, vi), h[i * n + na] = _b[0], h[i * n + en] = _b[1];\r
-                                        if (Math.abs(x) <= Math.abs(zz) + Math.abs(q)) {\r
-                                            _c = cmath_6.CMath.cdivCC(-r - y * h[i * n + na], -s - y * h[i * n + en], zz, q), h[(i + 1) * n + na] = _c[0], h[(i + 1) * n + en] = _c[1];\r
-                                        }\r
-                                        else {\r
-                                            h[(i + 1) * n + na] = (-ra - w * h[i * n + na] + q * h[i * n + en]) / x;\r
-                                            h[(i + 1) * n + en] = (-sa - w * h[i * n + en] - q * h[i * n + na]) / x;\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        _d = cmath_6.CMath.cdivCC(-ra, -sa, w, q), h[i * n + na] = _d[0], h[i * n + en] = _d[1];\r
-                                    }\r
-                                    t = Math.max(Math.abs(h[i * n + na]), Math.abs(h[i * n + en]));\r
-                                    if (t === 0.0) {\r
-                                        continue;\r
-                                    }\r
-                                    tst1 = t;\r
-                                    tst2 = tst1 + 1.0 / tst1;\r
-                                    if (tst2 <= tst1) {\r
-                                        for (j = i; j <= en; j++) {\r
-                                            h[j * n + na] /= t;\r
-                                            h[j * n + en] /= t;\r
-                                        }\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    zz = w;\r
-                                    r = ra;\r
-                                    s = sa;\r
-                                }\r
-                            }\r
-                        }\r
-                        else if (q === 0.0) {\r
-                            m = en;\r
-                            h[en * n + en] = 1.0;\r
-                            if (na < 0) {\r
-                                continue;\r
-                            }\r
-                            for (i = en - 1; i >= 0; i--) {\r
-                                w = h[i * n + i] - p;\r
-                                r = 0.0;\r
-                                for (j = m; j <= en; j++) {\r
-                                    r += h[i * n + j] * h[j * n + en];\r
-                                }\r
-                                if (wi[i] < 0.0) {\r
-                                    zz = w;\r
-                                    s = r;\r
-                                    continue;\r
-                                }\r
-                                m = i;\r
-                                if (wi[i] === 0.0) {\r
-                                    t = w;\r
-                                    if (t === 0.0) {\r
-                                        tst1 = norm;\r
-                                        t = tst1;\r
-                                        do {\r
-                                            t = 0.01 * t;\r
-                                            tst2 = norm + t;\r
-                                        } while (tst2 > tst1);\r
-                                    }\r
-                                    h[i * n + en] = -r / t;\r
-                                }\r
-                                else {\r
-                                    x = h[i * n + (i + 1)];\r
-                                    y = h[(i + 1) * n + i];\r
-                                    q = (wr[i] - p) * (wr[i] - p) + wi[i] * wi[i];\r
-                                    t = (x * s - zz * r) / q;\r
-                                    h[i * n + en] = t;\r
-                                    if (Math.abs(x) <= Math.abs(zz)) {\r
-                                        h[(i + 1) * n + en] = (-s - y * t) / zz;\r
-                                    }\r
-                                    else {\r
-                                        h[(i + 1) * n + en] = (-r - w * t) / x;\r
-                                    }\r
-                                }\r
-                                t = Math.abs(h[i * n + en]);\r
-                                if (t === 0.0) {\r
-                                    continue;\r
-                                }\r
-                                tst1 = t;\r
-                                tst2 = tst1 + 1.0 / tst1;\r
-                                if (tst2 <= tst1) {\r
-                                    for (j = i; j <= en; j++) {\r
-                                        h[j * n + en] /= t;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            continue;\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        if (i >= low && i <= igh) {\r
-                            continue;\r
-                        }\r
-                        for (j = i; j < n; j++) {\r
-                            z[i * n + j] = h[i * n + j];\r
-                        }\r
-                    }\r
-                    for (j = n - 1; j >= 0; j--) {\r
-                        m = Math.min(j, igh);\r
-                        for (i = low; i <= igh; i++) {\r
-                            zz = 0.0;\r
-                            for (k = low; k <= m; k++) {\r
-                                zz += z[i * n + k] * h[k * n + j];\r
-                            }\r
-                            z[i * n + j] = zz;\r
-                        }\r
-                    }\r
-                    var _a, _b, _c, _d;\r
-                };\r
-                Eigen.balbak = function (n, low, igh, scale, m, z) {\r
-                    var i, j, k;\r
-                    var s;\r
-                    if (m === 0) {\r
-                        return;\r
-                    }\r
-                    if (igh !== low) {\r
-                        for (i = low; i <= igh; i++) {\r
-                            s = scale[i];\r
-                            for (j = 0; j < m; j++) {\r
-                                z[i * n + j] *= s;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = low - 1; i >= 0; i--) {\r
-                        k = scale[i];\r
-                        if (k !== i) {\r
-                            for (j = 0; j < m; j++) {\r
-                                s = z[i * n + j];\r
-                                z[i * n + j] = z[k * n + j];\r
-                                z[j * n + j] = s;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = igh + 1; i < n; i++) {\r
-                        k = scale[i];\r
-                        if (k !== i) {\r
-                            for (j = 0; j < m; j++) {\r
-                                s = z[i * n + j];\r
-                                z[i * n + j] = z[k * n + j];\r
-                                z[j * n + j] = s;\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.rg = function (n, a, wr, wi, matz, zr, zi) {\r
-                    var i, j;\r
-                    var tmpArr1 = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var _a = Eigen.balanc(n, a, tmpArr1), low = _a[0], igh = _a[1];\r
-                    var tmpArr2 = dataHelper_10.DataHelper.allocateInt32Array(igh + 1);\r
-                    Eigen.elmhes(n, low, igh, a, tmpArr2);\r
-                    if (matz) {\r
-                        Eigen.eltran(n, low, igh, a, tmpArr2, zr);\r
-                        Eigen.hqr2(n, low, igh, a, wr, wi, zr);\r
-                        Eigen.balbak(n, low, igh, tmpArr1, n, zr);\r
-                        for (i = 0; i < n;) {\r
-                            if (wi[i] === 0) {\r
-                                for (j = 0; j < n; j++) {\r
-                                    zi[j * n + i] = 0.0;\r
-                                }\r
-                                i++;\r
-                            }\r
-                            else if (wi[i] > 0) {\r
-                                for (j = 0; j < n; j++) {\r
-                                    zi[j * n + i] = zr[j * n + (i + 1)];\r
-                                    zi[j * n + (i + 1)] = -zr[j * n + (i + 1)];\r
-                                    zr[j * n + (i + 1)] = zr[j * n + i];\r
-                                }\r
-                                i += 2;\r
-                            }\r
-                            else {\r
-                                throw new Error('This should never happen.');\r
-                            }\r
-                        }\r
-                    }\r
-                    else {\r
-                        Eigen.hqr(n, low, igh, a, wr, wi);\r
-                    }\r
-                };\r
-                Eigen.cbal = function (n, ar, ai, scale) {\r
-                    var i, j, k, l, m;\r
-                    var c, f, g, r, s, b2;\r
-                    var flag = true;\r
-                    var radix = 16.0;\r
-                    b2 = radix * radix;\r
-                    k = 0;\r
-                    l = n - 1;\r
-                    while (flag) {\r
-                        flag = false;\r
-                        rowLoop: for (j = l; j >= 0; j--) {\r
-                            for (i = 0; i <= l; i++) {\r
-                                if (i === j) {\r
-                                    continue;\r
-                                }\r
-                                if (ar[j * n + i] !== 0.0 || ai[j * n + i] !== 0.0) {\r
-                                    continue rowLoop;\r
-                                }\r
-                            }\r
-                            m = l;\r
-                            scale[m] = j;\r
-                            if (j !== m) {\r
-                                for (i = 0; i <= l; i++) {\r
-                                    f = ar[i * n + j];\r
-                                    ar[i * n + j] = ar[i * n + m];\r
-                                    ar[i * n + m] = f;\r
-                                    f = ai[i * n + j];\r
-                                    ai[i * n + j] = ai[i * n + m];\r
-                                    ai[i * n + m] = f;\r
-                                }\r
-                                for (i = k; i < n; i++) {\r
-                                    f = ar[j * n + i];\r
-                                    ar[j * n + i] = ar[m * n + i];\r
-                                    ar[m * n + i] = f;\r
-                                    f = ai[j * n + i];\r
-                                    ai[j * n + i] = ai[m * n + i];\r
-                                    ai[m * n + i] = f;\r
-                                }\r
-                            }\r
-                            if (l === 0) {\r
-                                return [k, l];\r
-                            }\r
-                            l--;\r
-                            flag = true;\r
-                            break;\r
-                        }\r
-                    }\r
-                    flag = true;\r
-                    while (flag) {\r
-                        flag = false;\r
-                        colLoop: for (j = k; j <= l; j++) {\r
-                            for (i = k; i <= l; i++) {\r
-                                if (i === j) {\r
-                                    continue;\r
-                                }\r
-                                if (ar[i * n + j] !== 0 || ai[i * n + j] !== 0.0) {\r
-                                    continue colLoop;\r
-                                }\r
-                            }\r
-                            m = k;\r
-                            scale[m] = j;\r
-                            if (j !== m) {\r
-                                for (i = 0; i <= l; i++) {\r
-                                    f = ar[i * n + j];\r
-                                    ar[i * n + j] = ar[i * n + m];\r
-                                    ar[i * n + m] = f;\r
-                                    f = ai[i * n + j];\r
-                                    ai[i * n + j] = ai[i * n + m];\r
-                                    ai[i * n + m] = f;\r
-                                }\r
-                                for (i = k; i < n; i++) {\r
-                                    f = ar[j * n + i];\r
-                                    ar[j * n + i] = ar[m * n + i];\r
-                                    ar[m * n + i] = f;\r
-                                    f = ai[j * n + i];\r
-                                    ai[j * n + i] = ai[m * n + i];\r
-                                    ai[m * n + i] = f;\r
-                                }\r
-                            }\r
-                            k++;\r
-                            flag = true;\r
-                            break;\r
-                        }\r
-                    }\r
-                    for (i = k; i <= l; i++) {\r
-                        scale[i] = 1.0;\r
-                    }\r
-                    do {\r
-                        flag = false;\r
-                        for (i = k; i <= l; i++) {\r
-                            c = 0.0;\r
-                            r = 0.0;\r
-                            for (j = k; j <= l; j++) {\r
-                                if (j !== i) {\r
-                                    c += Math.abs(ar[j * n + i]) + Math.abs(ai[j * n + i]);\r
-                                    r += Math.abs(ar[i * n + j]) + Math.abs(ai[i * n + j]);\r
-                                }\r
-                            }\r
-                            if (c === 0.0 || r === 0.0) {\r
-                                continue;\r
-                            }\r
-                            g = r / radix;\r
-                            f = 1.0;\r
-                            s = c + r;\r
-                            while (c < g) {\r
-                                f *= radix;\r
-                                c *= b2;\r
-                            }\r
-                            g = r * radix;\r
-                            while (c >= g) {\r
-                                f /= radix;\r
-                                c /= b2;\r
-                            }\r
-                            if ((c + r) / f >= 0.95 * s) {\r
-                                continue;\r
-                            }\r
-                            g = 1.0 / f;\r
-                            scale[i] *= f;\r
-                            flag = true;\r
-                            for (j = k; j < n; j++) {\r
-                                ar[i * n + j] *= g;\r
-                                ai[i * n + j] *= g;\r
-                            }\r
-                            for (j = 0; j <= l; j++) {\r
-                                ar[j * n + i] *= f;\r
-                                ai[j * n + i] *= f;\r
-                            }\r
-                        }\r
-                    } while (flag);\r
-                    return [k, l];\r
-                };\r
-                Eigen.corth = function (n, low, igh, ar, ai, ortr, orti) {\r
-                    var i, j, m, la, mp, kp1;\r
-                    var f, g, h, fi, fr, scale;\r
-                    la = igh - 1;\r
-                    kp1 = low + 1;\r
-                    if (la < kp1) {\r
-                        return;\r
-                    }\r
-                    for (m = kp1; m <= la; m++) {\r
-                        h = 0.0;\r
-                        ortr[m] = 0.0;\r
-                        orti[m] = 0.0;\r
-                        scale = 0.0;\r
-                        for (i = m; i <= igh; i++) {\r
-                            scale += Math.abs(ar[i * n + (m - 1)]) + Math.abs(ai[i * n + (m - 1)]);\r
-                        }\r
-                        if (scale === 0.0) {\r
-                            continue;\r
-                        }\r
-                        mp = m + igh;\r
-                        for (i = igh; i >= m; i--) {\r
-                            ortr[i] = ar[i * n + (m - 1)] / scale;\r
-                            orti[i] = ai[i * n + (m - 1)] / scale;\r
-                            h += ortr[i] * ortr[i] + orti[i] * orti[i];\r
-                        }\r
-                        g = Math.sqrt(h);\r
-                        f = cmath_6.CMath.length2(ortr[m], orti[m]);\r
-                        if (f !== 0.0) {\r
-                            h += f * g;\r
-                            g /= f;\r
-                            ortr[m] *= 1.0 + g;\r
-                            orti[m] *= 1.0 + g;\r
-                        }\r
-                        else {\r
-                            ortr[m] = g;\r
-                            ar[m * n + (m - 1)] = scale;\r
-                        }\r
-                        for (j = m; j < n; j++) {\r
-                            fr = 0.0;\r
-                            fi = 0.0;\r
-                            for (i = igh; i >= m; i--) {\r
-                                fr += ortr[i] * ar[i * n + j] + orti[i] * ai[i * n + j];\r
-                                fi += ortr[i] * ai[i * n + j] - orti[i] * ar[i * n + j];\r
-                            }\r
-                            fr /= h;\r
-                            fi /= h;\r
-                            for (i = m; i <= igh; i++) {\r
-                                ar[i * n + j] += -fr * ortr[i] + fi * orti[i];\r
-                                ai[i * n + j] += -fr * orti[i] - fi * ortr[i];\r
-                            }\r
-                        }\r
-                        for (i = 0; i <= igh; i++) {\r
-                            fr = 0.0;\r
-                            fi = 0.0;\r
-                            for (j = igh; j >= m; j--) {\r
-                                fr += ortr[j] * ar[i * n + j] - orti[j] * ai[i * n + j];\r
-                                fi += ortr[j] * ai[i * n + j] + orti[j] * ar[i * n + j];\r
-                            }\r
-                            fr /= h;\r
-                            fi /= h;\r
-                            for (j = m; j <= igh; j++) {\r
-                                ar[i * n + j] += -fr * ortr[j] - fi * orti[j];\r
-                                ai[i * n + j] += fr * orti[j] - fi * ortr[j];\r
-                            }\r
-                        }\r
-                        ortr[m] *= scale;\r
-                        orti[m] *= scale;\r
-                        ar[m * n + (m - 1)] *= -g;\r
-                        ai[m * n + (m - 1)] *= -g;\r
-                    }\r
-                };\r
-                Eigen.comqr = function (n, low, igh, hr, hi, wr, wi) {\r
-                    var i, j, l, ll, en;\r
-                    var itn, its = 0, lp1, enm1 = 0;\r
-                    var si, sr, ti, tr, xi, xr;\r
-                    var yi, yr, zzi, zzr, norm;\r
-                    var tst1, tst2;\r
-                    var skip = false;\r
-                    if (low !== igh) {\r
-                        l = low + 1;\r
-                        for (i = l; i <= igh; i++) {\r
-                            ll = Math.min(i + 1, igh);\r
-                            if (hi[i * n + (i - 1)] === 0.0) {\r
-                                continue;\r
-                            }\r
-                            norm = cmath_6.CMath.length2(hr[i * n + (i - 1)], hi[i * n + (i - 1)]);\r
-                            yr = hr[i * n + (i - 1)] / norm;\r
-                            yi = hi[i * n + (i - 1)] / norm;\r
-                            hr[i * n + (i - 1)] = norm;\r
-                            hi[i * n + (i - 1)] = 0.0;\r
-                            for (j = i; j < n; j++) {\r
-                                si = yr * hi[i * n + j] - yi * hr[i * n + j];\r
-                                hr[i * n + j] = yr * hr[i * n + j] + yi * hi[i * n + j];\r
-                                hi[i * n + j] = si;\r
-                            }\r
-                            for (j = 0; j <= ll; j++) {\r
-                                si = yr * hi[j * n + i] + yi * hr[j * n + i];\r
-                                hr[j * n + i] = yr * hr[j * n + i] - yi * hi[j * n + i];\r
-                                hi[j * n + i] = si;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        if (i >= low && i <= igh) {\r
-                            continue;\r
-                        }\r
-                        wr[i] = hr[i * n + i];\r
-                        wi[i] = hi[i * n + i];\r
-                    }\r
-                    en = igh;\r
-                    tr = 0.0;\r
-                    ti = 0.0;\r
-                    itn = 30 * n;\r
-                    while (true) {\r
-                        if (!skip) {\r
-                            if (en < low) {\r
-                                break;\r
-                            }\r
-                            its = 0;\r
-                            enm1 = en - 1;\r
-                        }\r
-                        for (l = en; l > low; l--) {\r
-                            tst1 = Math.abs(hr[(l - 1) * n + (l - 1)]) + Math.abs(hi[(l - 1) * n + (l - 1)])\r
-                                + Math.abs(hr[l * n + l]) + Math.abs(hi[l * n + l]);\r
-                            tst2 = tst1 + Math.abs(hr[l * n + (l - 1)]);\r
-                            if (tst2 === tst1) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        if (l === en) {\r
-                            wr[en] = hr[en * n + en] + tr;\r
-                            wi[en] = hi[en * n + en] + ti;\r
-                            en = enm1;\r
-                            skip = false;\r
-                        }\r
-                        else {\r
-                            if (itn === 0) {\r
-                                throw new Error('Maximum allowed iterations reached.');\r
-                            }\r
-                            if (its === 10 || its === 20) {\r
-                                sr = Math.abs(hr[en * n + enm1]) + Math.abs(hr[enm1 * n + (en - 2)]);\r
-                                si = 0.0;\r
-                            }\r
-                            else {\r
-                                sr = hr[en * n + en];\r
-                                si = hi[en * n + en];\r
-                                xr = hr[enm1 * n + en] * hr[en * n + enm1];\r
-                                xi = hi[enm1 * n + en] * hr[en * n + enm1];\r
-                                if (xr !== 0.0 || xi !== 0.0) {\r
-                                    yr = (hr[enm1 * n + enm1] - sr) / 2.0;\r
-                                    yi = (hi[enm1 * n + enm1] - si) / 2.0;\r
-                                    _a = cmath_6.CMath.csqrt((yr + yi) * (yr - yi) + xr, 2.0 * yr * yi + xi), zzr = _a[0], zzi = _a[1];\r
-                                    if (yr * zzr + yi * zzi < 0.0) {\r
-                                        zzr = -zzr;\r
-                                        zzi = -zzi;\r
-                                    }\r
-                                    _b = cmath_6.CMath.cdivCC(xr, xi, yr + zzr, yi + zzi), xr = _b[0], xi = _b[1];\r
-                                    sr -= xr;\r
-                                    si -= xi;\r
-                                }\r
-                            }\r
-                            for (i = low; i <= en; i++) {\r
-                                hr[i * n + i] -= sr;\r
-                                hi[i * n + i] -= si;\r
-                            }\r
-                            tr += sr;\r
-                            ti += si;\r
-                            its++;\r
-                            itn--;\r
-                            lp1 = l + 1;\r
-                            for (i = lp1; i <= en; i++) {\r
-                                sr = hr[i * n + (i - 1)];\r
-                                hr[i * n + (i - 1)] = 0.0;\r
-                                norm = cmath_6.CMath.length2(cmath_6.CMath.length2(hr[(i - 1) * n + (i - 1)], hi[(i - 1) * n + (i - 1)]), sr);\r
-                                xr = hr[(i - 1) * n + (i - 1)] / norm;\r
-                                wr[i - 1] = xr;\r
-                                xi = hi[(i - 1) * n + (i - 1)] / norm;\r
-                                wi[i - 1] = xi;\r
-                                hr[(i - 1) * n + (i - 1)] = norm;\r
-                                hi[(i - 1) * n + (i - 1)] = 0.0;\r
-                                hi[i * n + (i - 1)] = sr / norm;\r
-                                for (j = i; j <= en; j++) {\r
-                                    yr = hr[(i - 1) * n + j];\r
-                                    yi = hi[(i - 1) * n + j];\r
-                                    zzr = hr[i * n + j];\r
-                                    zzi = hi[i * n + j];\r
-                                    hr[(i - 1) * n + j] = xr * yr + xi * yi + hi[i * n + (i - 1)] * zzr;\r
-                                    hi[(i - 1) * n + j] = xr * yi - xi * yr + hi[i * n + (i - 1)] * zzi;\r
-                                    hr[i * n + j] = xr * zzr - xi * zzi - hi[i * n + (i - 1)] * yr;\r
-                                    hi[i * n + j] = xr * zzi + xi * zzr - hi[i * n + (i - 1)] * yi;\r
-                                }\r
-                            }\r
-                            si = hi[en * n + en];\r
-                            if (si !== 0.0) {\r
-                                norm = cmath_6.CMath.length2(hr[en * n + en], si);\r
-                                sr = hr[en * n + en] / norm;\r
-                                si /= norm;\r
-                                hr[en * n + en] = norm;\r
-                                hi[en * n + en] = 0.0;\r
-                            }\r
-                            for (j = lp1; j <= en; j++) {\r
-                                xr = wr[j - 1];\r
-                                xi = wi[j - 1];\r
-                                for (i = 0; i <= j; i++) {\r
-                                    yr = hr[i * n + (j - 1)];\r
-                                    yi = 0.0;\r
-                                    zzr = hr[i * n + j];\r
-                                    zzi = hi[i * n + j];\r
-                                    if (i !== j) {\r
-                                        yi = hi[i * n + (j - 1)];\r
-                                        hi[i * n + (j - 1)] = xr * yi + xi * yr + hi[j * n + (j - 1)] * zzi;\r
-                                    }\r
-                                    hr[i * n + (j - 1)] = xr * yr - xi * yi + hi[j * n + (j - 1)] * zzr;\r
-                                    hr[i * n + j] = xr * zzr + xi * zzi - hi[j * n + (j - 1)] * yr;\r
-                                    hi[i * n + j] = xr * zzi - xi * zzr - hi[j * n + (j - 1)] * yi;\r
-                                }\r
-                            }\r
-                            if (si === 0.0) {\r
-                                skip = true;\r
-                                continue;\r
-                            }\r
-                            for (i = l; i <= en; i++) {\r
-                                yr = hr[i * n + en];\r
-                                yi = hi[i * n + en];\r
-                                hr[i * n + en] = sr * yr - si * yi;\r
-                                hi[i * n + en] = sr * yi + si * yr;\r
-                            }\r
-                            skip = true;\r
-                        }\r
-                    }\r
-                    var _a, _b;\r
-                };\r
-                Eigen.comqr2 = function (n, low, igh, ortr, orti, hr, hi, wr, wi, zr, zi) {\r
-                    var i, j, k, l, ll, m, en;\r
-                    var ip1, itn, its = 0, lp1, enm1 = 0, iend;\r
-                    var si, sr, ti, tr, xi, xr;\r
-                    var yi, yr, zzi, zzr, norm;\r
-                    var tst1, tst2;\r
-                    var skip = false;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = 0; j < n; j++) {\r
-                            zr[i * n + j] = 0.0;\r
-                            zi[i * n + j] = 0.0;\r
-                        }\r
-                        zr[i * n + i] = 1.0;\r
-                    }\r
-                    iend = igh - low - 1;\r
-                    if (iend > 0) {\r
-                        for (i = igh - 1; i >= low + 1; i--) {\r
-                            if (ortr[i] === 0.0 && orti[i] === 0.0) {\r
-                                continue;\r
-                            }\r
-                            if (hr[i * n + (i - 1)] === 0.0 && hi[i * n + (i - 1)] === 0.0) {\r
-                                continue;\r
-                            }\r
-                            norm = hr[i * n + (i - 1)] * ortr[i] + hi[i * n + (i - 1)] * orti[i];\r
-                            ip1 = i + 1;\r
-                            for (k = ip1; k <= igh; k++) {\r
-                                ortr[k] = hr[k * n + (i - 1)];\r
-                                orti[k] = hi[k * n + (i - 1)];\r
-                            }\r
-                            for (j = i; j <= igh; j++) {\r
-                                sr = 0.0;\r
-                                si = 0.0;\r
-                                for (k = i; k <= igh; k++) {\r
-                                    sr += ortr[k] * zr[k * n + j] + orti[k] * zi[k * n + j];\r
-                                    si += ortr[k] * zi[k * n + j] - orti[k] * zr[k * n + j];\r
-                                }\r
-                                sr /= norm;\r
-                                si /= norm;\r
-                                for (k = i; k <= igh; k++) {\r
-                                    zr[k * n + j] += sr * ortr[k] - si * orti[k];\r
-                                    zi[k * n + j] += sr * orti[k] + si * ortr[k];\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    if (iend >= 0) {\r
-                        l = low + 1;\r
-                        for (i = l; i <= igh; i++) {\r
-                            ll = Math.min(i + 1, igh);\r
-                            if (hi[i * n + (i - 1)] === 0.0) {\r
-                                continue;\r
-                            }\r
-                            norm = cmath_6.CMath.length2(hr[i * n + (i - 1)], hi[i * n + (i - 1)]);\r
-                            yr = hr[i * n + (i - 1)] / norm;\r
-                            yi = hi[i * n + (i - 1)] / norm;\r
-                            hr[i * n + (i - 1)] = norm;\r
-                            hi[i * n + (i - 1)] = 0.0;\r
-                            for (j = i; j < n; j++) {\r
-                                si = yr * hi[i * n + j] - yi * hr[i * n + j];\r
-                                hr[i * n + j] = yr * hr[i * n + j] + yi * hi[i * n + j];\r
-                                hi[i * n + j] = si;\r
-                            }\r
-                            for (j = 0; j <= ll; j++) {\r
-                                si = yr * hi[j * n + i] + yi * hr[j * n + i];\r
-                                hr[j * n + i] = yr * hr[j * n + i] - yi * hi[j * n + i];\r
-                                hi[j * n + i] = si;\r
-                            }\r
-                            for (j = low; j <= igh; j++) {\r
-                                si = yr * zi[j * n + i] + yi * zr[j * n + i];\r
-                                zr[j * n + i] = yr * zr[j * n + i] - yi * zi[j * n + i];\r
-                                zi[j * n + i] = si;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        if (i >= low && i <= igh) {\r
-                            continue;\r
-                        }\r
-                        wr[i] = hr[i * n + i];\r
-                        wi[i] = hi[i * n + i];\r
-                    }\r
-                    en = igh;\r
-                    tr = 0.0;\r
-                    ti = 0.0;\r
-                    itn = 30 * n;\r
-                    while (true) {\r
-                        if (!skip) {\r
-                            if (en < low) {\r
-                                break;\r
-                            }\r
-                            its = 0;\r
-                            enm1 = en - 1;\r
-                        }\r
-                        for (l = en; l > low; l--) {\r
-                            tst1 = Math.abs(hr[(l - 1) * n + (l - 1)]) + Math.abs(hi[(l - 1) * n + (l - 1)])\r
-                                + Math.abs(hr[l * n + l]) + Math.abs(hi[l * n + l]);\r
-                            tst2 = tst1 + Math.abs(hr[l * n + (l - 1)]);\r
-                            if (tst2 === tst1) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        if (l === en) {\r
-                            hr[en * n + en] += tr;\r
-                            wr[en] = hr[en * n + en];\r
-                            hi[en * n + en] += ti;\r
-                            wi[en] = hi[en * n + en];\r
-                            en = enm1;\r
-                            skip = false;\r
-                        }\r
-                        else {\r
-                            if (itn === 0) {\r
-                                throw new Error('Maximum allowed iterations reached.');\r
-                            }\r
-                            if (its === 10 || its === 20) {\r
-                                sr = Math.abs(hr[en * n + enm1]) + Math.abs(hr[enm1 * n + (en - 2)]);\r
-                                si = 0.0;\r
-                            }\r
-                            else {\r
-                                sr = hr[en * n + en];\r
-                                si = hi[en * n + en];\r
-                                xr = hr[enm1 * n + en] * hr[en * n + enm1];\r
-                                xi = hi[enm1 * n + en] * hr[en * n + enm1];\r
-                                if (xr !== 0.0 || xi !== 0.0) {\r
-                                    yr = (hr[enm1 * n + enm1] - sr) / 2.0;\r
-                                    yi = (hi[enm1 * n + enm1] - si) / 2.0;\r
-                                    _a = cmath_6.CMath.csqrt((yr + yi) * (yr - yi) + xr, 2.0 * yr * yi + xi), zzr = _a[0], zzi = _a[1];\r
-                                    if (yr * zzr + yi * zzi < 0.0) {\r
-                                        zzr = -zzr;\r
-                                        zzi = -zzi;\r
-                                    }\r
-                                    _b = cmath_6.CMath.cdivCC(xr, xi, yr + zzr, yi + zzi), xr = _b[0], xi = _b[1];\r
-                                    sr -= xr;\r
-                                    si -= xi;\r
-                                }\r
-                            }\r
-                            for (i = low; i <= en; i++) {\r
-                                hr[i * n + i] -= sr;\r
-                                hi[i * n + i] -= si;\r
-                            }\r
-                            tr += sr;\r
-                            ti += si;\r
-                            its++;\r
-                            itn--;\r
-                            lp1 = l + 1;\r
-                            for (i = lp1; i <= en; i++) {\r
-                                sr = hr[i * n + (i - 1)];\r
-                                hr[i * n + (i - 1)] = 0.0;\r
-                                norm = cmath_6.CMath.length2(cmath_6.CMath.length2(hr[(i - 1) * n + (i - 1)], hi[(i - 1) * n + (i - 1)]), sr);\r
-                                xr = hr[(i - 1) * n + (i - 1)] / norm;\r
-                                wr[i - 1] = xr;\r
-                                xi = hi[(i - 1) * n + (i - 1)] / norm;\r
-                                wi[i - 1] = xi;\r
-                                hr[(i - 1) * n + (i - 1)] = norm;\r
-                                hi[(i - 1) * n + (i - 1)] = 0.0;\r
-                                hi[i * n + (i - 1)] = sr / norm;\r
-                                for (j = i; j < n; j++) {\r
-                                    yr = hr[(i - 1) * n + j];\r
-                                    yi = hi[(i - 1) * n + j];\r
-                                    zzr = hr[i * n + j];\r
-                                    zzi = hi[i * n + j];\r
-                                    hr[(i - 1) * n + j] = xr * yr + xi * yi + hi[i * n + (i - 1)] * zzr;\r
-                                    hi[(i - 1) * n + j] = xr * yi - xi * yr + hi[i * n + (i - 1)] * zzi;\r
-                                    hr[i * n + j] = xr * zzr - xi * zzi - hi[i * n + (i - 1)] * yr;\r
-                                    hi[i * n + j] = xr * zzi + xi * zzr - hi[i * n + (i - 1)] * yi;\r
-                                }\r
-                            }\r
-                            si = hi[en * n + en];\r
-                            if (si !== 0.0) {\r
-                                norm = cmath_6.CMath.length2(hr[en * n + en], si);\r
-                                sr = hr[en * n + en] / norm;\r
-                                si /= norm;\r
-                                hr[en * n + en] = norm;\r
-                                hi[en * n + en] = 0.0;\r
-                                if (en < n - 1) {\r
-                                    ip1 = en + 1;\r
-                                    for (j = ip1; j < n; j++) {\r
-                                        yr = hr[en * n + j];\r
-                                        yi = hi[en * n + j];\r
-                                        hr[en * n + j] = sr * yr + si * yi;\r
-                                        hi[en * n + j] = sr * yi - si * yr;\r
-                                    }\r
-                                }\r
-                            }\r
-                            for (j = lp1; j <= en; j++) {\r
-                                xr = wr[j - 1];\r
-                                xi = wi[j - 1];\r
-                                for (i = 0; i <= j; i++) {\r
-                                    yr = hr[i * n + (j - 1)];\r
-                                    yi = 0.0;\r
-                                    zzr = hr[i * n + j];\r
-                                    zzi = hi[i * n + j];\r
-                                    if (i !== j) {\r
-                                        yi = hi[i * n + (j - 1)];\r
-                                        hi[i * n + (j - 1)] = xr * yi + xi * yr + hi[j * n + (j - 1)] * zzi;\r
-                                    }\r
-                                    hr[i * n + (j - 1)] = xr * yr - xi * yi + hi[j * n + (j - 1)] * zzr;\r
-                                    hr[i * n + j] = xr * zzr + xi * zzi - hi[j * n + (j - 1)] * yr;\r
-                                    hi[i * n + j] = xr * zzi - xi * zzr - hi[j * n + (j - 1)] * yi;\r
-                                }\r
-                                for (i = low; i <= igh; i++) {\r
-                                    yr = zr[i * n + (j - 1)];\r
-                                    yi = zi[i * n + (j - 1)];\r
-                                    zzr = zr[i * n + j];\r
-                                    zzi = zi[i * n + j];\r
-                                    zr[i * n + (j - 1)] = xr * yr - xi * yi + hi[j * n + (j - 1)] * zzr;\r
-                                    zi[i * n + (j - 1)] = xr * yi + xi * yr + hi[j * n + (j - 1)] * zzi;\r
-                                    zr[i * n + j] = xr * zzr + xi * zzi - hi[j * n + (j - 1)] * yr;\r
-                                    zi[i * n + j] = xr * zzi - xi * zzr - hi[j * n + (j - 1)] * yi;\r
-                                }\r
-                            }\r
-                            if (si === 0.0) {\r
-                                skip = true;\r
-                                continue;\r
-                            }\r
-                            for (i = 0; i <= en; i++) {\r
-                                yr = hr[i * n + en];\r
-                                yi = hi[i * n + en];\r
-                                hr[i * n + en] = sr * yr - si * yi;\r
-                                hi[i * n + en] = sr * yi + si * yr;\r
-                            }\r
-                            for (i = low; i <= igh; i++) {\r
-                                yr = zr[i * n + en];\r
-                                yi = zi[i * n + en];\r
-                                zr[i * n + en] = sr * yr - si * yi;\r
-                                zi[i * n + en] = sr * yi + si * yr;\r
-                            }\r
-                            skip = true;\r
-                        }\r
-                    }\r
-                    norm = 0.0;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = i; j < n; j++) {\r
-                            tr = Math.abs(hr[i * n + j]) + Math.abs(hi[i * n + j]);\r
-                            if (tr > norm) {\r
-                                norm = tr;\r
-                            }\r
-                        }\r
-                    }\r
-                    if (n === 1 || norm === 0.0) {\r
-                        return;\r
-                    }\r
-                    for (en = n - 1; en >= 1; en--) {\r
-                        xr = wr[en];\r
-                        xi = wi[en];\r
-                        hr[en * n + en] = 1.0;\r
-                        hi[en * n + en] = 0.0;\r
-                        enm1 = en - 1;\r
-                        for (i = en - 1; i >= 0; i--) {\r
-                            zzr = 0.0;\r
-                            zzi = 0.0;\r
-                            ip1 = i + 1;\r
-                            for (j = ip1; j <= en; j++) {\r
-                                zzr += hr[i * n + j] * hr[j * n + en] - hi[i * n + j] * hi[j * n + en];\r
-                                zzi += hr[i * n + j] * hi[j * n + en] + hi[i * n + j] * hr[j * n + en];\r
-                            }\r
-                            yr = xr - wr[i];\r
-                            yi = xi - wi[i];\r
-                            if (yr === 0.0 && yi === 0.0) {\r
-                                tst1 = norm;\r
-                                yr = tst1;\r
-                                do {\r
-                                    yr *= 0.01;\r
-                                    tst2 = norm + yr;\r
-                                } while (tst2 > tst1);\r
-                            }\r
-                            _c = cmath_6.CMath.cdivCC(zzr, zzi, yr, yi), hr[i * n + en] = _c[0], hi[i * n + en] = _c[1];\r
-                            tr = Math.abs(hr[i * n + en]) + Math.abs(hi[i * n + en]);\r
-                            if (tr === 0.0) {\r
-                                continue;\r
-                            }\r
-                            tst1 = tr;\r
-                            tst2 = tst1 + 1.0 / tst1;\r
-                            if (tst2 <= tst1) {\r
-                                for (j = i; j <= en; j++) {\r
-                                    hr[j * n + en] /= tr;\r
-                                    hi[j * n + en] /= tr;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        if (i >= low && i <= igh) {\r
-                            continue;\r
-                        }\r
-                        for (j = i; j < n; j++) {\r
-                            zr[i * n + j] = hr[i * n + j];\r
-                            zi[i * n + j] = hi[i * n + j];\r
-                        }\r
-                    }\r
-                    for (j = n - 1; j >= low; j--) {\r
-                        m = Math.min(j, igh);\r
-                        for (i = low; i <= igh; i++) {\r
-                            zzr = 0.0;\r
-                            zzi = 0.0;\r
-                            for (k = low; k <= m; k++) {\r
-                                zzr += zr[i * n + k] * hr[k * n + j] - zi[i * n + k] * hi[k * n + j];\r
-                                zzi += zr[i * n + k] * hi[k * n + j] + zi[i * n + k] * hr[k * n + j];\r
-                            }\r
-                            zr[i * n + j] = zzr;\r
-                            zi[i * n + j] = zzi;\r
-                        }\r
-                    }\r
-                    var _a, _b, _c;\r
-                };\r
-                Eigen.cbabk2 = function (n, low, igh, scale, m, zr, zi) {\r
-                    var i, j, k;\r
-                    var s;\r
-                    if (m === 0) {\r
-                        return;\r
-                    }\r
-                    if (igh !== low) {\r
-                        for (i = low; i <= igh; i++) {\r
-                            s = scale[i];\r
-                            for (j = 0; j < m; j++) {\r
-                                zr[i * n + j] *= s;\r
-                                zi[i * n + j] *= s;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = low - 1; i >= 0; i--) {\r
-                        k = scale[i];\r
-                        if (k !== i) {\r
-                            for (j = 0; j < m; j++) {\r
-                                s = zr[i * n + j];\r
-                                zr[i * n + j] = zr[k * n + j];\r
-                                zr[k * n + j] = s;\r
-                                s = zi[i * n + j];\r
-                                zi[i * n + j] = zi[k * n + j];\r
-                                zi[k * n + j] = s;\r
-                            }\r
-                        }\r
-                    }\r
-                    for (i = igh + 1; i < n; i++) {\r
-                        k = scale[i];\r
-                        if (k !== i) {\r
-                            for (j = 0; j < m; j++) {\r
-                                s = zr[i * n + j];\r
-                                zr[i * n + j] = zr[k * n + j];\r
-                                zr[k * n + j] = s;\r
-                                s = zi[i * n + j];\r
-                                zi[i * n + j] = zi[k * n + j];\r
-                                zi[k * n + j] = s;\r
-                            }\r
-                        }\r
-                    }\r
-                };\r
-                Eigen.cg = function (n, ar, ai, wr, wi, matz, zr, zi) {\r
-                    var scale = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var ortr = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var orti = dataHelper_10.DataHelper.allocateFloat64Array(n);\r
-                    var _a = Eigen.cbal(n, ar, ai, scale), low = _a[0], igh = _a[1];\r
-                    Eigen.corth(n, low, igh, ar, ai, ortr, orti);\r
-                    if (matz) {\r
-                        Eigen.comqr2(n, low, igh, ortr, orti, ar, ai, wr, wi, zr, zi);\r
-                        Eigen.cbabk2(n, low, igh, scale, n, zr, zi);\r
-                    }\r
-                    else {\r
-                        Eigen.comqr(n, low, igh, ar, ai, wr, wi);\r
-                    }\r
-                };\r
-                return Eigen;\r
-            }());\r
-            exports_49("Eigen", Eigen);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/decomp/chol", [], function (exports_50, context_50) {\r
-    "use strict";\r
-    var __moduleName = context_50 && context_50.id;\r
-    var Cholesky;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            Cholesky = (function () {\r
-                function Cholesky() {\r
-                }\r
-                Cholesky.chol = function (n, a) {\r
-                    var i, j, k;\r
-                    var acc;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = 0; j <= i; j++) {\r
-                            acc = a[i * n + j];\r
-                            for (k = 0; k < j; k++) {\r
-                                acc -= a[i * n + k] * a[j * n + k];\r
-                            }\r
-                            if (i === j) {\r
-                                if (acc <= 0.0) {\r
-                                    return n - i - 1;\r
-                                }\r
-                                a[i * n + i] = Math.sqrt(acc);\r
-                            }\r
-                            else {\r
-                                a[i * n + j] = acc / a[j * n + j];\r
-                            }\r
-                        }\r
-                    }\r
-                    return 0;\r
-                };\r
-                Cholesky.cchol = function (n, reA, imA) {\r
-                    var i, j, k;\r
-                    var accRe, accIm;\r
-                    for (i = 0; i < n; i++) {\r
-                        for (j = 0; j <= i; j++) {\r
-                            accRe = reA[i * n + j];\r
-                            accIm = imA[i * n + j];\r
-                            if (i === j) {\r
-                                if (accIm !== 0) {\r
-                                    return i + 1;\r
-                                }\r
-                                for (k = 0; k < j; k++) {\r
-                                    accRe -= reA[j * n + k] * reA[j * n + k] + imA[j * n + k] * imA[j * n + k];\r
-                                }\r
-                                if (accRe <= 0.0) {\r
-                                    return i + 1;\r
-                                }\r
-                                reA[i * n + i] = Math.sqrt(accRe);\r
-                                imA[i * n + i] = 0.0;\r
-                            }\r
-                            else {\r
-                                for (k = 0; k < j; k++) {\r
-                                    accRe -= reA[i * n + k] * reA[j * n + k] + imA[i * n + k] * imA[j * n + k];\r
-                                    accIm -= -reA[i * n + k] * imA[j * n + k] + imA[i * n + k] * reA[j * n + k];\r
-                                }\r
-                                reA[i * n + j] = accRe / reA[j * n + j];\r
-                                imA[i * n + j] = accIm / reA[j * n + j];\r
-                            }\r
-                        }\r
-                    }\r
-                    return 0;\r
-                };\r
-                return Cholesky;\r
-            }());\r
-            exports_50("Cholesky", Cholesky);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/decomp/qr", ["jasmal/lib/constant", "jasmal/lib/math/cmath", "jasmal/lib/helper/dataHelper"], function (exports_51, context_51) {\r
-    "use strict";\r
-    var __moduleName = context_51 && context_51.id;\r
-    var constant_5, cmath_7, dataHelper_11, QR;\r
-    return {\r
-        setters: [\r
-            function (constant_5_1) {\r
-                constant_5 = constant_5_1;\r
-            },\r
-            function (cmath_7_1) {\r
-                cmath_7 = cmath_7_1;\r
-            },\r
-            function (dataHelper_11_1) {\r
-                dataHelper_11 = dataHelper_11_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            QR = (function () {\r
-                function QR() {\r
-                }\r
-                QR.qrp = function (m, n, a, d, ind) {\r
-                    var i, j, k, r, l;\r
-                    var s, t, f, g, h;\r
-                    var tau = 0;\r
-                    l = Math.min(m, n);\r
-                    var c = dataHelper_11.DataHelper.allocateFloat64Array(n);\r
-                    for (i = 0; i < l; i++) {\r
-                        d[i] = 0;\r
-                    }\r
-                    k = 0;\r
-                    for (j = 0; j < n; j++) {\r
-                        s = 0;\r
-                        for (i = 0; i < m; i++) {\r
-                            s += a[i * n + j] * a[i * n + j];\r
-                        }\r
-                        c[j] = s;\r
-                        if (s > tau) {\r
-                            tau = s;\r
-                            k = j;\r
-                        }\r
-                    }\r
-                    r = 0;\r
-                    while (tau > 0 && r < l) {\r
-                        if (k !== r) {\r
-                            for (var i_3 = 0; i_3 < m; i_3++) {\r
-                                t = a[i_3 * n + r];\r
-                                a[i_3 * n + r] = a[i_3 * n + k];\r
-                                a[i_3 * n + k] = t;\r
-                            }\r
-                            ind[r] = k;\r
-                            t = c[r];\r
-                            c[r] = c[k];\r
-                            c[k] = t;\r
-                        }\r
-                        else {\r
-                            ind[r] = r;\r
-                        }\r
-                        s = 0.0;\r
-                        for (i = r; i < m; i++) {\r
-                            s += a[i * n + r] * a[i * n + r];\r
-                        }\r
-                        if (s) {\r
-                            f = a[r * n + r];\r
-                            g = f >= 0 ? -Math.sqrt(s) : Math.sqrt(s);\r
-                            h = f * g - s;\r
-                            a[r * n + r] = f - g;\r
-                            for (j = r + 1; j < n; j++) {\r
-                                s = 0.0;\r
-                                for (k = r; k < m; k++) {\r
-                                    s += a[k * n + r] * a[k * n + j];\r
-                                }\r
-                                f = s / h;\r
-                                for (k = r; k < m; k++) {\r
-                                    a[k * n + j] += f * a[k * n + r];\r
-                                }\r
-                            }\r
-                            d[r] = g;\r
-                        }\r
-                        else {\r
-                            d[r] = 0.0;\r
-                        }\r
-                        for (j = r + 1; j < n; j++) {\r
-                            c[j] -= a[r * n + j] * a[r * n + j];\r
-                        }\r
-                        tau = 0.0;\r
-                        for (j = r + 1; j < n; j++) {\r
-                            if (c[j] > tau) {\r
-                                tau = c[j];\r
-                                k = j;\r
-                            }\r
-                        }\r
-                        r++;\r
-                    }\r
-                    for (; r < n; r++) {\r
-                        ind[r] = r;\r
-                    }\r
-                };\r
-                QR.qrtrans = function (m, n, a, d, q) {\r
-                    var i, j, k;\r
-                    var g, h, s;\r
-                    for (i = 0; i < m; i++) {\r
-                        q[i * m + i] = 1.0;\r
-                    }\r
-                    for (i = Math.min(m, n) - 1; i >= 0; i--) {\r
-                        g = d[i];\r
-                        if (g) {\r
-                            h = -1.0 / g / a[i * n + i];\r
-                            for (j = i; j < m; j++) {\r
-                                s = 0.0;\r
-                                for (k = i; k < m; k++) {\r
-                                    s += a[k * n + i] * q[k * m + j];\r
-                                }\r
-                                s *= h;\r
-                                for (k = i; k < m; k++) {\r
-                                    q[k * m + j] -= a[k * n + i] * s;\r
-                                }\r
-                            }\r
-                        }\r
-                        a[i * n + i] = g;\r
-                        for (k = i + 1; k < m; k++) {\r
-                            a[k * n + i] = 0.0;\r
-                        }\r
-                    }\r
-                };\r
-                QR.ind2p = function (n, ind, p) {\r
-                    var i, t;\r
-                    var perm = dataHelper_11.DataHelper.naturalNumbersAsInt32(n);\r
-                    for (i = 0; i < n; i++) {\r
-                        perm[i] = i;\r
-                    }\r
-                    for (i = 0; i < n; i++) {\r
-                        if (ind[i] !== i) {\r
-                            t = perm[i];\r
-                            perm[i] = perm[ind[i]];\r
-                            perm[ind[i]] = t;\r
-                        }\r
-                    }\r
-                    for (var i_4 = 0; i_4 < n; i_4++) {\r
-                        p[perm[i_4] * n + i_4] = 1.0;\r
-                    }\r
-                };\r
-                QR.qrpf = function (m, n, a, q, p) {\r
-                    var d = dataHelper_11.DataHelper.allocateFloat64Array(Math.min(m, n));\r
-                    var ind = dataHelper_11.DataHelper.allocateInt32Array(n);\r
-                    QR.qrp(m, n, a, d, ind);\r
-                    QR.qrtrans(m, n, a, d, q);\r
-                    QR.ind2p(n, ind, p);\r
-                };\r
-                QR.qrpsol = function (m, n, p, a, d, ind, b, x) {\r
-                    var i, j, k, l;\r
-                    var g, h, r, s, t;\r
-                    var tol;\r
-                    l = Math.min(m, n);\r
-                    tol = Math.abs(d[0]) * constant_5.EPSILON;\r
-                    if (tol === 0) {\r
-                        return 0;\r
-                    }\r
-                    r = l;\r
-                    for (i = 1; i < l; i++) {\r
-                        if (Math.abs(d[i]) < tol) {\r
-                            r = i;\r
-                            break;\r
-                        }\r
-                    }\r
-                    for (i = 0; i < l; i++) {\r
-                        g = d[i];\r
-                        if (g) {\r
-                            h = -1.0 / g / a[i * n + i];\r
-                            for (j = 0; j < p; j++) {\r
-                                s = 0.0;\r
-                                for (k = i; k < m; k++) {\r
-                                    s += a[k * n + i] * b[k * p + j];\r
-                                }\r
-                                s *= h;\r
-                                for (k = i; k < m; k++) {\r
-                                    b[k * p + j] -= a[k * n + i] * s;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    for (j = 0; j < p; j++) {\r
-                        for (i = r - 1; i >= 0; i--) {\r
-                            s = b[i * p + j];\r
-                            for (k = i + 1; k < r; k++) {\r
-                                s -= a[i * n + k] * x[k * p + j];\r
-                            }\r
-                            x[i * p + j] = s / d[i];\r
-                        }\r
-                    }\r
-                    var ind2 = dataHelper_11.DataHelper.naturalNumbersAsInt32(n);\r
-                    for (i = 0; i < n; i++) {\r
-                        if (ind[i] !== i) {\r
-                            for (j = 0; j < p; j++) {\r
-                                t = x[ind2[i] * p + j];\r
-                                x[ind2[i] * p + j] = x[ind2[ind[i]] * p + j];\r
-                                x[ind2[ind[i]] * p + j] = t;\r
-                            }\r
-                            t = ind2[i];\r
-                            ind2[i] = ind2[ind[i]];\r
-                            ind2[ind[i]] = t;\r
-                        }\r
-                    }\r
-                    return r;\r
-                };\r
-                QR.cqrp = function (m, n, ar, ai, d, phr, phi, ind) {\r
-                    var i, j, k, r, l;\r
-                    var s, si, sr, t, f, g, h;\r
-                    var tau = 0;\r
-                    l = Math.min(m, n);\r
-                    var c = dataHelper_11.DataHelper.allocateFloat64Array(n);\r
-                    for (i = 0; i < l; i++) {\r
-                        d[i] = 0;\r
-                        phr[i] = 1.0;\r
-                        phi[i] = 0.0;\r
-                    }\r
-                    k = 0;\r
-                    for (j = 0; j < n; j++) {\r
-                        s = 0;\r
-                        for (i = 0; i < m; i++) {\r
-                            s += ar[i * n + j] * ar[i * n + j] + ai[i * n + j] * ai[i * n + j];\r
-                        }\r
-                        c[j] = s;\r
-                        if (s > tau) {\r
-                            tau = s;\r
-                            k = j;\r
-                        }\r
-                    }\r
-                    r = 0;\r
-                    while (tau > 0 && r < l) {\r
-                        if (k !== r) {\r
-                            for (var i_5 = 0; i_5 < m; i_5++) {\r
-                                t = ar[i_5 * n + r];\r
-                                ar[i_5 * n + r] = ar[i_5 * n + k];\r
-                                ar[i_5 * n + k] = t;\r
-                                t = ai[i_5 * n + r];\r
-                                ai[i_5 * n + r] = ai[i_5 * n + k];\r
-                                ai[i_5 * n + k] = t;\r
-                            }\r
-                            ind[r] = k;\r
-                            t = c[r];\r
-                            c[r] = c[k];\r
-                            c[k] = t;\r
-                        }\r
-                        else {\r
-                            ind[r] = r;\r
-                        }\r
-                        s = 0.0;\r
-                        for (i = r; i < m; i++) {\r
-                            s += ar[i * n + r] * ar[i * n + r] + ai[i * n + r] * ai[i * n + r];\r
-                        }\r
-                        if (s) {\r
-                            f = cmath_7.CMath.length2(ar[r * n + r], ai[r * n + r]);\r
-                            g = Math.sqrt(s);\r
-                            h = -f * g - s;\r
-                            if (f) {\r
-                                phr[r] = ar[r * n + r] / f;\r
-                                phi[r] = ai[r * n + r] / f;\r
-                                ar[r * n + r] += phr[r] * g;\r
-                                ai[r * n + r] += phi[r] * g;\r
-                            }\r
-                            else {\r
-                                phr[r] = 1.0;\r
-                                phi[r] = 0.0;\r
-                                ar[r * n + r] = g;\r
-                                ai[i * n + r] = 0.0;\r
-                            }\r
-                            for (j = r + 1; j < n; j++) {\r
-                                sr = 0.0;\r
-                                si = 0.0;\r
-                                for (k = r; k < m; k++) {\r
-                                    sr += ar[k * n + r] * ar[k * n + j] + ai[k * n + r] * ai[k * n + j];\r
-                                    si += ar[k * n + r] * ai[k * n + j] - ai[k * n + r] * ar[k * n + j];\r
-                                }\r
-                                sr /= h;\r
-                                si /= h;\r
-                                for (k = r; k < m; k++) {\r
-                                    ar[k * n + j] += sr * ar[k * n + r] - si * ai[k * n + r];\r
-                                    ai[k * n + j] += sr * ai[k * n + r] + si * ar[k * n + r];\r
-                                }\r
-                            }\r
-                            d[r] = g;\r
-                        }\r
-                        else {\r
-                            d[r] = 0.0;\r
-                        }\r
-                        for (j = r + 1; j < n; j++) {\r
-                            c[j] -= ar[r * n + j] * ar[r * n + j] + ai[r * n + j] * ai[r * n + j];\r
-                        }\r
-                        tau = 0.0;\r
-                        for (j = r + 1; j < n; j++) {\r
-                            if (c[j] > tau) {\r
-                                tau = c[j];\r
-                                k = j;\r
-                            }\r
-                        }\r
-                        r++;\r
-                    }\r
-                    for (; r < n; r++) {\r
-                        ind[r] = r;\r
-                    }\r
-                };\r
-                QR.cqrtrans = function (m, n, ar, ai, d, phr, phi, qr, qi) {\r
-                    var i, j, k;\r
-                    var g, h, si, sr;\r
-                    for (i = 0; i < m; i++) {\r
-                        qr[i * m + i] = 1.0;\r
-                    }\r
-                    for (i = Math.min(m, n) - 1; i >= 0; i--) {\r
-                        g = d[i];\r
-                        if (g) {\r
-                            h = -1.0 / g / cmath_7.CMath.length2(ar[i * n + i], ai[i * n + i]);\r
-                            for (j = i; j < m; j++) {\r
-                                sr = 0.0;\r
-                                si = 0.0;\r
-                                for (k = i; k < m; k++) {\r
-                                    sr += ar[k * n + i] * qr[k * m + j] + ai[k * n + i] * qi[k * m + j];\r
-                                    si += ar[k * n + i] * qi[k * m + j] - ai[k * n + i] * qr[k * m + j];\r
-                                }\r
-                                sr *= h;\r
-                                si *= h;\r
-                                for (k = i; k < m; k++) {\r
-                                    qr[k * m + j] += sr * ar[k * n + i] - si * ai[k * n + i];\r
-                                    qi[k * m + j] += sr * ai[k * n + i] + si * ar[k * n + i];\r
-                                }\r
-                            }\r
-                        }\r
-                        ar[i * n + i] = -g * phr[i];\r
-                        ai[i * n + i] = -g * phi[i];\r
-                        for (k = i + 1; k < m; k++) {\r
-                            ar[k * n + i] = 0.0;\r
-                            ai[k * n + i] = 0.0;\r
-                        }\r
-                    }\r
-                };\r
-                QR.cqrpf = function (m, n, ar, ai, qr, qi, p) {\r
-                    var l = Math.min(m, n);\r
-                    var d = dataHelper_11.DataHelper.allocateFloat64Array(l);\r
-                    var phr = dataHelper_11.DataHelper.allocateFloat64Array(l);\r
-                    var phi = dataHelper_11.DataHelper.allocateFloat64Array(l);\r
-                    var ind = dataHelper_11.DataHelper.allocateInt32Array(n);\r
-                    QR.cqrp(m, n, ar, ai, d, phr, phi, ind);\r
-                    QR.cqrtrans(m, n, ar, ai, d, phr, phi, qr, qi);\r
-                    QR.ind2p(n, ind, p);\r
-                };\r
-                QR.cqrpsol = function (m, n, p, ar, ai, d, ind, phr, phi, br, bi, xr, xi) {\r
-                    var i, j, k, l;\r
-                    var g, h, r, si, sr, t;\r
-                    var tol;\r
-                    l = Math.min(m, n);\r
-                    tol = Math.abs(d[0]) * constant_5.EPSILON;\r
-                    if (tol === 0) {\r
-                        return 0;\r
-                    }\r
-                    r = l;\r
-                    for (i = 1; i < l; i++) {\r
-                        if (Math.abs(d[i]) < tol) {\r
-                            r = i;\r
-                            break;\r
-                        }\r
-                    }\r
-                    for (i = 0; i < l; i++) {\r
-                        g = d[i];\r
-                        if (g) {\r
-                            h = -1.0 / g / cmath_7.CMath.length2(ar[i * n + i], ai[i * n + i]);\r
-                            for (j = 0; j < p; j++) {\r
-                                sr = 0.0;\r
-                                si = 0.0;\r
-                                for (k = i; k < m; k++) {\r
-                                    sr += ar[k * n + i] * br[k * p + j] + ai[k * n + i] * bi[k * p + j];\r
-                                    si += ar[k * n + i] * bi[k * p + j] - ai[k * n + i] * br[k * p + j];\r
-                                }\r
-                                sr *= h;\r
-                                si *= h;\r
-                                for (k = i; k < m; k++) {\r
-                                    br[k * p + j] += ar[k * n + i] * sr - ai[k * n + i] * si;\r
-                                    bi[k * p + j] += ar[k * n + i] * si + ai[k * n + i] * sr;\r
-                                }\r
-                            }\r
-                        }\r
-                    }\r
-                    for (j = 0; j < p; j++) {\r
-                        for (i = r - 1; i >= 0; i--) {\r
-                            sr = br[i * p + j];\r
-                            si = bi[i * p + j];\r
-                            for (k = i + 1; k < r; k++) {\r
-                                sr -= ar[i * n + k] * xr[k * p + j] - ai[i * n + k] * xi[k * p + j];\r
-                                si -= ar[i * n + k] * xi[k * p + j] + ai[i * n + k] * xr[k * p + j];\r
-                            }\r
-                            _a = cmath_7.CMath.cdivCC(sr, si, -d[i] * phr[i], -d[i] * phi[i]), xr[i * p + j] = _a[0], xi[i * p + j] = _a[1];\r
-                        }\r
-                    }\r
-                    var ind2 = dataHelper_11.DataHelper.naturalNumbersAsInt32(n);\r
-                    for (i = 0; i < n; i++) {\r
-                        if (ind[i] !== i) {\r
-                            for (j = 0; j < p; j++) {\r
-                                t = xr[ind2[i] * p + j];\r
-                                xr[ind2[i] * p + j] = xr[ind2[ind[i]] * p + j];\r
-                                xr[ind2[ind[i]] * p + j] = t;\r
-                                t = xi[ind2[i] * p + j];\r
-                                xi[ind2[i] * p + j] = xi[ind2[ind[i]] * p + j];\r
-                                xi[ind2[ind[i]] * p + j] = t;\r
-                            }\r
-                            t = ind2[i];\r
-                            ind2[i] = ind2[ind[i]];\r
-                            ind2[ind[i]] = t;\r
-                        }\r
-                    }\r
-                    return r;\r
-                    var _a;\r
-                };\r
-                return QR;\r
-            }());\r
-            exports_51("QR", QR);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/norm", ["jasmal/lib/math/cmath"], function (exports_52, context_52) {\r
-    "use strict";\r
-    var __moduleName = context_52 && context_52.id;\r
-    var cmath_8, NormFunction;\r
-    return {\r
-        setters: [\r
-            function (cmath_8_1) {\r
-                cmath_8 = cmath_8_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            NormFunction = (function () {\r
-                function NormFunction() {\r
-                }\r
-                NormFunction.vec0Norm = function (reX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        if (reX[i] !== 0) {\r
-                            norm++;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.cvec0Norm = function (reX, imX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i]) || isNaN(imX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        if (reX[i] !== 0 || imX[i] !== 0) {\r
-                            norm++;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.vec2Norm = function (reX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        norm += reX[i] * reX[i];\r
-                    }\r
-                    return Math.sqrt(norm);\r
-                };\r
-                NormFunction.cvec2Norm = function (reX, imX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i]) || isNaN(imX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        norm += reX[i] * reX[i] + imX[i] * imX[i];\r
-                    }\r
-                    return Math.sqrt(norm);\r
-                };\r
-                NormFunction.vecInfNorm = function (reX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        var v = Math.abs(reX[i]);\r
-                        if (v > norm) {\r
-                            norm = v;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.cvecInfNorm = function (reX, imX) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i]) || isNaN(imX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        var v = cmath_8.CMath.length2(reX[i], imX[i]);\r
-                        if (v > norm) {\r
-                            norm = v;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.vecPNorm = function (reX, p) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        norm += Math.pow(Math.abs(reX[i]), p);\r
-                    }\r
-                    return Math.pow(norm, 1 / p);\r
-                };\r
-                NormFunction.cvecPNorm = function (reX, imX, p) {\r
-                    var norm = 0;\r
-                    for (var i = 0; i < reX.length; i++) {\r
-                        if (isNaN(reX[i]) || isNaN(imX[i])) {\r
-                            return NaN;\r
-                        }\r
-                        norm += Math.pow(cmath_8.CMath.length2(reX[i], imX[i]), p);\r
-                    }\r
-                    return Math.pow(norm, 1 / p);\r
-                };\r
-                NormFunction.mat1Norm = function (m, n, reX) {\r
-                    var norm = 0, colSum, el;\r
-                    for (var j = 0; j < n; j++) {\r
-                        colSum = 0;\r
-                        for (var i = 0; i < m; i++) {\r
-                            el = reX[i * n + j];\r
-                            if (isNaN(el)) {\r
-                                return NaN;\r
-                            }\r
-                            colSum += Math.abs(el);\r
-                        }\r
-                        if (colSum > norm) {\r
-                            norm = colSum;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.cmat1Norm = function (m, n, reX, imX) {\r
-                    var norm = 0, colSum, elRe, elIm;\r
-                    for (var j = 0; j < n; j++) {\r
-                        colSum = 0;\r
-                        for (var i = 0; i < m; i++) {\r
-                            elRe = reX[i * n + j];\r
-                            elIm = imX[i * n + j];\r
-                            if (isNaN(elRe) || isNaN(elIm)) {\r
-                                return NaN;\r
-                            }\r
-                            colSum += cmath_8.CMath.length2(elRe, elIm);\r
-                        }\r
-                        if (colSum > norm) {\r
-                            norm = colSum;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.matInfNorm = function (m, n, reX) {\r
-                    var norm = 0, rowSum, el;\r
-                    for (var i = 0; i < m; i++) {\r
-                        rowSum = 0;\r
-                        for (var j = 0; j < n; j++) {\r
-                            el = reX[i * n + j];\r
-                            if (isNaN(el)) {\r
-                                return NaN;\r
-                            }\r
-                            rowSum += Math.abs(el);\r
-                        }\r
-                        if (rowSum > norm) {\r
-                            norm = rowSum;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                NormFunction.cmatInfNorm = function (m, n, reX, imX) {\r
-                    var norm = 0, rowSum, elRe, elIm;\r
-                    for (var i = 0; i < m; i++) {\r
-                        rowSum = 0;\r
-                        for (var j = 0; j < n; j++) {\r
-                            elRe = reX[i * n + j];\r
-                            elIm = imX[i * n + j];\r
-                            if (isNaN(elRe) || isNaN(elIm)) {\r
-                                return NaN;\r
-                            }\r
-                            rowSum += cmath_8.CMath.length2(elRe, elIm);\r
-                        }\r
-                        if (rowSum > norm) {\r
-                            norm = rowSum;\r
-                        }\r
-                    }\r
-                    return norm;\r
-                };\r
-                return NormFunction;\r
-            }());\r
-            exports_52("NormFunction", NormFunction);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/matrix/index", ["jasmal/lib/tensor", "jasmal/lib/complexNumber", "jasmal/lib/dtype", "jasmal/lib/ops/matrix/matmul", "jasmal/lib/ops/matrix/transpose", "jasmal/lib/ops/matrix/decomp/lu", "jasmal/lib/ops/matrix/decomp/svd", "jasmal/lib/ops/matrix/decomp/eigen", "jasmal/lib/ops/matrix/decomp/chol", "jasmal/lib/ops/matrix/decomp/qr", "jasmal/lib/ops/matrix/norm", "jasmal/lib/constant", "jasmal/lib/helper/dataHelper", "jasmal/lib/math/cmath"], function (exports_53, context_53) {\r
-    "use strict";\r
-    var __moduleName = context_53 && context_53.id;\r
-    var tensor_9, complexNumber_6, dtype_14, matmul_1, transpose_1, lu_1, svd_1, eigen_1, chol_1, qr_1, norm_1, constant_6, dataHelper_12, cmath_9, MatrixOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_9_1) {\r
-                tensor_9 = tensor_9_1;\r
-            },\r
-            function (complexNumber_6_1) {\r
-                complexNumber_6 = complexNumber_6_1;\r
-            },\r
-            function (dtype_14_1) {\r
-                dtype_14 = dtype_14_1;\r
-            },\r
-            function (matmul_1_1) {\r
-                matmul_1 = matmul_1_1;\r
-            },\r
-            function (transpose_1_1) {\r
-                transpose_1 = transpose_1_1;\r
-            },\r
-            function (lu_1_1) {\r
-                lu_1 = lu_1_1;\r
-            },\r
-            function (svd_1_1) {\r
-                svd_1 = svd_1_1;\r
-            },\r
-            function (eigen_1_1) {\r
-                eigen_1 = eigen_1_1;\r
-            },\r
-            function (chol_1_1) {\r
-                chol_1 = chol_1_1;\r
-            },\r
-            function (qr_1_1) {\r
-                qr_1 = qr_1_1;\r
-            },\r
-            function (norm_1_1) {\r
-                norm_1 = norm_1_1;\r
-            },\r
-            function (constant_6_1) {\r
-                constant_6 = constant_6_1;\r
-            },\r
-            function (dataHelper_12_1) {\r
-                dataHelper_12 = dataHelper_12_1;\r
-            },\r
-            function (cmath_9_1) {\r
-                cmath_9 = cmath_9_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            MatrixOpProviderFactory = (function () {\r
-                function MatrixOpProviderFactory() {\r
-                }\r
-                MatrixOpProviderFactory.create = function (arithmOp, mathOp, mmb, mtb) {\r
-                    if (mmb === void 0) { mmb = new matmul_1.BuiltInMMB(); }\r
-                    if (mtb === void 0) { mtb = new transpose_1.BuiltInMTB(); }\r
-                    var opEye = function (m, n, dtype) {\r
-                        if (dtype === void 0) { dtype = 3; }\r
-                        if (n == undefined)\r
-                            n = m;\r
-                        var X = tensor_9.Tensor.zeros([m, n], dtype);\r
-                        var l = Math.min(n, m);\r
-                        for (var i = 0; i < l; i++) {\r
-                            X.realData[i * n + i] = 1;\r
-                        }\r
-                        return X;\r
-                    };\r
-                    var opHilb = function (n) {\r
-                        var m = tensor_9.Tensor.zeros([n, n]);\r
-                        for (var i = 0; i < n; i++) {\r
-                            for (var j = 0; j < n; j++) {\r
-                                m.realData[i * n + j] = 1 / (i + j + 1);\r
-                            }\r
-                        }\r
-                        return m;\r
-                    };\r
-                    var opDiag = function (x, k) {\r
-                        if (k === void 0) { k = 0; }\r
-                        var X = tensor_9.Tensor.analyzeOpInput(x);\r
-                        if (X.isInputScalar) {\r
-                            return tensor_9.Tensor.scalar(X.re, X.im);\r
-                        }\r
-                        else {\r
-                            var Y = void 0;\r
-                            var reX = X.reArr;\r
-                            var imX = X.imArr;\r
-                            var reY = void 0, imY = void 0;\r
-                            var n = void 0, minI = void 0, maxI = void 0;\r
-                            if (X.originalShape.length === 1) {\r
-                                n = reX.length + Math.abs(k);\r
-                                minI = k >= 0 ? 0 : -k;\r
-                                maxI = minI + reX.length - 1;\r
-                                Y = tensor_9.Tensor.zeros([n, n], X.originalDType);\r
-                                reY = Y.realData;\r
-                                if (X.isComplex) {\r
-                                    Y.ensureComplexStorage();\r
-                                    imY = Y.imagData;\r
-                                    for (var i = minI; i <= maxI; i++) {\r
-                                        reY[i * n + i + k] = reX[i - minI];\r
-                                        imY[i * n + i + k] = imX[i - minI];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = minI; i <= maxI; i++) {\r
-                                        reY[i * n + i + k] = reX[i - minI];\r
-                                    }\r
-                                }\r
-                            }\r
-                            else if (X.originalShape.length === 2) {\r
-                                if (k <= -X.originalShape[0] || k >= X.originalShape[1]) {\r
-                                    throw new Error('The specified diagonal does not exist.');\r
-                                }\r
-                                n = Math.min(X.originalShape[0], X.originalShape[1]);\r
-                                minI = k >= 0 ? 0 : -k;\r
-                                if (k >= 0) {\r
-                                    maxI = Math.min(X.originalShape[1] - k - 1, n - 1);\r
-                                }\r
-                                else {\r
-                                    maxI = Math.min(X.originalShape[0] - 1, minI + n - 1);\r
-                                }\r
-                                Y = tensor_9.Tensor.zeros([maxI - minI + 1], X.originalDType);\r
-                                reY = Y.realData;\r
-                                if (X.isComplex) {\r
-                                    Y.ensureComplexStorage();\r
-                                    imY = Y.imagData;\r
-                                    for (var i = minI; i <= maxI; i++) {\r
-                                        reY[i - minI] = reX[i * X.originalShape[1] + i + k];\r
-                                        imY[i - minI] = imX[i * X.originalShape[1] + i + k];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (var i = minI; i <= maxI; i++) {\r
-                                        reY[i - minI] = reX[i * X.originalShape[1] + i + k];\r
-                                    }\r
-                                }\r
-                            }\r
-                            else {\r
-                                throw new Error('Matrix, vector, or scalar expected.');\r
-                            }\r
-                            return Y;\r
-                        }\r
-                    };\r
-                    var opVander = function (x, n, increasing) {\r
-                        if (increasing === void 0) { increasing = false; }\r
-                        var info = tensor_9.Tensor.analyzeOpInput(x);\r
-                        if (info.originalShape.length > 1) {\r
-                            throw new Error('Vector expected.');\r
-                        }\r
-                        if (n == undefined) {\r
-                            n = info.originalShape[0];\r
-                        }\r
-                        else {\r
-                            if (n <= 0 || Math.floor(n) !== n) {\r
-                                throw new Error('n must be a positive integer.');\r
-                            }\r
-                        }\r
-                        var m = info.originalShape[0];\r
-                        var Y = tensor_9.Tensor.zeros([m, n], dtype_14.OutputDTypeResolver.uOnlyLogicToFloat(info.originalDType, info.isComplex));\r
-                        var reX = info.isInputScalar ? [info.re] : info.reArr;\r
-                        var reY = Y.realData;\r
-                        if (info.isComplex) {\r
-                            Y.ensureComplexStorage();\r
-                            var imX = info.isInputScalar ? [info.im] : info.imArr;\r
-                            var imY = Y.imagData;\r
-                            for (var i = 0; i < m; i++) {\r
-                                var reT = reX[i];\r
-                                var imT = imX[i];\r
-                                if (increasing) {\r
-                                    reY[i * n] = 1;\r
-                                    imY[i * n] = 0;\r
-                                    for (var j = 1; j < n; j++) {\r
-                                        reY[i * n + j] = reY[i * n + j - 1] * reT - imY[i * n + j - 1] * imT;\r
-                                        imY[i * n + j] = reY[i * n + j - 1] * imT + imY[i * n + j - 1] * reT;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    reY[i * n + n - 1] = 1;\r
-                                    imY[i * n + n - 1] = 0;\r
-                                    for (var j = n - 2; j >= 0; j--) {\r
-                                        reY[i * n + j] = reY[i * n + j + 1] * reT - imY[i * n + j + 1] * imT;\r
-                                        imY[i * n + j] = reY[i * n + j + 1] * imT + imY[i * n + j + 1] * reT;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < m; i++) {\r
-                                var t = reX[i];\r
-                                if (increasing) {\r
-                                    reY[i * n] = 1;\r
-                                    for (var j = 1; j < n; j++) {\r
-                                        reY[i * n + j] = reY[i * n + j - 1] * t;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    reY[i * n + n - 1] = 1;\r
-                                    for (var j = n - 2; j >= 0; j--) {\r
-                                        reY[i * n + j] = reY[i * n + j + 1] * t;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    var copyLower = function (m, n, k, x, y) {\r
-                        for (var i = 0; i < m; i++) {\r
-                            var maxJ = Math.min(n - 1, k + i);\r
-                            for (var j = 0; j <= maxJ; j++) {\r
-                                y[i * n + j] = x[i * n + j];\r
-                            }\r
-                        }\r
-                    };\r
-                    var copyUpper = function (m, n, k, x, y) {\r
-                        for (var i = 0; i < m; i++) {\r
-                            var minJ = Math.max(k + i, 0);\r
-                            for (var j = minJ; j < n; j++) {\r
-                                y[i * n + j] = x[i * n + j];\r
-                            }\r
-                        }\r
-                    };\r
-                    var opTril = function (x, k) {\r
-                        if (k === void 0) { k = 0; }\r
-                        var info = tensor_9.Tensor.analyzeOpInput(x);\r
-                        if (info.isInputScalar || info.originalShape.length > 2) {\r
-                            throw new Error('Matrix or vector expected.');\r
-                        }\r
-                        else {\r
-                            var m = void 0, n = void 0;\r
-                            if (info.originalShape.length === 1) {\r
-                                m = 1;\r
-                                n = info.originalShape[0];\r
-                            }\r
-                            else {\r
-                                m = info.originalShape[0];\r
-                                n = info.originalShape[1];\r
-                            }\r
-                            var Y = tensor_9.Tensor.zeros(info.originalShape, info.originalDType);\r
-                            copyLower(m, n, k, info.reArr, Y.realData);\r
-                            if (info.isComplex) {\r
-                                Y.ensureComplexStorage();\r
-                                copyLower(m, n, k, info.imArr, Y.imagData);\r
-                            }\r
-                            return Y;\r
-                        }\r
-                    };\r
-                    var opTriu = function (x, k) {\r
-                        if (k === void 0) { k = 0; }\r
-                        var info = tensor_9.Tensor.analyzeOpInput(x);\r
-                        if (info.isInputScalar || info.originalShape.length > 2) {\r
-                            throw new Error('Matrix or vector expected.');\r
-                        }\r
-                        else {\r
-                            var m = void 0, n = void 0;\r
-                            if (info.originalShape.length === 1) {\r
-                                m = 1;\r
-                                n = info.originalShape[0];\r
-                            }\r
-                            else {\r
-                                m = info.originalShape[0];\r
-                                n = info.originalShape[1];\r
-                            }\r
-                            var Y = tensor_9.Tensor.zeros(info.originalShape, info.originalDType);\r
-                            copyUpper(m, n, k, info.reArr, Y.realData);\r
-                            if (info.isComplex) {\r
-                                Y.ensureComplexStorage();\r
-                                copyUpper(m, n, k, info.imArr, Y.imagData);\r
-                            }\r
-                            return Y;\r
-                        }\r
-                    };\r
-                    var isSymmetric = function (m, n, x, skew) {\r
-                        if (skew) {\r
-                            for (var i = 0; i < m; i++) {\r
-                                for (var j = 0; j < n; j++) {\r
-                                    if (x[i * n + j] !== -x[j * m + i]) {\r
-                                        return false;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < m; i++) {\r
-                                for (var j = 0; j < n; j++) {\r
-                                    if (x[i * n + j] !== x[j * m + i]) {\r
-                                        return false;\r
-                                    }\r
-                                }\r
-                            }\r
-                        }\r
-                        return true;\r
-                    };\r
-                    var opIsSymmetric = function (x, skew) {\r
-                        if (skew === void 0) { skew = false; }\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        if (X.ndim !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        var _a = X.shape, m = _a[0], n = _a[1];\r
-                        if (X.hasComplexStorage()) {\r
-                            return isSymmetric(m, n, X.realData, skew) && isSymmetric(m, n, X.imagData, skew);\r
-                        }\r
-                        else {\r
-                            return isSymmetric(m, n, X.realData, skew);\r
-                        }\r
-                    };\r
-                    var opIsHermitian = function (x, skew) {\r
-                        if (skew === void 0) { skew = false; }\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        if (X.ndim !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        var _a = X.shape, m = _a[0], n = _a[1];\r
-                        if (X.hasComplexStorage()) {\r
-                            return isSymmetric(m, n, X.realData, skew) && isSymmetric(m, n, X.imagData, !skew);\r
-                        }\r
-                        else {\r
-                            return isSymmetric(m, n, X.realData, skew);\r
-                        }\r
-                    };\r
-                    var matMulOutputTypeResolver = function (t1, _isComplex1, t2, _isComplex2) {\r
-                        switch (t1) {\r
-                            case 0:\r
-                            case 1:\r
-                                switch (t2) {\r
-                                    case 0:\r
-                                    case 1:\r
-                                        return 1;\r
-                                    case 3:\r
-                                        return 3;\r
-                                }\r
-                            case 3:\r
-                                return 3;\r
-                        }\r
-                        return undefined;\r
-                    };\r
-                    var opMatMul = function (x, y, yModifier) {\r
-                        if (yModifier === void 0) { yModifier = 0; }\r
-                        var vx = tensor_9.Tensor.analyzeOpInput(x);\r
-                        var vy = tensor_9.Tensor.analyzeOpInput(y);\r
-                        if (vx.originalShape.length > 2 || vy.originalShape.length > 2) {\r
-                            throw new Error('Matrix or vector expected.');\r
-                        }\r
-                        if (vx.isInputScalar) {\r
-                            vx.reArr = [vx.re];\r
-                            if (vx.isComplex) {\r
-                                vx.imArr = [vx.im];\r
-                            }\r
-                        }\r
-                        if (vy.isInputScalar) {\r
-                            vy.reArr = [vy.re];\r
-                            if (vy.isComplex) {\r
-                                vy.imArr = [vy.im];\r
-                            }\r
-                        }\r
-                        var m = vx.originalShape.length === 1 ? 1 : vx.originalShape[0];\r
-                        var n1 = vx.originalShape.length === 1 ? vx.originalShape[0] : vx.originalShape[1];\r
-                        var n2 = vy.originalShape.length === 1 ? 1 : vy.originalShape[0];\r
-                        var p = vy.originalShape.length === 1 ? vy.originalShape[0] : vy.originalShape[1];\r
-                        if (yModifier > 0) {\r
-                            var tmp = n2;\r
-                            n2 = p;\r
-                            p = tmp;\r
-                        }\r
-                        if (n1 !== n2) {\r
-                            throw new Error("Matrix dimensions (" + m + ", " + n1 + ") and (" + n2 + ", " + p + ") are not compatible.");\r
-                        }\r
-                        var Z = tensor_9.Tensor.zeros([m, p], matMulOutputTypeResolver(vx.originalDType, vx.isComplex, vy.originalDType, vy.isComplex));\r
-                        if (vx.reArr.length === 0 || vy.reArr.length === 0) {\r
-                            return Z;\r
-                        }\r
-                        if (vx.isComplex) {\r
-                            Z.ensureComplexStorage();\r
-                            if (vy.isComplex) {\r
-                                mmb.cmulmm(m, n1, p, yModifier, vx.reArr, vx.imArr, vy.reArr, vy.imArr, Z.realData, Z.imagData);\r
-                            }\r
-                            else {\r
-                                mmb.mulmm(m, n1, p, yModifier, vx.reArr, vy.reArr, Z.realData);\r
-                                mmb.mulmm(m, n1, p, yModifier, vx.imArr, vy.reArr, Z.imagData);\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (vy.isComplex) {\r
-                                Z.ensureComplexStorage();\r
-                                if (yModifier === 2) {\r
-                                    mmb.mulmm(m, n1, p, 1, vx.reArr, vy.reArr, Z.realData);\r
-                                    mmb.mulmm(m, n1, p, 1, vx.reArr, vy.imArr, Z.imagData);\r
-                                    var reZ = Z.imagData;\r
-                                    for (var i = 0; i < reZ.length; i++) {\r
-                                        reZ[i] = -reZ[i];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    mmb.mulmm(m, n1, p, yModifier, vx.reArr, vy.reArr, Z.realData);\r
-                                    mmb.mulmm(m, n1, p, yModifier, vx.reArr, vy.imArr, Z.imagData);\r
-                                }\r
-                            }\r
-                            else {\r
-                                mmb.mulmm(m, n1, p, yModifier, vx.reArr, vy.reArr, Z.realData);\r
-                            }\r
-                        }\r
-                        return Z;\r
-                    };\r
-                    var opKron = function (x, y) {\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        var Y = y instanceof tensor_9.Tensor ? y : tensor_9.Tensor.toTensor(y);\r
-                        if (X.ndim > 2 || Y.ndim > 2) {\r
-                            throw new Error('Kronecker produce for ndim > 2 is not supported.');\r
-                        }\r
-                        if (X.ndim === 1 && Y.ndim === 1) {\r
-                            return arithmOp.mul(X.getReshapedCopy([-1, 1]), Y).reshape([-1]);\r
-                        }\r
-                        var shapeX = X.shape;\r
-                        var shapeY = Y.shape;\r
-                        var A = X.getReshapedCopy([shapeX[0], 1, shapeX[1], 1]);\r
-                        var B = Y.getReshapedCopy([1, shapeY[0], 1, shapeY[1]]);\r
-                        return arithmOp.mul(A, B).reshape([shapeX[0] * shapeY[0], shapeX[1] * shapeY[1]]);\r
-                    };\r
-                    var opTranspose = function (x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (shapeX.length === 1) {\r
-                            return X.getReshapedCopy([-1, 1]);\r
-                        }\r
-                        else if (shapeX.length === 2) {\r
-                            var Y = tensor_9.Tensor.zeros([shapeX[1], shapeX[0]], X.dtype);\r
-                            mtb.transpose(shapeX, X.realData, Y.realData);\r
-                            if (X.hasComplexStorage()) {\r
-                                Y.ensureComplexStorage();\r
-                                mtb.transpose(shapeX, X.imagData, Y.imagData);\r
-                            }\r
-                            return Y;\r
-                        }\r
-                        else {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                    };\r
-                    var opHermitian = function (x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        var Y;\r
-                        if (shapeX.length === 1) {\r
-                            Y = X.getReshapedCopy([-1, 1]);\r
-                            if (Y.hasComplexStorage()) {\r
-                                Y.ensureUnsharedLocalStorage();\r
-                                var im = Y.imagData;\r
-                                for (var i = 0; i < im.length; i++) {\r
-                                    im[i] = -im[i];\r
-                                }\r
-                            }\r
-                            return Y;\r
-                        }\r
-                        else if (shapeX.length === 2) {\r
-                            var Y_1 = tensor_9.Tensor.zeros([shapeX[1], shapeX[0]], X.dtype);\r
-                            if (X.hasComplexStorage()) {\r
-                                Y_1.ensureComplexStorage();\r
-                                mtb.hermitian(shapeX, X.realData, X.imagData, Y_1.realData, Y_1.imagData);\r
-                            }\r
-                            else {\r
-                                mtb.transpose(shapeX, X.realData, Y_1.realData);\r
-                            }\r
-                            return Y_1;\r
-                        }\r
-                        else {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                    };\r
-                    var opTrace = function (x) {\r
-                        var infoX = tensor_9.Tensor.analyzeOpInput(x);\r
-                        if (infoX.hasOnlyOneElement) {\r
-                            return infoX.isComplex ? new complexNumber_6.ComplexNumber(infoX.re, infoX.im) : infoX.re;\r
-                        }\r
-                        else {\r
-                            if (infoX.originalShape.length !== 2 || infoX.originalShape[0] !== infoX.originalShape[1]) {\r
-                                throw new Error('Square matrix expected.');\r
-                            }\r
-                            var re = infoX.reArr;\r
-                            var im = infoX.imArr;\r
-                            var n = infoX.originalShape[0];\r
-                            var accRe = 0, accIm = 0;\r
-                            for (var i = 0; i < n; i++) {\r
-                                accRe += re[i * n + i];\r
-                            }\r
-                            if (infoX.isComplex) {\r
-                                for (var i = 0; i < n; i++) {\r
-                                    accIm += im[i * n + i];\r
-                                }\r
-                            }\r
-                            return accIm === 0 ? accRe : new complexNumber_6.ComplexNumber(accRe, accIm);\r
-                        }\r
-                    };\r
-                    var opNorm = function (x, p) {\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        if (X.ndim > 2) {\r
-                            throw new Error('Norm only works for vectors and matrices.');\r
-                        }\r
-                        if (X.ndim === 1 || (X.ndim === 2 && X.shape[1] === 1)) {\r
-                            if (typeof (p) !== 'number') {\r
-                                throw new Error('For vectors, p must be nonnegative.');\r
-                            }\r
-                            if (p < 0) {\r
-                                throw new Error('p must be nonnegative.');\r
-                            }\r
-                            switch (p) {\r
-                                case 0:\r
-                                    return X.hasComplexStorage()\r
-                                        ? norm_1.NormFunction.cvec0Norm(X.realData, X.imagData)\r
-                                        : norm_1.NormFunction.vec0Norm(X.realData);\r
-                                case 2:\r
-                                    return X.hasComplexStorage()\r
-                                        ? norm_1.NormFunction.cvec2Norm(X.realData, X.imagData)\r
-                                        : norm_1.NormFunction.vec2Norm(X.realData);\r
-                                case Infinity:\r
-                                    return X.hasComplexStorage()\r
-                                        ? norm_1.NormFunction.cvecInfNorm(X.realData, X.imagData)\r
-                                        : norm_1.NormFunction.vecInfNorm(X.realData);\r
-                                default:\r
-                                    return X.hasComplexStorage()\r
-                                        ? norm_1.NormFunction.cvecPNorm(X.realData, X.imagData, p)\r
-                                        : norm_1.NormFunction.vecPNorm(X.realData, p);\r
-                            }\r
-                        }\r
-                        else {\r
-                            var shape = X.shape;\r
-                            if (typeof (p) === 'string') {\r
-                                if (p.toLowerCase() !== 'fro') {\r
-                                    throw new Error('Expecting "fro".');\r
-                                }\r
-                                return X.hasComplexStorage()\r
-                                    ? norm_1.NormFunction.cvec2Norm(X.realData, X.imagData)\r
-                                    : norm_1.NormFunction.vec2Norm(X.realData);\r
-                            }\r
-                            else {\r
-                                switch (p) {\r
-                                    case 1:\r
-                                        return X.hasComplexStorage()\r
-                                            ? norm_1.NormFunction.cmat1Norm(shape[0], shape[1], X.realData, X.imagData)\r
-                                            : norm_1.NormFunction.mat1Norm(shape[0], shape[1], X.realData);\r
-                                    case 2:\r
-                                        var s = dataHelper_12.DataHelper.allocateFloat64Array(shape[1]);\r
-                                        if (X === x) {\r
-                                            X = x.asType(3, true);\r
-                                        }\r
-                                        if (X.hasNonZeroComplexStorage()) {\r
-                                            svd_1.SVD.csvd(shape[0], shape[1], false, X.realData, X.imagData, s, [], []);\r
-                                        }\r
-                                        else {\r
-                                            svd_1.SVD.svd(shape[0], shape[1], false, X.realData, s, []);\r
-                                        }\r
-                                        return s[0];\r
-                                    case Infinity:\r
-                                        return X.hasComplexStorage()\r
-                                            ? norm_1.NormFunction.cmatInfNorm(shape[0], shape[1], X.realData, X.imagData)\r
-                                            : norm_1.NormFunction.matInfNorm(shape[0], shape[1], X.realData);\r
-                                    default:\r
-                                        throw new Error('Only 1, 2, and infinity norm are supported for matrices.');\r
-                                }\r
-                            }\r
-                        }\r
-                    };\r
-                    function doCompactLU(x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (shapeX.length !== 2 || shapeX[0] !== shapeX[1]) {\r
-                            throw new Error('Square matrix expected.');\r
-                        }\r
-                        X.ensureUnsharedLocalStorage();\r
-                        var m = shapeX[0];\r
-                        var p = new Array(m);\r
-                        var sign;\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            sign = lu_1.LU.clu(m, X.realData, X.imagData, p);\r
-                        }\r
-                        else {\r
-                            X.trimImaginaryPart();\r
-                            sign = lu_1.LU.lu(m, X.realData, p);\r
-                        }\r
-                        return [X, p, sign];\r
-                    }\r
-                    function opLu(x, compact) {\r
-                        if (compact === void 0) { compact = false; }\r
-                        var _a = doCompactLU(x), X = _a[0], p = _a[1];\r
-                        if (compact) {\r
-                            return [X, p];\r
-                        }\r
-                        else {\r
-                            var shapeX = X.shape;\r
-                            var L = tensor_9.Tensor.zeros(shapeX);\r
-                            var U = tensor_9.Tensor.zeros(shapeX);\r
-                            var P = tensor_9.Tensor.zeros(shapeX);\r
-                            lu_1.LU.compactToFull(shapeX[0], false, X.realData, L.realData, U.realData);\r
-                            if (X.hasComplexStorage()) {\r
-                                L.ensureComplexStorage();\r
-                                U.ensureComplexStorage();\r
-                                P.ensureComplexStorage();\r
-                                lu_1.LU.compactToFull(shapeX[0], true, X.imagData, L.imagData, U.imagData);\r
-                            }\r
-                            lu_1.LU.permutationToFull(p, P.realData);\r
-                            return [L, U, P];\r
-                        }\r
-                    }\r
-                    function opInv(x) {\r
-                        var _a = doCompactLU(x), X = _a[0], p = _a[1];\r
-                        var m = X.shape[0];\r
-                        var B = opEye(m);\r
-                        if (X.hasComplexStorage()) {\r
-                            B.ensureComplexStorage();\r
-                            lu_1.LU.cluSolve(m, m, X.realData, X.imagData, p, B.realData, B.imagData);\r
-                        }\r
-                        else {\r
-                            lu_1.LU.luSolve(m, m, X.realData, p, B.realData);\r
-                        }\r
-                        return B;\r
-                    }\r
-                    function opDet(x) {\r
-                        var _a = doCompactLU(x), X = _a[0], sign = _a[2];\r
-                        var m = X.shape[0];\r
-                        var reX = X.realData;\r
-                        var accRe = 1;\r
-                        var tmp;\r
-                        if (X.hasComplexStorage()) {\r
-                            var imX = X.imagData;\r
-                            var accIm = 0;\r
-                            for (var i = 0; i < m; i++) {\r
-                                tmp = accRe;\r
-                                accRe = accRe * reX[i * m + i] - accIm * imX[i * m + i];\r
-                                accIm = tmp * imX[i * m + i] + accIm * reX[i * m + i];\r
-                            }\r
-                            accRe *= sign;\r
-                            accIm *= sign;\r
-                            return accIm === 0 ? accRe : new complexNumber_6.ComplexNumber(accRe, accIm);\r
-                        }\r
-                        else {\r
-                            for (var i = 0; i < m; i++) {\r
-                                accRe *= reX[i * m + i];\r
-                            }\r
-                            accRe *= sign;\r
-                            return accRe;\r
-                        }\r
-                    }\r
-                    var opQr = function (x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (shapeX.length !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        var Q = tensor_9.Tensor.zeros([shapeX[0], shapeX[0]]);\r
-                        var P = tensor_9.Tensor.zeros([shapeX[1], shapeX[1]]);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            Q.ensureComplexStorage();\r
-                            qr_1.QR.cqrpf(shapeX[0], shapeX[1], X.realData, X.imagData, Q.realData, Q.imagData, P.realData);\r
-                        }\r
-                        else {\r
-                            qr_1.QR.qrpf(shapeX[0], shapeX[1], X.realData, Q.realData, P.realData);\r
-                        }\r
-                        return [Q, X, P];\r
-                    };\r
-                    function opSvd(x, svOnly) {\r
-                        if (svOnly === void 0) { svOnly = false; }\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (shapeX.length !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        var s = tensor_9.Tensor.zeros([shapeX[1]]);\r
-                        var ns = Math.min(shapeX[0], shapeX[1]);\r
-                        if (svOnly) {\r
-                            if (X.hasNonZeroComplexStorage()) {\r
-                                svd_1.SVD.csvd(shapeX[0], shapeX[1], false, X.realData, X.imagData, s.realData, [], []);\r
-                            }\r
-                            else {\r
-                                svd_1.SVD.svd(shapeX[0], shapeX[1], false, X.realData, s.realData, []);\r
-                            }\r
-                            if (ns !== s.size) {\r
-                                s = s.get(":" + ns);\r
-                            }\r
-                            return s;\r
-                        }\r
-                        else {\r
-                            var V = tensor_9.Tensor.zeros([shapeX[1], shapeX[1]]);\r
-                            if (X.hasNonZeroComplexStorage()) {\r
-                                V.ensureComplexStorage();\r
-                                svd_1.SVD.csvd(shapeX[0], shapeX[1], true, X.realData, X.imagData, s.realData, V.realData, V.imagData);\r
-                            }\r
-                            else {\r
-                                svd_1.SVD.svd(shapeX[0], shapeX[1], true, X.realData, s.realData, V.realData);\r
-                                X.trimImaginaryPart();\r
-                            }\r
-                            if (ns < shapeX[1]) {\r
-                                var S = tensor_9.Tensor.zeros(shapeX);\r
-                                var reS = S.realData;\r
-                                for (var i = 0; i < ns; i++) {\r
-                                    reS[i * shapeX[1] + i] = s.realData[i];\r
-                                }\r
-                                return [X.get(':', ':' + ns, true), S, V];\r
-                            }\r
-                            else {\r
-                                return [X, opDiag(s), V];\r
-                            }\r
-                        }\r
-                    }\r
-                    var opRank = function (x, tol) {\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shape = X.shape;\r
-                        var s = dataHelper_12.DataHelper.allocateFloat64Array(shape[1]);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            svd_1.SVD.csvd(shape[0], shape[1], false, X.realData, X.imagData, s, [], []);\r
-                        }\r
-                        else {\r
-                            svd_1.SVD.svd(shape[0], shape[1], false, X.realData, s, []);\r
-                        }\r
-                        var sMax = s[0];\r
-                        if (sMax === 0) {\r
-                            return 0;\r
-                        }\r
-                        tol = tol == undefined ? constant_6.EPSILON * sMax : tol;\r
-                        var r = 0;\r
-                        for (; r < s.length; r++) {\r
-                            if (s[r] < tol) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        return r;\r
-                    };\r
-                    var opCond = function (x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shape = X.shape;\r
-                        var s = dataHelper_12.DataHelper.allocateFloat64Array(shape[1]);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            svd_1.SVD.csvd(shape[0], shape[1], false, X.realData, X.imagData, s, [], []);\r
-                        }\r
-                        else {\r
-                            svd_1.SVD.svd(shape[0], shape[1], false, X.realData, s, []);\r
-                        }\r
-                        return s[0] / s[s.length - 1];\r
-                    };\r
-                    var opPinv = function (x, tol) {\r
-                        var X = x instanceof tensor_9.Tensor ? x.asType(3, true) : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        var s = new Array(shapeX[1]);\r
-                        var V = tensor_9.Tensor.zeros([shapeX[1], shapeX[1]]);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            V.ensureComplexStorage();\r
-                            svd_1.SVD.csvd(shapeX[0], shapeX[1], true, X.realData, X.imagData, s, V.realData, V.imagData);\r
-                        }\r
-                        else {\r
-                            svd_1.SVD.svd(shapeX[0], shapeX[1], true, X.realData, s, V.realData);\r
-                        }\r
-                        var sMax = s[0];\r
-                        if (sMax === 0) {\r
-                            return tensor_9.Tensor.zeros([shapeX[1], shapeX[0]]);\r
-                        }\r
-                        tol = tol == undefined ? constant_6.EPSILON * sMax : tol;\r
-                        var r = 0;\r
-                        for (; r < s.length; r++) {\r
-                            if (s[r] < tol) {\r
-                                break;\r
-                            }\r
-                        }\r
-                        if (r === 0) {\r
-                            return tensor_9.Tensor.zeros([shapeX[1], shapeX[0]]);\r
-                        }\r
-                        for (var i = 0; i < r; i++) {\r
-                            s[i] = 1.0 / s[i];\r
-                        }\r
-                        var Z = arithmOp.mul(V.get(':', ':' + r, true), s.slice(0, r));\r
-                        return opMatMul(Z, X.get(':', ':' + r, true), 2);\r
-                    };\r
-                    function opEig(x, evOnly) {\r
-                        if (evOnly === void 0) { evOnly = false; }\r
-                        var X;\r
-                        var needExtraCopy = false;\r
-                        if (x instanceof tensor_9.Tensor) {\r
-                            X = x;\r
-                            if (X.dtype !== 3) {\r
-                                X = X.asType(3);\r
-                            }\r
-                            else {\r
-                                needExtraCopy = true;\r
-                            }\r
-                        }\r
-                        else {\r
-                            X = tensor_9.Tensor.toTensor(x);\r
-                        }\r
-                        var shapeX = X.shape;\r
-                        if (X.ndim !== 2 || shapeX[0] !== shapeX[1]) {\r
-                            throw new Error('Square matrix expected.');\r
-                        }\r
-                        var E;\r
-                        var v = tensor_9.Tensor.zeros([shapeX[0]]);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            X = needExtraCopy ? X.copy(true) : X;\r
-                            if (opIsHermitian(X)) {\r
-                                if (evOnly) {\r
-                                    eigen_1.Eigen.ch(shapeX[0], X.realData, X.imagData, v.realData, false, [], []);\r
-                                }\r
-                                else {\r
-                                    E = tensor_9.Tensor.zeros(shapeX);\r
-                                    E.ensureComplexStorage();\r
-                                    eigen_1.Eigen.ch(shapeX[0], X.realData, X.imagData, v.realData, true, E.realData, E.imagData);\r
-                                }\r
-                            }\r
-                            else {\r
-                                v.ensureComplexStorage();\r
-                                if (evOnly) {\r
-                                    eigen_1.Eigen.cg(shapeX[0], X.realData, X.imagData, v.realData, v.imagData, true, [], []);\r
-                                }\r
-                                else {\r
-                                    E = tensor_9.Tensor.zeros(shapeX);\r
-                                    E.ensureComplexStorage();\r
-                                    eigen_1.Eigen.cg(shapeX[0], X.realData, X.imagData, v.realData, v.imagData, true, E.realData, E.imagData);\r
-                                }\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (opIsSymmetric(X)) {\r
-                                if (evOnly) {\r
-                                    eigen_1.Eigen.rs(shapeX[0], X.realData, v.realData, false, []);\r
-                                }\r
-                                else {\r
-                                    E = tensor_9.Tensor.zeros(shapeX);\r
-                                    eigen_1.Eigen.rs(shapeX[0], X.realData, v.realData, true, E.realData);\r
-                                }\r
-                            }\r
-                            else {\r
-                                v.ensureComplexStorage();\r
-                                X = needExtraCopy ? X.copy(true) : X;\r
-                                if (evOnly) {\r
-                                    eigen_1.Eigen.rg(shapeX[0], X.realData, v.realData, v.imagData, false, [], []);\r
-                                }\r
-                                else {\r
-                                    E = tensor_9.Tensor.zeros(shapeX);\r
-                                    E.ensureComplexStorage();\r
-                                    eigen_1.Eigen.rg(shapeX[0], X.realData, v.realData, v.imagData, true, E.realData, E.imagData);\r
-                                }\r
-                            }\r
-                        }\r
-                        if (v.hasComplexStorage() && !v.hasNonZeroComplexStorage()) {\r
-                            v.trimImaginaryPart();\r
-                        }\r
-                        return evOnly ? v : [E, opDiag(v)];\r
-                    }\r
-                    ;\r
-                    var opChol = function (x) {\r
-                        var X = opTril(x);\r
-                        if (X.dtype !== 3) {\r
-                            X = X.asType(3);\r
-                        }\r
-                        var shapeX = X.shape;\r
-                        var p;\r
-                        if (shapeX[0] !== shapeX[1]) {\r
-                            throw new Error('Square matrix expected.');\r
-                        }\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            p = chol_1.Cholesky.cchol(shapeX[0], X.realData, X.imagData);\r
-                        }\r
-                        else {\r
-                            p = chol_1.Cholesky.chol(shapeX[0], X.realData);\r
-                        }\r
-                        if (p !== 0) {\r
-                            throw new Error('Matrix is not positive definite.');\r
-                        }\r
-                        return X;\r
-                    };\r
-                    var opLinsolve = function (a, b) {\r
-                        var A = a instanceof tensor_9.Tensor ? a.asType(3, true) : tensor_9.Tensor.toTensor(a);\r
-                        var B = b instanceof tensor_9.Tensor ? b.asType(3, true) : tensor_9.Tensor.toTensor(b);\r
-                        if (A.ndim !== 2) {\r
-                            throw new Error('a should be a matrix.');\r
-                        }\r
-                        if (B.ndim > 2) {\r
-                            throw new Error('b should be a vector or a matrix.');\r
-                        }\r
-                        var shapeA = A.shape;\r
-                        var shapeB = B.ndim === 1 ? [B.size, 1] : B.shape;\r
-                        if (shapeA[0] !== shapeB[0]) {\r
-                            throw new Error('The number of rows in A must match that in B.');\r
-                        }\r
-                        var isAComplex = A.hasNonZeroComplexStorage();\r
-                        var isBComplex = B.hasNonZeroComplexStorage();\r
-                        if (shapeA[0] === shapeA[1]) {\r
-                            var p = dataHelper_12.DataHelper.allocateInt32Array(shapeA[0]);\r
-                            if (isAComplex) {\r
-                                B.ensureComplexStorage();\r
-                                lu_1.LU.clu(shapeA[0], A.realData, A.imagData, p);\r
-                                lu_1.LU.cluSolve(shapeA[0], shapeB[1], A.realData, A.imagData, p, B.realData, B.imagData);\r
-                            }\r
-                            else {\r
-                                lu_1.LU.lu(shapeA[0], A.realData, p);\r
-                                lu_1.LU.luSolve(shapeA[0], shapeB[1], A.realData, p, B.realData);\r
-                                if (isBComplex) {\r
-                                    lu_1.LU.luSolve(shapeA[0], shapeB[1], A.realData, p, B.imagData);\r
-                                }\r
-                            }\r
-                            return B;\r
-                        }\r
-                        else {\r
-                            var X = tensor_9.Tensor.zeros([shapeA[1], shapeB[1]]);\r
-                            var l = Math.min(shapeA[0], shapeA[1]);\r
-                            var d = dataHelper_12.DataHelper.allocateFloat64Array(l);\r
-                            var ind = dataHelper_12.DataHelper.allocateInt32Array(shapeA[1]);\r
-                            if (isAComplex) {\r
-                                X.ensureComplexStorage();\r
-                                var phr = dataHelper_12.DataHelper.allocateFloat64Array(l);\r
-                                var phi = dataHelper_12.DataHelper.allocateFloat64Array(l);\r
-                                qr_1.QR.cqrp(shapeA[0], shapeA[1], A.realData, A.imagData, d, phr, phi, ind);\r
-                                qr_1.QR.cqrpsol(shapeA[0], shapeA[1], shapeB[1], A.realData, A.imagData, d, ind, phr, phi, B.realData, B.imagData, X.realData, X.imagData);\r
-                            }\r
-                            else {\r
-                                qr_1.QR.qrp(shapeA[0], shapeA[1], A.realData, d, ind);\r
-                                qr_1.QR.qrpsol(shapeA[0], shapeA[1], shapeB[1], A.realData, d, ind, B.realData, X.realData);\r
-                                if (isBComplex) {\r
-                                    X.ensureComplexStorage();\r
-                                    qr_1.QR.qrpsol(shapeA[0], shapeA[1], shapeB[1], A.realData, d, ind, B.imagData, X.imagData);\r
-                                }\r
-                            }\r
-                            return X;\r
-                        }\r
-                    };\r
-                    var opMLDivide = function (a, b) {\r
-                        return opLinsolve(a, b);\r
-                    };\r
-                    var opMRDivide = function (a, b) {\r
-                        return opTranspose(opLinsolve(opTranspose(b), opTranspose(a)));\r
-                    };\r
-                    var opSqrtm = function (x) {\r
-                        var X = x instanceof tensor_9.Tensor ? x : tensor_9.Tensor.toTensor(x);\r
-                        var shapeX = X.shape;\r
-                        if (shapeX.length === 1 && shapeX[0] === 1) {\r
-                            if (X.hasNonZeroComplexStorage()) {\r
-                                var _a = cmath_9.CMath.csqrt(X.realData[0], X.imagData[0]), re = _a[0], im = _a[1];\r
-                                return tensor_9.Tensor.scalar(re, im);\r
-                            }\r
-                            else {\r
-                                var re = X.realData[0];\r
-                                return re >= 0 ? tensor_9.Tensor.scalar(Math.sqrt(re)) : tensor_9.Tensor.scalar(0, Math.sqrt(-re));\r
-                            }\r
-                        }\r
-                        if (shapeX.length !== 2 || (shapeX[0] !== shapeX[1])) {\r
-                            throw new Error('Square matrix expected.');\r
-                        }\r
-                        if (opIsHermitian(X)) {\r
-                            var E = tensor_9.Tensor.zeros(shapeX);\r
-                            var v = tensor_9.Tensor.zeros([shapeX[0]]);\r
-                            if (X.hasNonZeroComplexStorage()) {\r
-                                X = X.asType(3, true);\r
-                                E.ensureComplexStorage();\r
-                                eigen_1.Eigen.ch(shapeX[0], X.realData, X.imagData, v.realData, true, E.realData, E.imagData);\r
-                            }\r
-                            else {\r
-                                eigen_1.Eigen.rs(shapeX[0], X.realData, v.realData, true, E.realData);\r
-                            }\r
-                            mathOp.sqrt(v, true);\r
-                            return opMatMul(arithmOp.mul(E, v), E, 2);\r
-                        }\r
-                        else {\r
-                            throw new Error('Matrix square root for non-Hermitian matrices is not supported yet.');\r
-                        }\r
-                    };\r
-                    return {\r
-                        isSymmetric: opIsSymmetric,\r
-                        isHermitian: opIsHermitian,\r
-                        eye: opEye,\r
-                        hilb: opHilb,\r
-                        diag: opDiag,\r
-                        vander: opVander,\r
-                        tril: opTril,\r
-                        triu: opTriu,\r
-                        matmul: opMatMul,\r
-                        kron: opKron,\r
-                        transpose: opTranspose,\r
-                        hermitian: opHermitian,\r
-                        trace: opTrace,\r
-                        inv: opInv,\r
-                        det: opDet,\r
-                        norm: opNorm,\r
-                        lu: opLu,\r
-                        svd: opSvd,\r
-                        rank: opRank,\r
-                        cond: opCond,\r
-                        pinv: opPinv,\r
-                        eig: opEig,\r
-                        chol: opChol,\r
-                        qr: opQr,\r
-                        linsolve: opLinsolve,\r
-                        mldivide: opMLDivide,\r
-                        mrdivide: opMRDivide,\r
-                        sqrtm: opSqrtm\r
-                    };\r
-                };\r
-                return MatrixOpProviderFactory;\r
-            }());\r
-            exports_53("MatrixOpProviderFactory", MatrixOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/data/datafun", ["jasmal/lib/helper/comparisonHelper"], function (exports_54, context_54) {\r
-    "use strict";\r
-    var __moduleName = context_54 && context_54.id;\r
-    var comparisonHelper_2, DataFunction;\r
-    return {\r
-        setters: [\r
-            function (comparisonHelper_2_1) {\r
-                comparisonHelper_2 = comparisonHelper_2_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            DataFunction = (function () {\r
-                function DataFunction() {\r
-                }\r
-                DataFunction.max = function (x, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(x.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    var max = x[offset], idx = 0, j = 1;\r
-                    for (var i = offset + stride; i < ub; i += stride, j++) {\r
-                        if (x[i] > max) {\r
-                            max = x[i];\r
-                            idx = j;\r
-                        }\r
-                    }\r
-                    return [max, idx];\r
-                    var _a;\r
-                };\r
-                DataFunction.min = function (x, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(x.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    var min = x[offset], idx = 0, j = 1;\r
-                    for (var i = offset + stride; i < ub; i += stride, j++) {\r
-                        if (x[i] < min) {\r
-                            min = x[i];\r
-                            idx = j;\r
-                        }\r
-                    }\r
-                    return [min, idx];\r
-                    var _a;\r
-                };\r
-                DataFunction.sum = function (x, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(x.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    var acc = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        acc += x[i];\r
-                    }\r
-                    return acc;\r
-                    var _a;\r
-                };\r
-                DataFunction.prod = function (x, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(x.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    var acc = 1;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        acc *= x[i];\r
-                        if (acc === 0) {\r
-                            break;\r
-                        }\r
-                    }\r
-                    return acc;\r
-                    var _a;\r
-                };\r
-                DataFunction.cprod = function (reX, imX, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(reX.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    var accRe = 1;\r
-                    var accIm = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        var tmp = accRe;\r
-                        accRe = tmp * reX[i] - accIm * imX[i];\r
-                        accIm = tmp * imX[i] + accIm * reX[i];\r
-                    }\r
-                    return [accRe, accIm];\r
-                    var _a;\r
-                };\r
-                DataFunction.var = function (x, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(x.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    if (n === 1) {\r
-                        return isFinite(x[offset]) ? 0 : NaN;\r
-                    }\r
-                    var u = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        if (!isFinite(x[i])) {\r
-                            return NaN;\r
-                        }\r
-                        u += x[i];\r
-                    }\r
-                    u /= n;\r
-                    var v = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        v += (x[i] - u) * (x[i] - u);\r
-                    }\r
-                    return v / (n - 1);\r
-                    var _a;\r
-                };\r
-                DataFunction.cvar = function (reX, imX, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(reX.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    if (n === 1) {\r
-                        return (isFinite(reX[offset]) && isFinite(imX[offset])) ? 0 : NaN;\r
-                    }\r
-                    var uRe = 0, uIm = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        if (!isFinite(reX[offset]) || !isFinite(imX[offset])) {\r
-                            return NaN;\r
-                        }\r
-                        uRe += reX[i];\r
-                        uIm += imX[i];\r
-                    }\r
-                    uRe /= n;\r
-                    uIm /= n;\r
-                    var v = 0;\r
-                    for (var i = offset; i < ub; i += stride) {\r
-                        v += (reX[i] - uRe) * (reX[i] - uRe) + (imX[i] - uIm) * (imX[i] - uIm);\r
-                    }\r
-                    return v / (n - 1);\r
-                    var _a;\r
-                };\r
-                DataFunction.median = function (reX, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(reX.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    if (n === 1) {\r
-                        return reX[offset];\r
-                    }\r
-                    var arr = new Array(n);\r
-                    for (var i = 0; i < n; i++) {\r
-                        arr[i] = reX[offset + i * stride];\r
-                    }\r
-                    arr.sort(comparisonHelper_2.ComparisonHelper.compareNumberAsc);\r
-                    if (isNaN(arr[n - 1])) {\r
-                        return NaN;\r
-                    }\r
-                    if (n % 2 === 0) {\r
-                        return 0.5 * (arr[n / 2] + arr[n / 2 - 1]);\r
-                    }\r
-                    else {\r
-                        return arr[(n - 1) / 2];\r
-                    }\r
-                    var _a;\r
-                };\r
-                DataFunction.mode = function (reX, offset, stride, n) {\r
-                    if (offset === void 0) { offset = 0; }\r
-                    if (stride === void 0) { stride = 1; }\r
-                    if (n === void 0) { n = -1; }\r
-                    var ub;\r
-                    _a = DataFunction._processArgs(reX.length, offset, stride, n), n = _a[0], ub = _a[1];\r
-                    if (n === 1) {\r
-                        return reX[offset];\r
-                    }\r
-                    var arr = new Array(n);\r
-                    for (var i = 0; i < n; i++) {\r
-                        arr[i] = reX[offset + i * stride];\r
-                    }\r
-                    arr.sort(comparisonHelper_2.ComparisonHelper.compareNumberAsc);\r
-                    var nMax = n - 1;\r
-                    while (nMax >= 0 && isNaN(arr[nMax])) {\r
-                        nMax--;\r
-                    }\r
-                    if (nMax < 0) {\r
-                        return NaN;\r
-                    }\r
-                    var cur = arr[0];\r
-                    var result = cur;\r
-                    var freq = 1;\r
-                    var maxFreq = 1;\r
-                    for (var i = 1; i <= nMax; i++) {\r
-                        if (arr[i] === cur) {\r
-                            freq++;\r
-                        }\r
-                        else {\r
-                            if (freq > maxFreq) {\r
-                                maxFreq = freq;\r
-                                result = cur;\r
-                            }\r
-                            cur = arr[i];\r
-                            freq = 1;\r
-                        }\r
-                    }\r
-                    if (freq > maxFreq) {\r
-                        maxFreq = freq;\r
-                        result = cur;\r
-                    }\r
-                    return result;\r
-                    var _a;\r
-                };\r
-                DataFunction._processArgs = function (arrLength, offset, stride, n) {\r
-                    var ub = n < 0 ? arrLength : offset + n * stride;\r
-                    if (ub >= arrLength + stride) {\r
-                        throw new Error('Maximum index is out of bounds.');\r
-                    }\r
-                    return [n < 0 ? arrLength : n, ub];\r
-                };\r
-                return DataFunction;\r
-            }());\r
-            exports_54("DataFunction", DataFunction);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/data/fft", ["jasmal/lib/math/special"], function (exports_55, context_55) {\r
-    "use strict";\r
-    var __moduleName = context_55 && context_55.id;\r
-    var special_3, FFT;\r
-    return {\r
-        setters: [\r
-            function (special_3_1) {\r
-                special_3 = special_3_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            FFT = (function () {\r
-                function FFT() {\r
-                }\r
-                FFT.FFT = function (re, im, forward) {\r
-                    if (forward === void 0) { forward = true; }\r
-                    var n = re.length;\r
-                    if (im.length !== n) {\r
-                        throw new Error('Real part and imaginary part must have the same length.');\r
-                    }\r
-                    if (!special_3.SpecialFunction.isPowerOfTwoN(n)) {\r
-                        throw new Error('Length must be a power of 2.');\r
-                    }\r
-                    var i, i1, i2, j, k;\r
-                    var tRe, tIm;\r
-                    i2 = n >> 1;\r
-                    j = 0;\r
-                    for (i = 0; i < n - 1; i++) {\r
-                        if (i < j) {\r
-                            tRe = re[i];\r
-                            tIm = im[i];\r
-                            re[i] = re[j];\r
-                            im[i] = im[j];\r
-                            re[j] = tRe;\r
-                            im[j] = tIm;\r
-                        }\r
-                        k = i2;\r
-                        while (k <= j) {\r
-                            j -= k;\r
-                            k >>= 1;\r
-                        }\r
-                        j += k;\r
-                    }\r
-                    var m = 0;\r
-                    k = 1;\r
-                    while (!(n & k)) {\r
-                        m++;\r
-                        k <<= 1;\r
-                    }\r
-                    var l, l1, uRe, uIm, tmp;\r
-                    var c = -1.0;\r
-                    var s = 0.0;\r
-                    var l2 = 1;\r
-                    for (l = 0; l < m; l++) {\r
-                        l1 = l2;\r
-                        l2 <<= 1;\r
-                        uRe = 1.0;\r
-                        uIm = 0.0;\r
-                        for (j = 0; j < l1; j++) {\r
-                            for (i = j; i < n; i += l2) {\r
-                                i1 = i + l1;\r
-                                tRe = uRe * re[i1] - uIm * im[i1];\r
-                                tIm = uRe * im[i1] + uIm * re[i1];\r
-                                re[i1] = re[i] - tRe;\r
-                                im[i1] = im[i] - tIm;\r
-                                re[i] += tRe;\r
-                                im[i] += tIm;\r
-                            }\r
-                            tmp = uRe * c - uIm * s;\r
-                            uIm = uRe * s + uIm * c;\r
-                            uRe = tmp;\r
-                        }\r
-                        s = forward ? -Math.sqrt((1.0 - c) / 2.0) : Math.sqrt((1.0 - c) / 2.0);\r
-                        c = Math.sqrt((1.0 + c) / 2.0);\r
-                    }\r
-                    if (!forward) {\r
-                        var nInv = 1.0 / n;\r
-                        for (i = 0; i < n; i++) {\r
-                            re[i] *= nInv;\r
-                            im[i] *= nInv;\r
-                        }\r
-                    }\r
-                };\r
-                FFT.FFTNoPT = function (_re, _im, _forward) {\r
-                    if (_forward === void 0) { _forward = true; }\r
-                    throw new Error('Not implemented.');\r
-                };\r
-                return FFT;\r
-            }());\r
-            exports_55("FFT", FFT);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/data/index", ["jasmal/lib/tensor", "jasmal/lib/ops/data/datafun", "jasmal/lib/dtype", "jasmal/lib/helper/dataHelper", "jasmal/lib/helper/comparisonHelper", "jasmal/lib/math/special", "jasmal/lib/ops/data/fft"], function (exports_56, context_56) {\r
-    "use strict";\r
-    var __moduleName = context_56 && context_56.id;\r
-    var tensor_10, datafun_1, dtype_15, dataHelper_13, comparisonHelper_3, special_4, fft_1, DataOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_10_1) {\r
-                tensor_10 = tensor_10_1;\r
-            },\r
-            function (datafun_1_1) {\r
-                datafun_1 = datafun_1_1;\r
-            },\r
-            function (dtype_15_1) {\r
-                dtype_15 = dtype_15_1;\r
-            },\r
-            function (dataHelper_13_1) {\r
-                dataHelper_13 = dataHelper_13_1;\r
-            },\r
-            function (comparisonHelper_3_1) {\r
-                comparisonHelper_3 = comparisonHelper_3_1;\r
-            },\r
-            function (special_4_1) {\r
-                special_4 = special_4_1;\r
-            },\r
-            function (fft_1_1) {\r
-                fft_1 = fft_1_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            DataOpProviderFactory = (function () {\r
-                function DataOpProviderFactory() {\r
-                }\r
-                DataOpProviderFactory.create = function (coreOp, arithOp, mathOp, matOp, reductionOpGen) {\r
-                    var opMin = reductionOpGen.makeRealOnlyOpWithIndexOutput(datafun_1.DataFunction.min, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uOnlyLogicToFloat });\r
-                    var opMax = reductionOpGen.makeRealOnlyOpWithIndexOutput(datafun_1.DataFunction.max, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uOnlyLogicToFloat });\r
-                    var opSum = reductionOpGen.makeOp(datafun_1.DataFunction.sum, function (reX, imX, offset, stride, n) {\r
-                        return [datafun_1.DataFunction.sum(reX, offset, stride, n),\r
-                            datafun_1.DataFunction.sum(imX, offset, stride, n)];\r
-                    }, true, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uOnlyLogicToFloat });\r
-                    var opProd = reductionOpGen.makeOp(datafun_1.DataFunction.prod, datafun_1.DataFunction.cprod, true, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uOnlyLogicToFloat });\r
-                    var opMean = reductionOpGen.makeOp(function (reX, offset, stride, n) {\r
-                        return datafun_1.DataFunction.sum(reX, offset, stride, n) / n;\r
-                    }, function (reX, imX, offset, stride, n) {\r
-                        return [datafun_1.DataFunction.sum(reX, offset, stride, n) / n,\r
-                            datafun_1.DataFunction.sum(imX, offset, stride, n) / n];\r
-                    }, true, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uToFloat });\r
-                    var opMedian = reductionOpGen.makeRealOnlyOp(datafun_1.DataFunction.median, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uToFloat });\r
-                    var opMode = reductionOpGen.makeRealOnlyOp(datafun_1.DataFunction.mode, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uNoChange });\r
-                    var opVar = reductionOpGen.makeOp(datafun_1.DataFunction.var, datafun_1.DataFunction.cvar, false, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uToFloat });\r
-                    var opStd = reductionOpGen.makeOp(function (reX, offset, stride, n) {\r
-                        return Math.sqrt(datafun_1.DataFunction.var(reX, offset, stride, n));\r
-                    }, function (reX, imX, offset, stride, n) {\r
-                        return Math.sqrt(datafun_1.DataFunction.cvar(reX, imX, offset, stride, n));\r
-                    }, false, { outputDTypeResolver: dtype_15.OutputDTypeResolver.uToFloat });\r
-                    var opCumsum = function (x, axis) {\r
-                        if (axis === void 0) { axis = -1; }\r
-                        var X = x instanceof tensor_10.Tensor ? x.copy(true) : tensor_10.Tensor.toTensor(x);\r
-                        if (axis < 0 || (axis === 0 && X.ndim === 1)) {\r
-                            var re = X.realData;\r
-                            for (var i = 1; i < re.length; i++) {\r
-                                re[i] += re[i - 1];\r
-                            }\r
-                            if (X.hasComplexStorage()) {\r
-                                var im = X.imagData;\r
-                                for (var i = 1; i < im.length; i++) {\r
-                                    im[i] += im[i - 1];\r
-                                }\r
-                            }\r
-                            X.reshape([-1]);\r
-                        }\r
-                        else {\r
-                            if (axis >= X.ndim) {\r
-                                throw new Error("Invalid axis number " + axis + ".");\r
-                            }\r
-                            var shape_1 = X.shape;\r
-                            var n = shape_1[axis];\r
-                            if (n !== 1) {\r
-                                var strides_1 = X.strides;\r
-                                var stride_1 = strides_1[axis];\r
-                                var maxLevel_2 = X.ndim - 1;\r
-                                var doCumsum_1 = function (data, level, offset) {\r
-                                    if (level === maxLevel_2) {\r
-                                        for (var i = level === axis ? 1 : 0; i < shape_1[level]; i++) {\r
-                                            data[offset + i] += data[offset + i - stride_1];\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        var i = void 0;\r
-                                        if (level === axis) {\r
-                                            i = 1;\r
-                                            offset += strides_1[level];\r
-                                        }\r
-                                        else {\r
-                                            i = 0;\r
-                                        }\r
-                                        for (; i < shape_1[level]; i++) {\r
-                                            doCumsum_1(data, level + 1, offset);\r
-                                            offset += strides_1[level];\r
-                                        }\r
-                                    }\r
-                                };\r
-                                doCumsum_1(X.realData, 0, 0);\r
-                                if (X.hasComplexStorage()) {\r
-                                    doCumsum_1(X.imagData, 0, 0);\r
-                                }\r
-                            }\r
-                        }\r
-                        return X;\r
-                    };\r
-                    var opCov = function (x, y, samplesInColumns) {\r
-                        if (y === void 0) { y = x; }\r
-                        if (samplesInColumns === void 0) { samplesInColumns = true; }\r
-                        var X = x instanceof tensor_10.Tensor ? x : tensor_10.Tensor.toTensor(x);\r
-                        if (X.ndim === 1) {\r
-                            X = coreOp.prependAxis(X);\r
-                        }\r
-                        else if (X.ndim > 2) {\r
-                            throw new Error('Input must be either 1D or 2D.');\r
-                        }\r
-                        var axis = samplesInColumns ? 1 : 0;\r
-                        var n = X.shape[axis];\r
-                        var mX = opMean(X, axis, true);\r
-                        var xM = arithOp.sub(X, mX);\r
-                        if (y === x) {\r
-                            if (samplesInColumns) {\r
-                                return arithOp.div(matOp.matmul(xM, xM, 2), n - 1);\r
-                            }\r
-                            else {\r
-                                xM = mathOp.conj(xM, true);\r
-                                return arithOp.div(matOp.matmul(matOp.hermitian(xM), xM), n - 1);\r
-                            }\r
-                        }\r
-                        else {\r
-                            var Y = y instanceof tensor_10.Tensor ? y : tensor_10.Tensor.toTensor(y);\r
-                            if (Y.ndim === 1) {\r
-                                Y = coreOp.prependAxis(X);\r
-                            }\r
-                            else if (Y.ndim > 2) {\r
-                                throw new Error('Input must be either 1D or 2D.');\r
-                            }\r
-                            if (Y.shape[axis] !== n) {\r
-                                throw new Error('x and y must share the same number of samples.');\r
-                            }\r
-                            var mY = opMean(Y, axis, true);\r
-                            var yM = arithOp.sub(Y, mY);\r
-                            if (samplesInColumns) {\r
-                                return arithOp.div(matOp.matmul(xM, yM, 2), n - 1);\r
-                            }\r
-                            else {\r
-                                yM = mathOp.conj(yM, true);\r
-                                return arithOp.div(matOp.matmul(matOp.hermitian(xM), yM), n - 1);\r
-                            }\r
-                        }\r
-                    };\r
-                    var opCorrcoef = function (x, y, samplesInColumns) {\r
-                        if (y === void 0) { y = x; }\r
-                        if (samplesInColumns === void 0) { samplesInColumns = true; }\r
-                        var auto = x === y;\r
-                        var X = x instanceof tensor_10.Tensor ? x : tensor_10.Tensor.toTensor(x);\r
-                        var Y = auto ? X : (y instanceof tensor_10.Tensor ? y : tensor_10.Tensor.toTensor(y));\r
-                        var C = opCov(X, Y, samplesInColumns);\r
-                        if (auto) {\r
-                            var v = matOp.diag(C).trimImaginaryPart();\r
-                            v = mathOp.sqrt(v, true);\r
-                            arithOp.div(C, v, true);\r
-                            arithOp.div(C, coreOp.appendAxis(v), true);\r
-                        }\r
-                        else {\r
-                            var axis = samplesInColumns ? 1 : 0;\r
-                            var stdX = opStd(X, axis);\r
-                            var stdY = opStd(Y, axis);\r
-                            arithOp.div(C, coreOp.appendAxis(stdX), true);\r
-                            arithOp.div(C, coreOp.prependAxis(stdY), true);\r
-                        }\r
-                        return C;\r
-                    };\r
-                    var opFFTFB = function (x, forward, axis) {\r
-                        if (forward === void 0) { forward = true; }\r
-                        if (axis === void 0) { axis = -1; }\r
-                        var X = x instanceof tensor_10.Tensor ? x.asType(3, true) : tensor_10.Tensor.toTensor(x);\r
-                        X.ensureComplexStorage();\r
-                        if (axis < 0 || (axis === 0 && X.ndim === 1)) {\r
-                            if (special_4.SpecialFunction.isPowerOfTwoN(X.size)) {\r
-                                fft_1.FFT.FFT(X.realData, X.imagData, forward);\r
-                            }\r
-                            else {\r
-                                fft_1.FFT.FFTNoPT(X.realData, X.imagData, forward);\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (axis >= X.ndim) {\r
-                                throw new Error("Invalid axis number " + axis + ".");\r
-                            }\r
-                            var shapeX_1 = X.shape;\r
-                            var n_1 = shapeX_1[axis];\r
-                            var FFTFunc_1 = special_4.SpecialFunction.isPowerOfTwoN(n_1) ? fft_1.FFT.FFT : fft_1.FFT.FFTNoPT;\r
-                            var tmpReArr_1 = dataHelper_13.DataHelper.allocateFloat64Array(n_1);\r
-                            var tmpImArr_1 = dataHelper_13.DataHelper.allocateFloat64Array(n_1);\r
-                            var strides_2 = X.strides;\r
-                            var strideAtAxis_1 = strides_2[axis];\r
-                            var maxLevel_3 = X.ndim - 1;\r
-                            var doFFT_1 = function (re, im, level, offset) {\r
-                                if (level === maxLevel_3) {\r
-                                    for (var i = 0; i < shapeX_1[level]; i++) {\r
-                                        for (var k = 0; k < n_1; k++) {\r
-                                            tmpReArr_1[k] = re[strideAtAxis_1 * k + offset];\r
-                                            tmpImArr_1[k] = im[strideAtAxis_1 * k + offset];\r
-                                        }\r
-                                        FFTFunc_1(tmpReArr_1, tmpImArr_1, forward);\r
-                                        for (var k = 0; k < n_1; k++) {\r
-                                            re[strideAtAxis_1 * k + offset] = tmpReArr_1[k];\r
-                                            im[strideAtAxis_1 * k + offset] = tmpImArr_1[k];\r
-                                        }\r
-                                        offset++;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    var maxI = level === axis ? 1 : shapeX_1[level];\r
-                                    for (var i = 0; i < maxI; i++) {\r
-                                        doFFT_1(re, im, level + 1, offset);\r
-                                        offset += strides_2[level];\r
-                                    }\r
-                                }\r
-                            };\r
-                            doFFT_1(X.realData, X.imagData, 0, 0);\r
-                        }\r
-                        return X;\r
-                    };\r
-                    var opFFT = function (x, axis) {\r
-                        if (axis === void 0) { axis = -1; }\r
-                        return opFFTFB(x, true, axis);\r
-                    };\r
-                    var opIFFT = function (x, axis) {\r
-                        if (axis === void 0) { axis = -1; }\r
-                        return opFFTFB(x, false, axis);\r
-                    };\r
-                    function opSort(x, dir, outputIndices) {\r
-                        var X = x instanceof tensor_10.Tensor ? x : tensor_10.Tensor.toTensor(x);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            throw new Error('Sorting complex elements is not supported.');\r
-                        }\r
-                        var n = X.size;\r
-                        var Y = tensor_10.Tensor.zeros([n]);\r
-                        var dataX = X.realData, dataY = Y.realData;\r
-                        var indices = dataHelper_13.DataHelper.naturalNumbers(n);\r
-                        var comparator = comparisonHelper_3.ComparisonHelper.compareNumberWithIndexAsc;\r
-                        if (dir === 'asc') {\r
-                            indices.sort(function (ia, ib) { return comparator(dataX[ia], dataX[ib], ia, ib); });\r
-                        }\r
-                        else {\r
-                            indices.sort(function (ia, ib) { return comparator(dataX[ib], dataX[ia], ia, ib); });\r
-                        }\r
-                        for (var i = 0; i < n; i++) {\r
-                            dataY[i] = dataX[indices[i]];\r
-                        }\r
-                        return outputIndices ? [Y, indices] : Y;\r
-                    }\r
-                    function opSortRows(x, dir, outputIndices) {\r
-                        var X = x instanceof tensor_10.Tensor ? x : tensor_10.Tensor.toTensor(x);\r
-                        if (X.ndim !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            throw new Error('Sorting complex elements is not supported.');\r
-                        }\r
-                        var dataX = X.realData;\r
-                        var _a = X.shape, m = _a[0], n = _a[1];\r
-                        var indices = dataHelper_13.DataHelper.naturalNumbers(m);\r
-                        var comparator = dir === 'asc' ? comparisonHelper_3.ComparisonHelper.compareNumberAsc : comparisonHelper_3.ComparisonHelper.compareNumberDesc;\r
-                        indices.sort(function (ia, ib) {\r
-                            for (var j = 0; j < n; j++) {\r
-                                var cur = comparator(dataX[ia * n + j], dataX[ib * n + j]);\r
-                                if (cur !== 0) {\r
-                                    return cur;\r
-                                }\r
-                            }\r
-                            return (ia > ib) ? 1 : -1;\r
-                        });\r
-                        var Y = X.get(indices, ':', true);\r
-                        return outputIndices ? [Y, indices] : Y;\r
-                    }\r
-                    function findBinIndex(x, edges) {\r
-                        if (edges.length < 2) {\r
-                            throw new Error('Number of edges must be at least 2.');\r
-                        }\r
-                        if (x >= edges[edges.length - 1]) {\r
-                            return edges.length - 2;\r
-                        }\r
-                        var l = 0, u = edges.length - 1;\r
-                        var i;\r
-                        while (u - l > 1) {\r
-                            i = (l + u) >>> 1;\r
-                            if (x < edges[i]) {\r
-                                u = i;\r
-                            }\r
-                            else if (x > edges[i]) {\r
-                                l = i;\r
-                            }\r
-                            else {\r
-                                return i;\r
-                            }\r
-                        }\r
-                        return l;\r
-                    }\r
-                    var opHist = function (x, nBins) {\r
-                        if (nBins === void 0) { nBins = 10; }\r
-                        var X = x instanceof tensor_10.Tensor ? x : tensor_10.Tensor.toTensor(x);\r
-                        if (X.hasNonZeroComplexStorage()) {\r
-                            throw new Error('Input must be real.');\r
-                        }\r
-                        if (nBins <= 0 || Math.floor(nBins) !== nBins) {\r
-                            throw new Error('Number of bins must be a positive integer.');\r
-                        }\r
-                        var i;\r
-                        var data = X.realData;\r
-                        var lb = Infinity;\r
-                        var ub = -Infinity;\r
-                        var nNegInf = 0;\r
-                        var nPosInf = 0;\r
-                        var nNaN = 0;\r
-                        for (i = 0; i < data.length; i++) {\r
-                            if (isNaN(data[i])) {\r
-                                nNaN++;\r
-                                continue;\r
-                            }\r
-                            if (isFinite(data[i])) {\r
-                                if (data[i] < lb) {\r
-                                    lb = data[i];\r
-                                }\r
-                                if (data[i] > ub) {\r
-                                    ub = data[i];\r
-                                }\r
-                            }\r
-                            else {\r
-                                if (data[i] < 0) {\r
-                                    nNegInf++;\r
-                                }\r
-                                else {\r
-                                    nPosInf++;\r
-                                }\r
-                            }\r
-                        }\r
-                        if (lb === Infinity && ub === -Infinity) {\r
-                            throw new Error('None of the element is finite.');\r
-                        }\r
-                        var H = tensor_10.Tensor.zeros([nBins]);\r
-                        var h = H.realData;\r
-                        var E;\r
-                        var edges;\r
-                        if (lb === ub) {\r
-                            E = tensor_10.Tensor.zeros([nBins + 1]);\r
-                            edges = E.realData;\r
-                            var idxM = (nBins - 1) >>> 1;\r
-                            var edgeM = Math.floor(lb);\r
-                            for (i = 0; i <= nBins; i++) {\r
-                                edges[i] = edgeM - idxM + i;\r
-                            }\r
-                            h[idxM] = data.length - nNegInf - nPosInf - nNaN;\r
-                        }\r
-                        else {\r
-                            E = coreOp.linspace(lb, ub, nBins + 1);\r
-                            edges = E.realData;\r
-                            for (i = 0; i < data.length; i++) {\r
-                                if (isFinite(data[i])) {\r
-                                    h[findBinIndex(data[i], edges)]++;\r
-                                }\r
-                            }\r
-                        }\r
-                        h[0] += nNegInf;\r
-                        h[nBins - 1] += nPosInf;\r
-                        return [H, E];\r
-                    };\r
-                    return {\r
-                        min: opMin,\r
-                        max: opMax,\r
-                        sum: opSum,\r
-                        prod: opProd,\r
-                        cumsum: opCumsum,\r
-                        mean: opMean,\r
-                        median: opMedian,\r
-                        mode: opMode,\r
-                        std: opStd,\r
-                        var: opVar,\r
-                        cov: opCov,\r
-                        corrcoef: opCorrcoef,\r
-                        sort: opSort,\r
-                        sortRows: opSortRows,\r
-                        hist: opHist,\r
-                        fft: opFFT,\r
-                        ifft: opIFFT\r
-                    };\r
-                };\r
-                return DataOpProviderFactory;\r
-            }());\r
-            exports_56("DataOpProviderFactory", DataOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/poly/polyfun", [], function (exports_57, context_57) {\r
-    "use strict";\r
-    var __moduleName = context_57 && context_57.id;\r
-    var PolynomialEvaluator;\r
-    return {\r
-        setters: [],\r
-        execute: function () {\r
-            PolynomialEvaluator = (function () {\r
-                function PolynomialEvaluator() {\r
-                }\r
-                PolynomialEvaluator.evalPolyRR = function (p, x) {\r
-                    if (p.length === 0) {\r
-                        return 0;\r
-                    }\r
-                    var acc = p[0];\r
-                    for (var i = 1; i < p.length; i++) {\r
-                        acc = acc * x + p[i];\r
-                    }\r
-                    return acc;\r
-                };\r
-                PolynomialEvaluator.evalPolyRC = function (p, reX, imX) {\r
-                    if (p.length === 0) {\r
-                        return [0, 0];\r
-                    }\r
-                    var accRe = p[0];\r
-                    var accIm = 0;\r
-                    var tmp;\r
-                    for (var i = 1; i < p.length; i++) {\r
-                        tmp = accRe;\r
-                        accRe = accRe * reX - accIm * imX;\r
-                        accIm = tmp * imX + accIm * reX;\r
-                        accRe += p[i];\r
-                    }\r
-                    return [accRe, accIm];\r
-                };\r
-                PolynomialEvaluator.evalPolyCR = function (reP, imP, x) {\r
-                    return [PolynomialEvaluator.evalPolyRR(reP, x), PolynomialEvaluator.evalPolyRR(imP, x)];\r
-                };\r
-                PolynomialEvaluator.evalPolyCC = function (reP, imP, reX, imX) {\r
-                    if (reP.length === 0) {\r
-                        return [0, 0];\r
-                    }\r
-                    var accRe = reP[0];\r
-                    var accIm = imP[0];\r
-                    var tmp;\r
-                    for (var i = 1; i < reP.length; i++) {\r
-                        tmp = accRe;\r
-                        accRe = accRe * reX - accIm * imX;\r
-                        accIm = tmp * imX + accIm * reX;\r
-                        accRe += reP[i];\r
-                        accIm += imP[i];\r
-                    }\r
-                    return [accRe, accIm];\r
-                };\r
-                return PolynomialEvaluator;\r
-            }());\r
-            exports_57("PolynomialEvaluator", PolynomialEvaluator);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/poly/index", ["jasmal/lib/tensor", "jasmal/lib/dtype", "jasmal/lib/ops/poly/polyfun", "jasmal/lib/complexNumber", "jasmal/lib/math/cmath", "jasmal/lib/helper/dataHelper"], function (exports_58, context_58) {\r
-    "use strict";\r
-    var __moduleName = context_58 && context_58.id;\r
-    var tensor_11, dtype_16, polyfun_1, complexNumber_7, cmath_10, dataHelper_14, PolynomialOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_11_1) {\r
-                tensor_11 = tensor_11_1;\r
-            },\r
-            function (dtype_16_1) {\r
-                dtype_16 = dtype_16_1;\r
-            },\r
-            function (polyfun_1_1) {\r
-                polyfun_1 = polyfun_1_1;\r
-            },\r
-            function (complexNumber_7_1) {\r
-                complexNumber_7 = complexNumber_7_1;\r
-            },\r
-            function (cmath_10_1) {\r
-                cmath_10 = cmath_10_1;\r
-            },\r
-            function (dataHelper_14_1) {\r
-                dataHelper_14 = dataHelper_14_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            PolynomialOpProviderFactory = (function () {\r
-                function PolynomialOpProviderFactory() {\r
-                }\r
-                PolynomialOpProviderFactory.create = function (coreOp, matOp) {\r
-                    var opPolyval = function (p, x, inPlace) {\r
-                        if (inPlace === void 0) { inPlace = false; }\r
-                        var infoP = tensor_11.Tensor.analyzeOpInput(p);\r
-                        if (infoP.originalShape.length !== 1) {\r
-                            throw new Error('Vector expected for p.');\r
-                        }\r
-                        var infoX = tensor_11.Tensor.analyzeOpInput(x);\r
-                        if (infoP.isInputScalar) {\r
-                            infoP.reArr = [infoP.re];\r
-                            infoP.imArr = [infoP.im];\r
-                        }\r
-                        var reP = infoP.reArr, imP = infoP.imArr;\r
-                        if (infoX.isInputScalar) {\r
-                            var re = void 0, im = 0;\r
-                            if (infoP.isComplex) {\r
-                                if (infoX.isComplex) {\r
-                                    _a = polyfun_1.PolynomialEvaluator.evalPolyCC(reP, imP, infoX.re, infoX.im), re = _a[0], im = _a[1];\r
-                                }\r
-                                else {\r
-                                    _b = polyfun_1.PolynomialEvaluator.evalPolyCR(reP, imP, infoX.re), re = _b[0], im = _b[1];\r
-                                }\r
-                            }\r
-                            else {\r
-                                if (infoX.isComplex) {\r
-                                    _c = polyfun_1.PolynomialEvaluator.evalPolyRC(reP, infoX.re, infoX.im), re = _c[0], im = _c[1];\r
-                                }\r
-                                else {\r
-                                    re = polyfun_1.PolynomialEvaluator.evalPolyRR(reP, infoX.re);\r
-                                }\r
-                            }\r
-                            return im === 0 ? re : new complexNumber_7.ComplexNumber(re, im);\r
-                        }\r
-                        else {\r
-                            var outputDType = dtype_16.OutputDTypeResolver.bWiderWithLogicToInt(infoP.originalDType, infoP.isComplex, infoX.originalDType, infoX.isComplex);\r
-                            var Y = void 0;\r
-                            if (inPlace) {\r
-                                if (infoX.originalType !== 3) {\r
-                                    throw new Error('Cannot perform in-place operations when the operand is not a tensor.');\r
-                                }\r
-                                else if (dtype_16.DTypeHelper.isWiderType(outputDType, infoX.originalDType)) {\r
-                                    throw new Error('Cannot perform in-place operations because the output data type is incompatible.');\r
-                                }\r
-                                Y = x;\r
-                                Y.ensureUnsharedLocalStorage();\r
-                            }\r
-                            else {\r
-                                Y = tensor_11.Tensor.zeros(infoX.originalShape, outputDType);\r
-                            }\r
-                            var reX = infoX.reArr;\r
-                            var imX = void 0;\r
-                            var reY = Y.realData;\r
-                            var imY = void 0;\r
-                            var i = void 0, n = Y.size;\r
-                            if (infoP.isComplex) {\r
-                                Y.ensureComplexStorage();\r
-                                imY = Y.imagData;\r
-                                if (infoX.isComplex) {\r
-                                    imX = infoX.imArr;\r
-                                    for (i = 0; i < n; i++) {\r
-                                        _d = polyfun_1.PolynomialEvaluator.evalPolyCC(reP, imP, reX[i], imX[i]), reY[i] = _d[0], imY[i] = _d[1];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (i = 0; i < n; i++) {\r
-                                        _e = polyfun_1.PolynomialEvaluator.evalPolyCR(reP, imP, reX[i]), reY[i] = _e[0], imY[i] = _e[1];\r
-                                    }\r
-                                }\r
-                            }\r
-                            else {\r
-                                if (infoX.isComplex) {\r
-                                    imX = infoX.imArr;\r
-                                    Y.ensureComplexStorage();\r
-                                    imY = Y.imagData;\r
-                                    for (i = 0; i < n; i++) {\r
-                                        _f = polyfun_1.PolynomialEvaluator.evalPolyRC(reP, reX[i], imX[i]), reY[i] = _f[0], imY[i] = _f[1];\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    for (i = 0; i < n; i++) {\r
-                                        reY[i] = polyfun_1.PolynomialEvaluator.evalPolyRR(reP, reX[i]);\r
-                                    }\r
-                                }\r
-                            }\r
-                            return Y;\r
-                        }\r
-                        var _a, _b, _c, _d, _e, _f;\r
-                    };\r
-                    var opPolyvalm = function (p, x) {\r
-                        if (typeof x === 'number' || x instanceof complexNumber_7.ComplexNumber) {\r
-                            return opPolyval(p, x);\r
-                        }\r
-                        var X = x instanceof tensor_11.Tensor ? x : tensor_11.Tensor.toTensor(x);\r
-                        if (X.ndim !== 2) {\r
-                            throw new Error('Matrix expected.');\r
-                        }\r
-                        var _a = X.shape, m = _a[0], n = _a[1];\r
-                        if (m !== n) {\r
-                            throw new Error('Square matrix expected.');\r
-                        }\r
-                        var isXComplex = X.hasNonZeroComplexStorage();\r
-                        var infoP = tensor_11.Tensor.analyzeOpInput(p);\r
-                        if (infoP.originalShape.length !== 1) {\r
-                            throw new Error('Vector expected.');\r
-                        }\r
-                        if (infoP.isInputScalar) {\r
-                            infoP.reArr = [infoP.re];\r
-                            infoP.imArr = [infoP.im];\r
-                        }\r
-                        var outputDType = dtype_16.OutputDTypeResolver.bWiderWithLogicToInt(infoP.originalDType, infoP.isComplex, X.dtype, isXComplex);\r
-                        var Y = tensor_11.Tensor.zeros([m, m], outputDType);\r
-                        var i, k;\r
-                        var reY = Y.realData;\r
-                        var imY = [];\r
-                        for (k = 0; k < m; k++) {\r
-                            reY[k * m + k] = infoP.reArr[0];\r
-                        }\r
-                        if (infoP.isComplex) {\r
-                            Y.ensureComplexStorage();\r
-                            imY = Y.imagData;\r
-                            for (k = 0; k < m; k++) {\r
-                                imY[k * m + k] = infoP.imArr[0];\r
-                            }\r
-                        }\r
-                        for (i = 1; i < infoP.reArr.length; i++) {\r
-                            Y = matOp.matmul(Y, x);\r
-                            reY = Y.realData;\r
-                            for (k = 0; k < m; k++) {\r
-                                reY[k * m + k] += infoP.reArr[i];\r
-                            }\r
-                            if (infoP.isComplex) {\r
-                                Y.ensureComplexStorage();\r
-                                imY = Y.imagData;\r
-                                for (k = 0; k < m; k++) {\r
-                                    imY[k * m + k] += infoP.imArr[i];\r
-                                }\r
-                            }\r
-                        }\r
-                        return Y;\r
-                    };\r
-                    var opPolyfit = function (x, y, n) {\r
-                        var X = x instanceof tensor_11.Tensor ? x : tensor_11.Tensor.toTensor(x);\r
-                        var Y = y instanceof tensor_11.Tensor ? y : tensor_11.Tensor.toTensor(y);\r
-                        if (X.size !== Y.size) {\r
-                            throw new Error('x and y must have the same size.');\r
-                        }\r
-                        return matOp.linsolve(matOp.vander(X, n + 1), Y).reshape([-1]);\r
-                    };\r
-                    var opRoots = function (p) {\r
-                        var P = p instanceof tensor_11.Tensor ? p : tensor_11.Tensor.toTensor(p);\r
-                        if (P.ndim > 1) {\r
-                            throw new Error('Vector expected.');\r
-                        }\r
-                        if (!dataHelper_14.DataHelper.isArrayAllFinite(P.realData) || (P.hasComplexStorage() && !dataHelper_14.DataHelper.isArrayAllFinite(P.imagData))) {\r
-                            throw new Error('Coefficients cannot contain NaN or Infinity.');\r
-                        }\r
-                        var idxNonZero = coreOp.find(P);\r
-                        if (idxNonZero.length === 0) {\r
-                            throw new Error('Coefficients cannot be all zeros.');\r
-                        }\r
-                        var nDeg = P.size - 1;\r
-                        var nTrailingZeros = nDeg - idxNonZero[idxNonZero.length - 1];\r
-                        if (idxNonZero.length === 1) {\r
-                            if (nTrailingZeros === 0) {\r
-                                throw new Error('The effective degree must be at least one.');\r
-                            }\r
-                            else {\r
-                                return tensor_11.Tensor.zeros([nTrailingZeros]);\r
-                            }\r
-                        }\r
-                        nDeg = nDeg - idxNonZero[0] - nTrailingZeros;\r
-                        P = P.get(idxNonZero[0] + ":" + (idxNonZero[idxNonZero.length - 1] + 1));\r
-                        var res;\r
-                        if (P.size === 2) {\r
-                            if (P.hasNonZeroComplexStorage()) {\r
-                                var _a = cmath_10.CMath.cdivCC(-P.realData[1], -P.imagData[1], P.realData[0], P.imagData[0]), re = _a[0], im = _a[1];\r
-                                res = tensor_11.Tensor.scalar(re, im);\r
-                            }\r
-                            else {\r
-                                res = tensor_11.Tensor.scalar(-P.realData[1] / P.realData[0]);\r
-                            }\r
-                        }\r
-                        else {\r
-                            var A = tensor_11.Tensor.zeros([nDeg, nDeg]);\r
-                            var reA = A.realData;\r
-                            var reP = P.realData;\r
-                            var i = void 0;\r
-                            if (P.hasNonZeroComplexStorage()) {\r
-                                A.ensureComplexStorage();\r
-                                var imA = A.imagData;\r
-                                var imP = P.imagData;\r
-                                for (i = 0; i < nDeg; i++) {\r
-                                    _b = cmath_10.CMath.cdivCC(-reP[i + 1], -imP[i + 1], reP[0], imP[0]), reA[i] = _b[0], imA[i] = _b[1];\r
-                                }\r
-                            }\r
-                            else {\r
-                                for (i = 0; i < nDeg; i++) {\r
-                                    reA[i] = -reP[i + 1] / reP[0];\r
-                                }\r
-                            }\r
-                            for (i = 1; i < nDeg; i++) {\r
-                                reA[i * nDeg + i - 1] = 1;\r
-                            }\r
-                            res = matOp.eig(A, true);\r
-                        }\r
-                        return nTrailingZeros > 0 ? coreOp.concat([tensor_11.Tensor.zeros([nTrailingZeros]), res]) : res;\r
-                        var _b;\r
-                    };\r
-                    return {\r
-                        polyval: opPolyval,\r
-                        polyvalm: opPolyvalm,\r
-                        polyfit: opPolyfit,\r
-                        roots: opRoots\r
-                    };\r
-                };\r
-                return PolynomialOpProviderFactory;\r
-            }());\r
-            exports_58("PolynomialOpProviderFactory", PolynomialOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/ops/set/index", ["jasmal/lib/tensor", "jasmal/lib/helper/dataHelper", "jasmal/lib/helper/comparisonHelper", "jasmal/lib/dtype"], function (exports_59, context_59) {\r
-    "use strict";\r
-    var __moduleName = context_59 && context_59.id;\r
-    var tensor_12, dataHelper_15, comparisonHelper_4, dtype_17, SetOpProviderFactory;\r
-    return {\r
-        setters: [\r
-            function (tensor_12_1) {\r
-                tensor_12 = tensor_12_1;\r
-            },\r
-            function (dataHelper_15_1) {\r
-                dataHelper_15 = dataHelper_15_1;\r
-            },\r
-            function (comparisonHelper_4_1) {\r
-                comparisonHelper_4 = comparisonHelper_4_1;\r
-            },\r
-            function (dtype_17_1) {\r
-                dtype_17 = dtype_17_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            SetOpProviderFactory = (function () {\r
-                function SetOpProviderFactory() {\r
-                }\r
-                SetOpProviderFactory.create = function (coreOp, logicCompOp) {\r
-                    function opUniqueInternal(infoX, outputIndices) {\r
-                        if (!infoX.isInputScalar && infoX.reArr.length === 0) {\r
-                            var empty = tensor_12.Tensor.zeros([0], infoX.originalDType);\r
-                            return outputIndices ? [empty, [], []] : [empty, []];\r
-                        }\r
-                        var dataRe = infoX.isInputScalar ? [infoX.re] : infoX.reArr;\r
-                        var dataIm;\r
-                        var n = dataRe.length;\r
-                        var indices = dataHelper_15.DataHelper.naturalNumbers(n);\r
-                        var ix = [];\r
-                        var iy = [];\r
-                        var i, last, k;\r
-                        var curRe, curIm, newRe, newIm;\r
-                        var uniqueRe;\r
-                        var uniqueIm;\r
-                        var Y;\r
-                        if (infoX.isComplex) {\r
-                            dataIm = infoX.isInputScalar ? [infoX.im] : infoX.imArr;\r
-                            indices.sort(function (ia, ib) {\r
-                                var a = dataRe[ia], b = dataRe[ib];\r
-                                var reOrder;\r
-                                if (isNaN(a)) {\r
-                                    reOrder = isNaN(b) ? 0 : 1;\r
-                                }\r
-                                else {\r
-                                    if (isNaN(b)) {\r
-                                        reOrder = -1;\r
-                                    }\r
-                                    else {\r
-                                        reOrder = a > b ? 1 : (a === b ? 0 : -1);\r
-                                    }\r
-                                }\r
-                                return reOrder !== 0 ? reOrder : comparisonHelper_4.ComparisonHelper.compareNumberWithIndexAsc(dataIm[ia], dataIm[ib], ia, ib);\r
-                            });\r
-                            last = 0;\r
-                            k = indices[0];\r
-                            curRe = dataRe[k];\r
-                            curIm = dataIm[k];\r
-                            for (i = 1; i < n; i++) {\r
-                                newRe = dataRe[indices[i]];\r
-                                newIm = dataIm[indices[i]];\r
-                                if (newRe !== curRe || newIm !== curIm) {\r
-                                    curRe = newRe;\r
-                                    curIm = newIm;\r
-                                    iy.push(k);\r
-                                    k = indices[i];\r
-                                    if (outputIndices) {\r
-                                        ix.push(indices.slice(last, i));\r
-                                        last = i;\r
-                                    }\r
-                                }\r
-                            }\r
-                            iy.push(k);\r
-                            if (outputIndices) {\r
-                                ix.push(indices.slice(last, i));\r
-                            }\r
-                            Y = tensor_12.Tensor.zeros([iy.length], infoX.originalDType).ensureComplexStorage();\r
-                            uniqueRe = Y.realData;\r
-                            uniqueIm = Y.imagData;\r
-                            for (i = 0; i < uniqueRe.length; i++) {\r
-                                uniqueRe[i] = dataRe[iy[i]];\r
-                                uniqueIm[i] = dataIm[iy[i]];\r
-                            }\r
-                        }\r
-                        else {\r
-                            indices.sort(function (ia, ib) { return comparisonHelper_4.ComparisonHelper.compareNumberWithIndexAsc(dataRe[ia], dataRe[ib], ia, ib); });\r
-                            last = 0;\r
-                            k = indices[0];\r
-                            curRe = dataRe[k];\r
-                            for (i = 1; i < n; i++) {\r
-                                newRe = dataRe[indices[i]];\r
-                                if (newRe !== curRe) {\r
-                                    curRe = newRe;\r
-                                    iy.push(k);\r
-                                    k = indices[i];\r
-                                    if (outputIndices) {\r
-                                        ix.push(indices.slice(last, i));\r
-                                        last = i;\r
-                                    }\r
-                                }\r
-                            }\r
-                            iy.push(k);\r
-                            if (outputIndices) {\r
-                                ix.push(indices.slice(last, i));\r
-                            }\r
-                            Y = tensor_12.Tensor.zeros([iy.length], infoX.originalDType);\r
-                            uniqueRe = Y.realData;\r
-                            for (i = 0; i < uniqueRe.length; i++) {\r
-                                uniqueRe[i] = dataRe[iy[i]];\r
-                            }\r
-                        }\r
-                        return outputIndices ? [Y, iy, ix] : [Y, iy];\r
-                    }\r
-                    ;\r
-                    function opUnique(x, outputIndices) {\r
-                        if (outputIndices === void 0) { outputIndices = false; }\r
-                        var infoX = tensor_12.Tensor.analyzeOpInput(x);\r
-                        return outputIndices ? opUniqueInternal(infoX, true) : opUniqueInternal(infoX, false)[0];\r
-                    }\r
-                    ;\r
-                    function opIsIn(x, y, outputIndices) {\r
-                        if (outputIndices === void 0) { outputIndices = false; }\r
-                        var infoX = tensor_12.Tensor.analyzeOpInput(x);\r
-                        var infoY = tensor_12.Tensor.analyzeOpInput(y);\r
-                        if (infoX.isInputScalar) {\r
-                            if (infoY.isInputScalar) {\r
-                                if (infoX.re === infoY.re && infoX.im === infoY.im) {\r
-                                    return outputIndices ? [true, 0] : true;\r
-                                }\r
-                                else {\r
-                                    return outputIndices ? [false, -1] : false;\r
-                                }\r
-                            }\r
-                            else {\r
-                                var idx = void 0;\r
-                                if (infoX.isComplex) {\r
-                                    if (infoY.isComplex) {\r
-                                        idx = dataHelper_15.DataHelper.firstIndexOfComplex(infoX.re, infoX.im, infoY.reArr, infoY.imArr);\r
-                                    }\r
-                                    else {\r
-                                        idx = -1;\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    if (infoY.isComplex) {\r
-                                        idx = dataHelper_15.DataHelper.firstIndexOfComplex(infoX.re, 0, infoY.reArr, infoY.imArr);\r
-                                    }\r
-                                    else {\r
-                                        idx = dataHelper_15.DataHelper.firstIndexOf(infoX.re, infoY.reArr);\r
-                                    }\r
-                                }\r
-                                var flag = idx >= 0;\r
-                                return outputIndices ? [flag, idx] : flag;\r
-                            }\r
-                        }\r
-                        else {\r
-                            var _a = opUniqueInternal(infoY, false), U = _a[0], iy = _a[1];\r
-                            var M = tensor_12.Tensor.zeros(infoX.originalShape, 0);\r
-                            var i = void 0;\r
-                            var n = infoX.reArr.length;\r
-                            var reX = infoX.reArr;\r
-                            var imX = void 0;\r
-                            var reU = U.realData;\r
-                            var imU = void 0;\r
-                            var reM = M.realData;\r
-                            if (outputIndices) {\r
-                                var I = tensor_12.Tensor.zeros(infoX.originalShape, dtype_17.DTypeHelper.getDTypeOfIndices());\r
-                                var reI = I.realData;\r
-                                var idx = void 0;\r
-                                if (infoX.isComplex) {\r
-                                    imX = infoX.imArr;\r
-                                    if (infoY.isComplex) {\r
-                                        imU = U.imagData;\r
-                                        for (i = 0; i < n; i++) {\r
-                                            idx = dataHelper_15.DataHelper.binarySearchComplex(reX[i], imX[i], reU, imU);\r
-                                            if (idx >= 0) {\r
-                                                reM[i] = 1;\r
-                                                reI[i] = iy[idx];\r
-                                            }\r
-                                            else {\r
-                                                reM[i] = 0;\r
-                                                reI[i] = -1;\r
-                                            }\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (i = 0; i < n; i++) {\r
-                                            if (imX[i] !== 0) {\r
-                                                reI[i] = -1;\r
-                                                reM[i] = 0;\r
-                                            }\r
-                                            else {\r
-                                                idx = dataHelper_15.DataHelper.binarySearch(reX[i], reU);\r
-                                                if (idx >= 0) {\r
-                                                    reM[i] = 1;\r
-                                                    reI[i] = iy[idx];\r
-                                                }\r
-                                                else {\r
-                                                    reM[i] = 0;\r
-                                                    reI[i] = -1;\r
-                                                }\r
-                                            }\r
-                                        }\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    if (infoY.isComplex) {\r
-                                        imU = U.imagData;\r
-                                        for (i = 0; i < n; i++) {\r
-                                            idx = dataHelper_15.DataHelper.binarySearchComplex(reX[i], 0, reU, imU);\r
-                                            if (idx >= 0) {\r
-                                                reM[i] = 1;\r
-                                                reI[i] = iy[idx];\r
-                                            }\r
-                                            else {\r
-                                                reM[i] = 0;\r
-                                                reI[i] = -1;\r
-                                            }\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (i = 0; i < n; i++) {\r
-                                            idx = dataHelper_15.DataHelper.binarySearch(reX[i], reU);\r
-                                            if (idx >= 0) {\r
-                                                reM[i] = 1;\r
-                                                reI[i] = iy[idx];\r
-                                            }\r
-                                            else {\r
-                                                reM[i] = 0;\r
-                                                reI[i] = -1;\r
-                                            }\r
-                                        }\r
-                                    }\r
-                                }\r
-                                return [M, I];\r
-                            }\r
-                            else {\r
-                                if (infoX.isComplex) {\r
-                                    imX = infoX.imArr;\r
-                                    if (infoY.isComplex) {\r
-                                        imU = U.imagData;\r
-                                        for (i = 0; i < n; i++) {\r
-                                            reM[i] = dataHelper_15.DataHelper.binarySearchComplex(reX[i], imX[i], reU, imU) >= 0 ? 1 : 0;\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (i = 0; i < n; i++) {\r
-                                            if (imX[i] !== 0) {\r
-                                                reM[i] = 0;\r
-                                            }\r
-                                            else {\r
-                                                reM[i] = dataHelper_15.DataHelper.binarySearch(reX[i], reU) >= 0 ? 1 : 0;\r
-                                            }\r
-                                        }\r
-                                    }\r
-                                }\r
-                                else {\r
-                                    if (infoY.isComplex) {\r
-                                        imU = U.imagData;\r
-                                        for (i = 0; i < n; i++) {\r
-                                            reM[i] = dataHelper_15.DataHelper.binarySearchComplex(reX[i], 0, reU, imU) >= 0 ? 1 : 0;\r
-                                        }\r
-                                    }\r
-                                    else {\r
-                                        for (i = 0; i < n; i++) {\r
-                                            reM[i] = dataHelper_15.DataHelper.binarySearch(reX[i], reU) >= 0 ? 1 : 0;\r
-                                        }\r
-                                    }\r
-                                }\r
-                                return M;\r
-                            }\r
-                        }\r
-                    }\r
-                    function opUnion(x, y, outputIndices) {\r
-                        if (outputIndices === void 0) { outputIndices = false; }\r
-                        var X = coreOp.flatten(x);\r
-                        var Y = coreOp.flatten(y);\r
-                        var Z = coreOp.concat([X, Y]);\r
-                        if (outputIndices) {\r
-                            var _a = opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false), U = _a[0], iu = _a[1];\r
-                            var nX = X.size;\r
-                            var ix = [];\r
-                            var iy = [];\r
-                            for (var i = 0; i < iu.length; i++) {\r
-                                if (iu[i] >= nX) {\r
-                                    iy.push(iu[i] - nX);\r
-                                }\r
-                                else {\r
-                                    ix.push(iu[i]);\r
-                                }\r
-                            }\r
-                            return [U, ix, iy];\r
-                        }\r
-                        else {\r
-                            return opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false)[0];\r
-                        }\r
-                    }\r
-                    function opIntersect(x, y, outputIndices) {\r
-                        if (outputIndices === void 0) { outputIndices = false; }\r
-                        var X = coreOp.flatten(x);\r
-                        var Y = coreOp.flatten(y);\r
-                        var Z;\r
-                        var M, I, U;\r
-                        var iRemaining, iu, ix, iy;\r
-                        var reI;\r
-                        var i;\r
-                        var outputDType = dtype_17.DTypeHelper.getWiderType(X.dtype, Y.dtype);\r
-                        if (X.size < Y.size) {\r
-                            if (outputIndices) {\r
-                                _a = opIsIn(X, Y, true), M = _a[0], I = _a[1];\r
-                                iRemaining = coreOp.find(M);\r
-                                reI = I.realData;\r
-                                Z = X.get(iRemaining).asType(outputDType, false);\r
-                                _b = opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false), U = _b[0], iu = _b[1];\r
-                                iy = new Array(iu.length);\r
-                                for (i = 0; i < iu.length; i++) {\r
-                                    iu[i] = iRemaining[iu[i]];\r
-                                    iy[i] = reI[iu[i]];\r
-                                }\r
-                                return [U, iu, iy];\r
-                            }\r
-                            else {\r
-                                M = opIsIn(X, Y);\r
-                                Z = X.get(M).asType(outputDType, false);\r
-                                return opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false)[0];\r
-                            }\r
-                        }\r
-                        else {\r
-                            if (outputIndices) {\r
-                                _c = opIsIn(Y, X, true), M = _c[0], I = _c[1];\r
-                                iRemaining = coreOp.find(M);\r
-                                reI = I.realData;\r
-                                Z = Y.get(iRemaining).asType(outputDType, false);\r
-                                _d = opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false), U = _d[0], iu = _d[1];\r
-                                ix = new Array(iu.length);\r
-                                for (i = 0; i < iu.length; i++) {\r
-                                    iu[i] = iRemaining[iu[i]];\r
-                                    ix[i] = reI[iu[i]];\r
-                                }\r
-                                return [U, ix, iu];\r
-                            }\r
-                            else {\r
-                                M = opIsIn(Y, X);\r
-                                Z = Y.get(M).asType(outputDType, false);\r
-                                return opUniqueInternal(tensor_12.Tensor.analyzeOpInput(Z), false)[0];\r
-                            }\r
-                        }\r
-                        var _a, _b, _c, _d;\r
-                    }\r
-                    function opSetDiff(x, y, outputIndices) {\r
-                        if (outputIndices === void 0) { outputIndices = false; }\r
-                        var X = coreOp.flatten(x);\r
-                        var Y = coreOp.flatten(y);\r
-                        var M;\r
-                        M = opIsIn(X, Y);\r
-                        logicCompOp.not(M, true);\r
-                        var iRemaining = coreOp.find(M);\r
-                        var _a = opUniqueInternal(tensor_12.Tensor.analyzeOpInput(X.get(iRemaining)), false), U = _a[0], iy = _a[1];\r
-                        if (outputIndices) {\r
-                            for (var i = 0; i < iy.length; i++) {\r
-                                iy[i] = iRemaining[iy[i]];\r
-                            }\r
-                            return [U, iy];\r
-                        }\r
-                        else {\r
-                            return U;\r
-                        }\r
-                    }\r
-                    return {\r
-                        unique: opUnique,\r
-                        isin: opIsIn,\r
-                        union: opUnion,\r
-                        intersect: opIntersect,\r
-                        setdiff: opSetDiff\r
-                    };\r
-                };\r
-                return SetOpProviderFactory;\r
-            }());\r
-            exports_59("SetOpProviderFactory", SetOpProviderFactory);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/lib/jasmal", ["jasmal/lib/tensor", "jasmal/lib/ops/random/index", "jasmal/lib/ops/arithmetic/index", "jasmal/lib/ops/math/index", "jasmal/lib/complexNumber", "jasmal/lib/ops/core/index", "jasmal/lib/ops/logicComp/index", "jasmal/lib/ops/binary/index", "jasmal/lib/ops/matrix/index", "jasmal/lib/ops/data/index", "jasmal/lib/ops/poly/index", "jasmal/lib/ops/set/index", "jasmal/lib/helper/objHelper", "jasmal/lib/ops/generator/index", "jasmal/lib/constant"], function (exports_60, context_60) {\r
-    "use strict";\r
-    var __moduleName = context_60 && context_60.id;\r
-    var tensor_13, random_1, arithmetic_1, math_1, complexNumber_8, core_1, logicComp_1, index_1, matrix_1, data_1, poly_1, index_2, objHelper_10, generator_3, constant_7, JasmalEngine;\r
-    return {\r
-        setters: [\r
-            function (tensor_13_1) {\r
-                tensor_13 = tensor_13_1;\r
-            },\r
-            function (random_1_1) {\r
-                random_1 = random_1_1;\r
-            },\r
-            function (arithmetic_1_1) {\r
-                arithmetic_1 = arithmetic_1_1;\r
-            },\r
-            function (math_1_1) {\r
-                math_1 = math_1_1;\r
-            },\r
-            function (complexNumber_8_1) {\r
-                complexNumber_8 = complexNumber_8_1;\r
-            },\r
-            function (core_1_1) {\r
-                core_1 = core_1_1;\r
-            },\r
-            function (logicComp_1_1) {\r
-                logicComp_1 = logicComp_1_1;\r
-            },\r
-            function (index_1_1) {\r
-                index_1 = index_1_1;\r
-            },\r
-            function (matrix_1_1) {\r
-                matrix_1 = matrix_1_1;\r
-            },\r
-            function (data_1_1) {\r
-                data_1 = data_1_1;\r
-            },\r
-            function (poly_1_1) {\r
-                poly_1 = poly_1_1;\r
-            },\r
-            function (index_2_1) {\r
-                index_2 = index_2_1;\r
-            },\r
-            function (objHelper_10_1) {\r
-                objHelper_10 = objHelper_10_1;\r
-            },\r
-            function (generator_3_1) {\r
-                generator_3 = generator_3_1;\r
-            },\r
-            function (constant_7_1) {\r
-                constant_7 = constant_7_1;\r
-            }\r
-        ],\r
-        execute: function () {\r
-            JasmalEngine = (function () {\r
-                function JasmalEngine() {\r
-                }\r
-                JasmalEngine.getDefaultOptions = function () {\r
-                    return {\r
-                        rngEngine: 'twister'\r
-                    };\r
-                };\r
-                JasmalEngine.createInstance = function (options) {\r
-                    var defaultOptions = JasmalEngine.getDefaultOptions();\r
-                    if (options) {\r
-                        for (var prop in options) {\r
-                            if (options.hasOwnProperty(prop)) {\r
-                                defaultOptions[prop] = options[prop];\r
-                            }\r
-                        }\r
-                        options = defaultOptions;\r
-                    }\r
-                    else {\r
-                        options = defaultOptions;\r
-                    }\r
-                    var elementWiseOpGen = generator_3.ElementWiseOpGenerator.getInstance();\r
-                    var reductionOpGen = generator_3.ReductionOpGenerator.getInstance();\r
-                    var coreOpProvider = core_1.CoreOpProviderFactory.create(elementWiseOpGen);\r
-                    var randomOpProvider = random_1.RandomOpProviderFactory.create(options.rngEngine);\r
-                    var arithmeticOpProvider = arithmetic_1.ArithmeticOpProviderFactory.create(elementWiseOpGen);\r
-                    var mathOpProvider = math_1.MathOpProviderFactory.create(elementWiseOpGen);\r
-                    var matrixOpProvider = matrix_1.MatrixOpProviderFactory.create(arithmeticOpProvider, mathOpProvider);\r
-                    var logicCompOpProvider = logicComp_1.LogicComparisonOpProviderFactory.create(elementWiseOpGen);\r
-                    var binaryOpProvider = index_1.BinaryOpProviderFactory.create(elementWiseOpGen);\r
-                    var dataOpProvider = data_1.DataOpProviderFactory.create(coreOpProvider, arithmeticOpProvider, mathOpProvider, matrixOpProvider, reductionOpGen);\r
-                    var polyOpProvider = poly_1.PolynomialOpProviderFactory.create(coreOpProvider, matrixOpProvider);\r
-                    var setOpProvider = index_2.SetOpProviderFactory.create(coreOpProvider, logicCompOpProvider);\r
-                    var jasmalCore = {\r
-                        LOGIC: 0,\r
-                        INT32: 1,\r
-                        FLOAT64: 3,\r
-                        MM_NONE: 0,\r
-                        MM_TRANSPOSED: 1,\r
-                        MM_HERMITIAN: 2,\r
-                        J: new complexNumber_8.ComplexNumber(0, 1),\r
-                        PI: Math.PI,\r
-                        EPSILON: constant_7.EPSILON,\r
-                        complexNumber: function (re, im) { return new complexNumber_8.ComplexNumber(re, im); },\r
-                        isComplexNumber: function (x) { return x instanceof complexNumber_8.ComplexNumber; },\r
-                        isTensor: function (x) { return x instanceof tensor_13.Tensor; },\r
-                        zeros: tensor_13.Tensor.zeros,\r
-                        ones: tensor_13.Tensor.ones,\r
-                        fromArray: function (re, im, dtype) { return tensor_13.Tensor.fromArray(re, im, dtype); },\r
-                        complex: function (x, y) { return tensor_13.Tensor.complex(x, y); }\r
-                    };\r
-                    return objHelper_10.ObjectHelper.createExtendChain(jasmalCore)\r
-                        .extend(coreOpProvider)\r
-                        .extend(randomOpProvider)\r
-                        .extend(arithmeticOpProvider)\r
-                        .extend(matrixOpProvider)\r
-                        .extend(mathOpProvider)\r
-                        .extend(logicCompOpProvider)\r
-                        .extend(binaryOpProvider)\r
-                        .extend(dataOpProvider)\r
-                        .extend(polyOpProvider)\r
-                        .extend(setOpProvider)\r
-                        .end();\r
-                };\r
-                return JasmalEngine;\r
-            }());\r
-            exports_60("JasmalEngine", JasmalEngine);\r
-        }\r
-    };\r
-});\r
-System.register("jasmal/index", ["jasmal/lib/jasmal"], function (exports_61, context_61) {\r
-    "use strict";\r
-    var __moduleName = context_61 && context_61.id;\r
-    return {\r
-        setters: [\r
-            function (jasmal_1_1) {\r
-                exports_61({\r
-                    "JasmalEngine": jasmal_1_1["JasmalEngine"]\r
-                });\r
-            }\r
-        ],\r
-        execute: function () {\r
-        }\r
-    };\r
-});\r
-//# sourceMappingURL=jasmal.js.map
\ No newline at end of file
diff --git a/src/imports/math.js.map b/src/imports/math.js.map
deleted file mode 100644 (file)
index 31c272a..0000000
+++ /dev/null
@@ -1 +0,0 @@
-{"version":3,"file":"math.js","mappings":"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ACN,oBACA,SACA,qBAEFhuB,YAAa,iDACbiqF,SAAU,CACR,kBACA,oBACA,oBACA,uBACA,uBACA,gCACA,iCAEFK,QAAS,CACP,OACA,SACA,MACA,OACA,MACA,MACA,a9LkgBFiH,K+L3hBsB,CACtB34G,KAAM,OACN8tB,SAAU,aACVsnB,OAAQ,CACN,qBACA,UACA,sBAEFhuB,YAAa,mDACbiqF,SAAU,CACR,mBACA,qBACA,qBACA,wBACA,wBACA,8BAEFK,QAAS,CACP,MACA,SACA,MACA,OACA,MACA,MACA,a/LogBFkH,OgM5hBwB,CACxB54G,KAAM,SACN8tB,SAAU,aACVsnB,OAAQ,CACN,uBACA,aAEFhuB,YAAa,mLACbiqF,SAAU,CACR,kBACA,yBAEFK,QAAS,CACP,MACA,OACA,MACA,OACA,MACA,MACA,WACA,gBhMygBFh0F,IiM7hBqB,CACrB1d,KAAM,MACN8tB,SAAU,aACVsnB,OAAQ,CACN,oBACA,SACA,qBAEFhuB,YAAa,iDACbiqF,SAAU,CACR,kBACA,oBACA,oBACA,uBACA,uBACA,gCACA,iCAEFK,QAAS,CACP,MACA,OACA,SACA,OACA,MACA,MACA,ajMqgBF92F,KkM9hBsB,CACtB5a,KAAM,OACN8tB,SAAU,aACVsnB,OAAQ,CACN,qBACA,UACA,4BAEFhuB,YAAa,2HACbiqF,SAAU,CACR,sBACA,8BACA,uBAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,OACA,MACA,MACA,alMygBF3jE,KmM/hBsB,CACtB/tC,KAAM,OACN8tB,SAAU,aACVsnB,OAAQ,CACN,qBACA,WAEFhuB,YAAa,qCACbiqF,SAAU,CACR,gBACA,kBACA,sBAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,MACA,MACA,anM2gBFmH,YoMhiB6B,CAC7B74G,KAAM,cACN8tB,SAAU,aACVsnB,OAAQ,CACN,iCACA,gDACA,+BAEFhuB,YAAa,sWACbiqF,SAAU,CACR,kCACA,yCACA,gCACA,yCAEFK,QAAS,CACP,OACA,SACA,MACA,MACA,OACA,MACA,MACA,apM0gBFoH,IqMjiBqB,CACrB94G,KAAM,MACN8tB,SAAU,aACVsnB,OAAQ,CACN,oBACA,SACA,oBACA,wBACA,oCAEFhuB,YAAa,iLACbiqF,SAAU,CACR,eACA,oBACA,mCACA,8BACA,2BAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,OACA,MACA,arMygBFriE,IsMliBqB,CACrBrvC,KAAM,MACN8tB,SAAU,aACVsnB,OAAQ,CACN,oBACA,SACA,qBAEFhuB,YAAa,iCACbiqF,SAAU,CACR,kBACA,oBACA,qBAEFK,QAAS,CACP,MACA,OACA,SACA,MACA,OACA,MACA,MACA,atM6gBFpV,SuMniB0B,CAC1Bt8F,KAAM,WACN8tB,SAAU,aACVsnB,OAAQ,CACN,yBACA,cACA,yBACA,6BACA,yCAEFhuB,YAAa,gIACbiqF,SAAU,CACR,oBACA,yBACA,wCACA,mCACA,gCAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,OACA,MACA,QvM0gBFqH,KwMpiBsB,CACtB/4G,KAAM,OACN8tB,SAAU,aACVsnB,OAAQ,CACN,aAEFhuB,YAAa,iIACbiqF,SAAU,CACR,kCACA,wGAEFK,QAAS,CACP,MACA,OACA,MACA,SACA,MACA,OACA,MACA,QxMohBFv7G,KyMviBsB,CACtB6J,KAAM,OACN8tB,SAAU,eACVsnB,OAAQ,CACN,WAEFhuB,YAAa,oDACbiqF,SAAU,CACR,YACA,kBAEFK,QAAS,CACP,MACA,OACA,SzM0hBF96G,M0MxiBuB,CACvBoJ,KAAM,QACN8tB,SAAU,eACVsnB,OAAQ,CACN,YAEFhuB,YAAa,6FACbiqF,SAAU,CACR,cAEFK,QAAS,CACP,OACA,QACA,U1M4hBF5mB,K2MziBsB,CACtB9qF,KAAM,OACN8tB,SAAU,eACVsnB,OAAQ,CACN,WAEFhuB,YAAa,8CACbiqF,SAAU,CACR,YACA,iBACA,WAEFK,QAAS,CACP,MACA,S3M4hBF1mB,M4M1iBuB,CACvBhrF,KAAM,QACN8tB,SAAU,eACVsnB,OAAQ,CACN,YAEFhuB,YAAa,6GACbiqF,SAAU,CACR,WACA,cAEFK,QAAS,CACP,QACA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","sources":["webpack://math/webpack/universalModuleDefinition","webpack://math/./node_modules/complex.js/complex.js","webpack://math/./node_modules/escape-latex/dist/index.js","webpack://math/./node_modules/javascript-natural-sort/naturalSort.js","webpack://math/./node_modules/seedrandom/index.js","webpack://math/./node_modules/seedrandom/lib/alea.js","webpack://math/./node_modules/seedrandom/lib/tychei.js","webpack://math/./node_modules/seedrandom/lib/xor128.js","webpack://math/./node_modules/seedrandom/lib/xor4096.js","webpack://math/./node_modules/seedrandom/lib/xorshift7.js","webpack://math/./node_modules/seedrandom/lib/xorwow.js","webpack://math/./node_modules/seedrandom/seedrandom.js","webpack://math/./node_modules/tiny-emitter/index.js","webpack://math/./node_modules/core-js/internals/a-callable.js","webpack://math/./node_modules/core-js/internals/a-constructor.js","webpack://math/./node_modules/core-js/internals/a-possible-prototype.js","webpack://math/./node_modules/core-js/internals/add-to-unscopables.js","webpack://math/./node_modules/core-js/internals/advance-string-index.js","webpack://math/./node_modules/core-js/internals/an-instance.js","webpack://math/./node_modules/core-js/internals/an-object.js","webpack://math/./node_modules/core-js/internals/array-includes.js","webpack://math/./node_modules/core-js/internals/array-method-is-strict.js","webpack://math/./node_modules/core-js/internals/array-reduce.js","webpack://math/./node_modules/core-js/internals/array-slice.js","webpack://math/./node_modules/core-js/internals/array-sort.js","webpack://math/./node_modules/core-js/internals/check-correctness-of-iteration.js","webpack://math/./node_modules/core-js/internals/classof-raw.js","webpack://math/./node_modules/core-js/internals/classof.js","webpack://math/./node_modules/core-js/internals/copy-constructor-properties.js","webpack://math/./node_modules/core-js/internals/create-non-enumerable-property.js","webpack://math/./node_modules/core-js/internals/create-property-descriptor.js","webpack://math/./node_modules/core-js/internals/define-built-in-accessor.js","webpack://math/./node_modules/core-js/internals/define-built-in.js","webpack://math/./node_modules/core-js/internals/define-global-property.js","webpack://math/./node_modules/core-js/internals/delete-property-or-throw.js","webpack://math/./node_modules/core-js/internals/descriptors.js","webpack://math/./node_modules/core-js/internals/document-create-element.js","webpack://math/./node_modules/core-js/internals/engine-ff-version.js","webpack://math/./node_modules/core-js/internals/engine-is-browser.js","webpack://math/./node_modules/core-js/internals/engine-is-deno.js","webpack://math/./node_modules/core-js/internals/engine-is-ie-or-edge.js","webpack://math/./node_modules/core-js/internals/engine-is-ios-pebble.js","webpack://math/./node_modules/core-js/internals/engine-is-ios.js","webpack://math/./node_modules/core-js/internals/engine-is-node.js","webpack://math/./node_modules/core-js/internals/engine-is-webos-webkit.js","webpack://math/./node_modules/core-js/internals/engine-user-agent.js","webpack://math/./node_modules/core-js/internals/engine-v8-version.js","webpack://math/./node_modules/core-js/internals/engine-webkit-version.js","webpack://math/./node_modules/core-js/internals/enum-bug-keys.js","webpack://math/./node_modules/core-js/internals/export.js","webpack://math/./node_modules/core-js/internals/fails.js","webpack://math/./node_modules/core-js/internals/fix-regexp-well-known-symbol-logic.js","webpack://math/./node_modules/core-js/internals/function-apply.js","webpack://math/./node_modules/core-js/internals/function-bind-context.js","webpack://math/./node_modules/core-js/internals/function-bind-native.js","webpack://math/./node_modules/core-js/internals/function-call.js","webpack://math/./node_modules/core-js/internals/function-name.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this-accessor.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this-clause.js","webpack://math/./node_modules/core-js/internals/function-uncurry-this.js","webpack://math/./node_modules/core-js/internals/get-built-in.js","webpack://math/./node_modules/core-js/internals/get-iterator-method.js","webpack://math/./node_modules/core-js/internals/get-iterator.js","webpack://math/./node_modules/core-js/internals/get-json-replacer-function.js","webpack://math/./node_modules/core-js/internals/get-method.js","webpack://math/./node_modules/core-js/internals/get-substitution.js","webpack://math/./node_modules/core-js/internals/global.js","webpack://math/./node_modules/core-js/internals/has-own-property.js","webpack://math/./node_modules/core-js/internals/hidden-keys.js","webpack://math/./node_modules/core-js/internals/host-report-errors.js","webpack://math/./node_modules/core-js/internals/html.js","webpack://math/./node_modules/core-js/internals/ie8-dom-define.js","webpack://math/./node_modules/core-js/internals/indexed-object.js","webpack://math/./node_modules/core-js/internals/inherit-if-required.js","webpack://math/./node_modules/core-js/internals/inspect-source.js","webpack://math/./node_modules/core-js/internals/internal-state.js","webpack://math/./node_modules/core-js/internals/is-array-iterator-method.js","webpack://math/./node_modules/core-js/internals/is-array.js","webpack://math/./node_modules/core-js/internals/is-callable.js","webpack://math/./node_modules/core-js/internals/is-constructor.js","webpack://math/./node_modules/core-js/internals/is-forced.js","webpack://math/./node_modules/core-js/internals/is-null-or-undefined.js","webpack://math/./node_modules/core-js/internals/is-object.js","webpack://math/./node_modules/core-js/internals/is-possible-prototype.js","webpack://math/./node_modules/core-js/internals/is-pure.js","webpack://math/./node_modules/core-js/internals/is-regexp.js","webpack://math/./node_modules/core-js/internals/is-symbol.js","webpack://math/./node_modules/core-js/internals/iterate.js","webpack://math/./node_modules/core-js/internals/iterator-close.js","webpack://math/./node_modules/core-js/internals/iterators.js","webpack://math/./node_modules/core-js/internals/length-of-array-like.js","webpack://math/./node_modules/core-js/internals/make-built-in.js","webpack://math/./node_modules/core-js/internals/math-trunc.js","webpack://math/./node_modules/core-js/internals/microtask.js","webpack://math/./node_modules/core-js/internals/new-promise-capability.js","webpack://math/./node_modules/core-js/internals/object-create.js","webpack://math/./node_modules/core-js/internals/object-define-properties.js","webpack://math/./node_modules/core-js/internals/object-define-property.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-descriptor.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-names.js","webpack://math/./node_modules/core-js/internals/object-get-own-property-symbols.js","webpack://math/./node_modules/core-js/internals/object-is-prototype-of.js","webpack://math/./node_modules/core-js/internals/object-keys-internal.js","webpack://math/./node_modules/core-js/internals/object-keys.js","webpack://math/./node_modules/core-js/internals/object-property-is-enumerable.js","webpack://math/./node_modules/core-js/internals/object-set-prototype-of.js","webpack://math/./node_modules/core-js/internals/ordinary-to-primitive.js","webpack://math/./node_modules/core-js/internals/own-keys.js","webpack://math/./node_modules/core-js/internals/perform.js","webpack://math/./node_modules/core-js/internals/promise-constructor-detection.js","webpack://math/./node_modules/core-js/internals/promise-native-constructor.js","webpack://math/./node_modules/core-js/internals/promise-resolve.js","webpack://math/./node_modules/core-js/internals/promise-statics-incorrect-iteration.js","webpack://math/./node_modules/core-js/internals/proxy-accessor.js","webpack://math/./node_modules/core-js/internals/queue.js","webpack://math/./node_modules/core-js/internals/regexp-exec-abstract.js","webpack://math/./node_modules/core-js/internals/regexp-exec.js","webpack://math/./node_modules/core-js/internals/regexp-flags.js","webpack://math/./node_modules/core-js/internals/regexp-get-flags.js","webpack://math/./node_modules/core-js/internals/regexp-sticky-helpers.js","webpack://math/./node_modules/core-js/internals/regexp-unsupported-dot-all.js","webpack://math/./node_modules/core-js/internals/regexp-unsupported-ncg.js","webpack://math/./node_modules/core-js/internals/require-object-coercible.js","webpack://math/./node_modules/core-js/internals/safe-get-built-in.js","webpack://math/./node_modules/core-js/internals/set-species.js","webpack://math/./node_modules/core-js/internals/set-to-string-tag.js","webpack://math/./node_modules/core-js/internals/shared-key.js","webpack://math/./node_modules/core-js/internals/shared-store.js","webpack://math/./node_modules/core-js/internals/shared.js","webpack://math/./node_modules/core-js/internals/species-constructor.js","webpack://math/./node_modules/core-js/internals/string-multibyte.js","webpack://math/./node_modules/core-js/internals/symbol-constructor-detection.js","webpack://math/./node_modules/core-js/internals/task.js","webpack://math/./node_modules/core-js/internals/to-absolute-index.js","webpack://math/./node_modules/core-js/internals/to-indexed-object.js","webpack://math/./node_modules/core-js/internals/to-integer-or-infinity.js","webpack://math/./node_modules/core-js/internals/to-length.js","webpack://math/./node_modules/core-js/internals/to-object.js","webpack://math/./node_modules/core-js/internals/to-primitive.js","webpack://math/./node_modules/core-js/internals/to-property-key.js","webpack://math/./node_modules/core-js/internals/to-string-tag-support.js","webpack://math/./node_modules/core-js/internals/to-string.js","webpack://math/./node_modules/core-js/internals/try-to-string.js","webpack://math/./node_modules/core-js/internals/uid.js","webpack://math/./node_modules/core-js/internals/use-symbol-as-uid.js","webpack://math/./node_modules/core-js/internals/v8-prototype-define-bug.js","webpack://math/./node_modules/core-js/internals/validate-arguments-length.js","webpack://math/./node_modules/core-js/internals/weak-map-basic-detection.js","webpack://math/./node_modules/core-js/internals/well-known-symbol.js","webpack://math/./node_modules/core-js/modules/es.array.includes.js","webpack://math/./node_modules/core-js/modules/es.array.reduce.js","webpack://math/./node_modules/core-js/modules/es.array.sort.js","webpack://math/./node_modules/core-js/modules/es.json.stringify.js","webpack://math/./node_modules/core-js/modules/es.promise.all.js","webpack://math/./node_modules/core-js/modules/es.promise.catch.js","webpack://math/./node_modules/core-js/modules/es.promise.constructor.js","webpack://math/./node_modules/core-js/modules/es.promise.js","webpack://math/./node_modules/core-js/modules/es.promise.race.js","webpack://math/./node_modules/core-js/modules/es.promise.reject.js","webpack://math/./node_modules/core-js/modules/es.promise.resolve.js","webpack://math/./node_modules/core-js/modules/es.regexp.constructor.js","webpack://math/./node_modules/core-js/modules/es.regexp.dot-all.js","webpack://math/./node_modules/core-js/modules/es.regexp.exec.js","webpack://math/./node_modules/core-js/modules/es.string.replace.js","webpack://math/./node_modules/core-js/modules/es.symbol.description.js","webpack://math/./node_modules/typed-function/lib/umd/typed-function.js","webpack://math/webpack/bootstrap","webpack://math/webpack/runtime/amd define","webpack://math/webpack/runtime/amd options","webpack://math/webpack/runtime/define property getters","webpack://math/webpack/runtime/hasOwnProperty shorthand","webpack://math/webpack/runtime/make namespace object","webpack://math/webpack/runtime/node module decorator","webpack://math/./src/utils/is.js","webpack://math/./src/utils/number.js","webpack://math/./src/utils/object.js","webpack://math/./src/utils/factory.js","webpack://math/./src/utils/customs.js","webpack://math/./src/utils/map.js","webpack://math/./src/core/function/typed.js","webpack://math/./src/type/resultset/ResultSet.js","webpack://math/./node_modules/decimal.js/decimal.mjs","webpack://math/./src/type/bignumber/BigNumber.js","webpack://math/./src/type/complex/Complex.js","webpack://math/./node_modules/fraction.js/fraction.js","webpack://math/./src/type/fraction/Fraction.js","webpack://math/./src/type/matrix/Range.js","webpack://math/./src/type/matrix/Matrix.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/extends.js","webpack://math/./src/utils/bignumber/formatter.js","webpack://math/./src/utils/string.js","webpack://math/./src/error/DimensionError.js","webpack://math/./src/error/IndexError.js","webpack://math/./src/utils/array.js","webpack://math/./src/utils/lruQueue.js","webpack://math/./src/utils/function.js","webpack://math/./src/type/matrix/DenseMatrix.js","webpack://math/./src/function/utils/clone.js","webpack://math/./src/utils/switch.js","webpack://math/./src/utils/collection.js","webpack://math/./src/function/utils/isInteger.js","webpack://math/./src/plain/number/utils.js","webpack://math/./src/utils/bignumber/nearlyEqual.js","webpack://math/./src/function/utils/isNegative.js","webpack://math/./src/function/utils/isNumeric.js","webpack://math/./src/function/utils/hasNumericValue.js","webpack://math/./src/function/utils/isPositive.js","webpack://math/./src/function/utils/isZero.js","webpack://math/./src/function/utils/isNaN.js","webpack://math/./src/function/utils/typeOf.js","webpack://math/./src/function/relational/compareUnits.js","webpack://math/./src/function/relational/equalScalar.js","webpack://math/./src/utils/complex.js","webpack://math/./src/type/matrix/SparseMatrix.js","webpack://math/./src/type/number.js","webpack://math/./src/type/bigint.js","webpack://math/./src/type/string.js","webpack://math/./src/type/boolean.js","webpack://math/./src/type/bignumber/function/bignumber.js","webpack://math/./src/type/complex/function/complex.js","webpack://math/./src/type/fraction/function/fraction.js","webpack://math/./src/type/matrix/function/matrix.js","webpack://math/./src/function/matrix/matrixFromFunction.js","webpack://math/./src/function/matrix/matrixFromRows.js","webpack://math/./src/function/matrix/matrixFromColumns.js","webpack://math/./src/type/unit/function/splitUnit.js","webpack://math/./src/plain/number/arithmetic.js","webpack://math/./src/function/arithmetic/unaryMinus.js","webpack://math/./src/function/arithmetic/unaryPlus.js","webpack://math/./src/function/arithmetic/abs.js","webpack://math/./src/function/matrix/apply.js","webpack://math/./src/function/arithmetic/addScalar.js","webpack://math/./src/function/arithmetic/subtractScalar.js","webpack://math/./src/function/arithmetic/cbrt.js","webpack://math/./src/type/matrix/utils/matAlgo11xS0s.js","webpack://math/./src/type/matrix/utils/matAlgo12xSfs.js","webpack://math/./src/type/matrix/utils/matAlgo14xDs.js","webpack://math/./src/function/arithmetic/ceil.js","webpack://math/./src/function/arithmetic/cube.js","webpack://math/./src/function/arithmetic/exp.js","webpack://math/./src/function/arithmetic/expm1.js","webpack://math/./src/function/arithmetic/fix.js","webpack://math/./src/function/arithmetic/floor.js","webpack://math/./src/type/matrix/utils/matAlgo02xDS0.js","webpack://math/./src/type/matrix/utils/matAlgo03xDSf.js","webpack://math/./src/type/matrix/utils/matAlgo05xSfSf.js","webpack://math/./src/type/matrix/utils/matAlgo13xDD.js","webpack://math/./src/type/matrix/utils/broadcast.js","webpack://math/./src/type/matrix/utils/matrixAlgorithmSuite.js","webpack://math/./src/function/arithmetic/mod.js","webpack://math/./src/type/matrix/utils/matAlgo01xDSid.js","webpack://math/./src/type/matrix/utils/matAlgo04xSidSid.js","webpack://math/./src/type/matrix/utils/matAlgo10xSids.js","webpack://math/./src/error/ArgumentsError.js","webpack://math/./src/function/arithmetic/gcd.js","webpack://math/./src/type/matrix/utils/matAlgo06xS0S0.js","webpack://math/./src/function/arithmetic/lcm.js","webpack://math/./src/function/arithmetic/log10.js","webpack://math/./src/function/arithmetic/log2.js","webpack://math/./src/function/arithmetic/multiplyScalar.js","webpack://math/./src/function/arithmetic/multiply.js","webpack://math/./src/function/arithmetic/nthRoot.js","webpack://math/./src/function/arithmetic/sign.js","webpack://math/./src/function/arithmetic/sqrt.js","webpack://math/./src/function/arithmetic/square.js","webpack://math/./src/function/arithmetic/subtract.js","webpack://math/./src/function/arithmetic/xgcd.js","webpack://math/./src/function/arithmetic/invmod.js","webpack://math/./src/type/matrix/utils/matAlgo09xS0Sf.js","webpack://math/./src/function/arithmetic/dotMultiply.js","webpack://math/./src/utils/bignumber/bitwise.js","webpack://math/./src/plain/number/bitwise.js","webpack://math/./src/function/bitwise/bitAnd.js","webpack://math/./src/function/bitwise/bitNot.js","webpack://math/./src/function/bitwise/bitOr.js","webpack://math/./src/type/matrix/utils/matAlgo07xSSf.js","webpack://math/./src/function/bitwise/bitXor.js","webpack://math/./src/function/complex/arg.js","webpack://math/./src/function/complex/conj.js","webpack://math/./src/function/complex/im.js","webpack://math/./src/function/complex/re.js","webpack://math/./src/plain/number/logical.js","webpack://math/./src/function/logical/not.js","webpack://math/./src/function/logical/or.js","webpack://math/./src/function/logical/xor.js","webpack://math/./src/function/matrix/concat.js","webpack://math/./src/function/matrix/column.js","webpack://math/./src/function/matrix/count.js","webpack://math/./src/function/matrix/cross.js","webpack://math/./src/function/matrix/diag.js","webpack://math/./src/utils/applyCallback.js","webpack://math/./src/function/matrix/filter.js","webpack://math/./src/function/matrix/flatten.js","webpack://math/./src/function/matrix/forEach.js","webpack://math/./src/function/matrix/getMatrixDataType.js","webpack://math/./src/function/matrix/identity.js","webpack://math/./src/function/matrix/kron.js","webpack://math/./src/function/matrix/map.js","webpack://math/./src/function/matrix/diff.js","webpack://math/./src/function/matrix/ones.js","webpack://math/./src/utils/noop.js","webpack://math/./src/function/matrix/range.js","webpack://math/./src/function/matrix/reshape.js","webpack://math/./src/function/matrix/resize.js","webpack://math/./src/function/matrix/rotate.js","webpack://math/./src/function/matrix/rotationMatrix.js","webpack://math/./src/function/matrix/row.js","webpack://math/./src/function/matrix/size.js","webpack://math/./src/function/matrix/squeeze.js","webpack://math/./src/function/matrix/subset.js","webpack://math/./src/function/matrix/transpose.js","webpack://math/./src/function/matrix/ctranspose.js","webpack://math/./src/function/matrix/zeros.js","webpack://math/./src/function/matrix/fft.js","webpack://math/./src/function/matrix/ifft.js","webpack://math/./src/function/numeric/solveODE.js","webpack://math/./src/function/special/erf.js","webpack://math/./src/function/special/zeta.js","webpack://math/./src/function/statistics/mode.js","webpack://math/./src/function/statistics/utils/improveErrorMessage.js","webpack://math/./src/function/statistics/prod.js","webpack://math/./src/function/string/format.js","webpack://math/./src/function/string/bin.js","webpack://math/./src/function/string/oct.js","webpack://math/./src/function/string/hex.js","webpack://math/./src/utils/print.js","webpack://math/./src/function/string/print.js","webpack://math/./src/function/unit/to.js","webpack://math/./src/function/utils/isPrime.js","webpack://math/./src/function/utils/numeric.js","webpack://math/./src/function/arithmetic/divideScalar.js","webpack://math/./src/function/arithmetic/pow.js","webpack://math/./src/function/arithmetic/round.js","webpack://math/./src/function/arithmetic/log.js","webpack://math/./src/function/arithmetic/log1p.js","webpack://math/./src/function/arithmetic/nthRoots.js","webpack://math/./src/function/arithmetic/dotPow.js","webpack://math/./src/function/arithmetic/dotDivide.js","webpack://math/./src/function/algebra/solver/utils/solveValidation.js","webpack://math/./src/function/algebra/solver/lsolve.js","webpack://math/./src/function/algebra/solver/usolve.js","webpack://math/./src/function/algebra/solver/lsolveAll.js","webpack://math/./src/function/algebra/solver/usolveAll.js","webpack://math/./src/type/matrix/utils/matAlgo08xS0Sid.js","webpack://math/./src/function/bitwise/useMatrixForArrayScalar.js","webpack://math/./src/function/bitwise/leftShift.js","webpack://math/./src/function/bitwise/rightArithShift.js","webpack://math/./src/function/bitwise/rightLogShift.js","webpack://math/./src/function/logical/and.js","webpack://math/./src/function/relational/compare.js","webpack://math/./src/function/relational/compareNatural.js","webpack://math/./src/function/relational/compareText.js","webpack://math/./src/function/relational/equal.js","webpack://math/./src/function/relational/equalText.js","webpack://math/./src/function/relational/smaller.js","webpack://math/./src/function/relational/smallerEq.js","webpack://math/./src/function/relational/larger.js","webpack://math/./src/function/relational/largerEq.js","webpack://math/./src/function/relational/deepEqual.js","webpack://math/./src/function/relational/unequal.js","webpack://math/./src/function/matrix/partitionSelect.js","webpack://math/./src/function/matrix/sort.js","webpack://math/./src/function/statistics/max.js","webpack://math/./src/function/statistics/min.js","webpack://math/./src/type/matrix/ImmutableDenseMatrix.js","webpack://math/./src/type/matrix/MatrixIndex.js","webpack://math/./src/type/matrix/FibonacciHeap.js","webpack://math/./src/type/matrix/Spa.js","webpack://math/./src/utils/bignumber/constants.js","webpack://math/./src/type/unit/Unit.js","webpack://math/./src/type/unit/function/unit.js","webpack://math/./src/type/matrix/function/sparse.js","webpack://math/./src/type/unit/function/createUnit.js","webpack://math/./src/function/trigonometry/acos.js","webpack://math/./src/plain/number/trigonometry.js","webpack://math/./src/function/trigonometry/acosh.js","webpack://math/./src/function/trigonometry/acot.js","webpack://math/./src/function/trigonometry/acoth.js","webpack://math/./src/function/trigonometry/acsc.js","webpack://math/./src/function/trigonometry/acsch.js","webpack://math/./src/function/trigonometry/asec.js","webpack://math/./src/function/trigonometry/asech.js","webpack://math/./src/function/trigonometry/asin.js","webpack://math/./src/function/trigonometry/asinh.js","webpack://math/./src/function/trigonometry/atan.js","webpack://math/./src/function/trigonometry/atan2.js","webpack://math/./src/function/trigonometry/atanh.js","webpack://math/./src/function/trigonometry/trigUnit.js","webpack://math/./src/function/trigonometry/cos.js","webpack://math/./src/function/trigonometry/cosh.js","webpack://math/./src/function/trigonometry/cot.js","webpack://math/./src/function/trigonometry/coth.js","webpack://math/./src/function/trigonometry/csc.js","webpack://math/./src/function/trigonometry/csch.js","webpack://math/./src/function/trigonometry/sec.js","webpack://math/./src/function/trigonometry/sech.js","webpack://math/./src/function/trigonometry/sin.js","webpack://math/./src/function/trigonometry/sinh.js","webpack://math/./src/function/trigonometry/tan.js","webpack://math/./src/function/trigonometry/tanh.js","webpack://math/./src/function/set/setCartesian.js","webpack://math/./src/function/set/setDifference.js","webpack://math/./src/function/set/setDistinct.js","webpack://math/./src/function/set/setIntersect.js","webpack://math/./src/function/set/setIsSubset.js","webpack://math/./src/function/set/setMultiplicity.js","webpack://math/./src/function/set/setPowerset.js","webpack://math/./src/function/set/setSize.js","webpack://math/./src/function/set/setSymDifference.js","webpack://math/./src/function/set/setUnion.js","webpack://math/./src/function/arithmetic/add.js","webpack://math/./src/function/arithmetic/hypot.js","webpack://math/./src/function/arithmetic/norm.js","webpack://math/./src/function/matrix/dot.js","webpack://math/./src/function/matrix/trace.js","webpack://math/./src/type/matrix/function/index.js","webpack://math/./src/expression/keywords.js","webpack://math/./src/expression/node/Node.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/typeof.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack://math/./node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack://math/./src/expression/transform/utils/errorTransform.js","webpack://math/./src/expression/node/utils/access.js","webpack://math/./src/expression/node/AccessorNode.js","webpack://math/./src/expression/node/ArrayNode.js","webpack://math/./src/expression/operators.js","webpack://math/./src/expression/node/AssignmentNode.js","webpack://math/./src/expression/node/utils/assign.js","webpack://math/./src/expression/node/BlockNode.js","webpack://math/./src/expression/node/ConditionalNode.js","webpack://math/./src/utils/latex.js","webpack://math/./src/expression/node/ConstantNode.js","webpack://math/./src/expression/node/FunctionAssignmentNode.js","webpack://math/./src/expression/node/IndexNode.js","webpack://math/./src/expression/node/ObjectNode.js","webpack://math/./src/utils/scope.js","webpack://math/./src/expression/node/OperatorNode.js","webpack://math/./src/expression/node/ParenthesisNode.js","webpack://math/./src/expression/node/RangeNode.js","webpack://math/./src/expression/node/RelationalNode.js","webpack://math/./src/expression/node/SymbolNode.js","webpack://math/./src/expression/node/FunctionNode.js","webpack://math/./src/expression/parse.js","webpack://math/./src/expression/function/compile.js","webpack://math/./src/expression/function/evaluate.js","webpack://math/./src/expression/Parser.js","webpack://math/./src/expression/function/parser.js","webpack://math/./src/function/algebra/decomposition/lup.js","webpack://math/./src/function/algebra/decomposition/qr.js","webpack://math/./src/function/algebra/sparse/csTdfs.js","webpack://math/./src/function/algebra/sparse/csFlip.js","webpack://math/./src/function/algebra/sparse/csAmd.js","webpack://math/./src/function/algebra/sparse/csFkeep.js","webpack://math/./src/function/algebra/sparse/csLeaf.js","webpack://math/./src/function/algebra/sparse/csCounts.js","webpack://math/./src/function/algebra/sparse/csSqr.js","webpack://math/./src/function/algebra/sparse/csPermute.js","webpack://math/./src/function/algebra/sparse/csEtree.js","webpack://math/./src/function/algebra/sparse/csPost.js","webpack://math/./src/function/algebra/sparse/csMarked.js","webpack://math/./src/function/algebra/sparse/csMark.js","webpack://math/./src/function/algebra/sparse/csUnflip.js","webpack://math/./src/function/algebra/sparse/csDfs.js","webpack://math/./src/function/algebra/sparse/csSpsolve.js","webpack://math/./src/function/algebra/sparse/csReach.js","webpack://math/./src/function/algebra/sparse/csLu.js","webpack://math/./src/function/algebra/decomposition/slu.js","webpack://math/./src/function/algebra/sparse/csIpvec.js","webpack://math/./src/function/algebra/solver/lusolve.js","webpack://math/./src/function/algebra/polynomialRoot.js","webpack://math/./src/expression/Help.js","webpack://math/./src/type/chain/Chain.js","webpack://math/./src/expression/embeddedDocs/constants/e.js","webpack://math/./src/expression/embeddedDocs/constants/pi.js","webpack://math/./src/expression/embeddedDocs/embeddedDocs.js","webpack://math/./src/expression/embeddedDocs/construction/bignumber.js","webpack://math/./src/expression/embeddedDocs/construction/bigint.js","webpack://math/./src/expression/embeddedDocs/construction/boolean.js","webpack://math/./src/expression/embeddedDocs/construction/complex.js","webpack://math/./src/expression/embeddedDocs/construction/createUnit.js","webpack://math/./src/expression/embeddedDocs/construction/fraction.js","webpack://math/./src/expression/embeddedDocs/construction/index.js","webpack://math/./src/expression/embeddedDocs/construction/matrix.js","webpack://math/./src/expression/embeddedDocs/construction/number.js","webpack://math/./src/expression/embeddedDocs/construction/sparse.js","webpack://math/./src/expression/embeddedDocs/construction/splitUnit.js","webpack://math/./src/expression/embeddedDocs/construction/string.js","webpack://math/./src/expression/embeddedDocs/construction/unit.js","webpack://math/./src/expression/embeddedDocs/constants/false.js","webpack://math/./src/expression/embeddedDocs/constants/i.js","webpack://math/./src/expression/embeddedDocs/constants/Infinity.js","webpack://math/./src/expression/embeddedDocs/constants/LN2.js","webpack://math/./src/expression/embeddedDocs/constants/LN10.js","webpack://math/./src/expression/embeddedDocs/constants/LOG2E.js","webpack://math/./src/expression/embeddedDocs/constants/LOG10E.js","webpack://math/./src/expression/embeddedDocs/constants/NaN.js","webpack://math/./src/expression/embeddedDocs/constants/null.js","webpack://math/./src/expression/embeddedDocs/constants/phi.js","webpack://math/./src/expression/embeddedDocs/constants/SQRT1_2.js","webpack://math/./src/expression/embeddedDocs/constants/SQRT2.js","webpack://math/./src/expression/embeddedDocs/constants/tau.js","webpack://math/./src/expression/embeddedDocs/constants/true.js","webpack://math/./src/expression/embeddedDocs/constants/version.js","webpack://math/./src/expression/embeddedDocs/function/algebra/derivative.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lsolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lsolveAll.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lup.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lusolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/leafCount.js","webpack://math/./src/expression/embeddedDocs/function/algebra/polynomialRoot.js","webpack://math/./src/expression/embeddedDocs/function/algebra/resolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplify.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplifyConstant.js","webpack://math/./src/expression/embeddedDocs/function/algebra/simplifyCore.js","webpack://math/./src/expression/embeddedDocs/function/algebra/symbolicEqual.js","webpack://math/./src/expression/embeddedDocs/function/algebra/rationalize.js","webpack://math/./src/expression/embeddedDocs/function/algebra/slu.js","webpack://math/./src/expression/embeddedDocs/function/algebra/usolve.js","webpack://math/./src/expression/embeddedDocs/function/algebra/usolveAll.js","webpack://math/./src/expression/embeddedDocs/function/algebra/qr.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/abs.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/add.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/cbrt.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/ceil.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/cube.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/divide.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotDivide.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotMultiply.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/dotPow.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/exp.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/expm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/expm1.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/fix.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/floor.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/gcd.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/hypot.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/lcm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log2.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log1p.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/log10.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/mod.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/multiply.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/norm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/nthRoot.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/nthRoots.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/pow.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/round.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sign.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sqrt.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/sqrtm.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/square.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/subtract.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/unaryMinus.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/unaryPlus.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/xgcd.js","webpack://math/./src/expression/embeddedDocs/function/arithmetic/invmod.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitAnd.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitNot.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitOr.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/bitXor.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/leftShift.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/rightArithShift.js","webpack://math/./src/expression/embeddedDocs/function/bitwise/rightLogShift.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/bellNumbers.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/catalan.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/composition.js","webpack://math/./src/expression/embeddedDocs/function/combinatorics/stirlingS2.js","webpack://math/./src/expression/embeddedDocs/core/config.js","webpack://math/./src/expression/embeddedDocs/core/import.js","webpack://math/./src/expression/embeddedDocs/core/typed.js","webpack://math/./src/expression/embeddedDocs/function/complex/arg.js","webpack://math/./src/expression/embeddedDocs/function/complex/conj.js","webpack://math/./src/expression/embeddedDocs/function/complex/re.js","webpack://math/./src/expression/embeddedDocs/function/complex/im.js","webpack://math/./src/expression/embeddedDocs/function/expression/evaluate.js","webpack://math/./src/expression/embeddedDocs/function/expression/help.js","webpack://math/./src/expression/embeddedDocs/function/geometry/distance.js","webpack://math/./src/expression/embeddedDocs/function/geometry/intersect.js","webpack://math/./src/expression/embeddedDocs/function/logical/and.js","webpack://math/./src/expression/embeddedDocs/function/logical/not.js","webpack://math/./src/expression/embeddedDocs/function/logical/or.js","webpack://math/./src/expression/embeddedDocs/function/logical/xor.js","webpack://math/./src/expression/embeddedDocs/function/matrix/concat.js","webpack://math/./src/expression/embeddedDocs/function/matrix/count.js","webpack://math/./src/expression/embeddedDocs/function/matrix/cross.js","webpack://math/./src/expression/embeddedDocs/function/matrix/column.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ctranspose.js","webpack://math/./src/expression/embeddedDocs/function/matrix/det.js","webpack://math/./src/expression/embeddedDocs/function/matrix/diag.js","webpack://math/./src/expression/embeddedDocs/function/matrix/diff.js","webpack://math/./src/expression/embeddedDocs/function/matrix/dot.js","webpack://math/./src/expression/embeddedDocs/function/matrix/getMatrixDataType.js","webpack://math/./src/expression/embeddedDocs/function/matrix/identity.js","webpack://math/./src/expression/embeddedDocs/function/matrix/filter.js","webpack://math/./src/expression/embeddedDocs/function/matrix/flatten.js","webpack://math/./src/expression/embeddedDocs/function/matrix/forEach.js","webpack://math/./src/expression/embeddedDocs/function/matrix/inv.js","webpack://math/./src/expression/embeddedDocs/function/matrix/pinv.js","webpack://math/./src/expression/embeddedDocs/function/matrix/eigs.js","webpack://math/./src/expression/embeddedDocs/function/matrix/kron.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromFunction.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromRows.js","webpack://math/./src/expression/embeddedDocs/function/matrix/matrixFromColumns.js","webpack://math/./src/expression/embeddedDocs/function/matrix/map.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ones.js","webpack://math/./src/expression/embeddedDocs/function/matrix/partitionSelect.js","webpack://math/./src/expression/embeddedDocs/function/matrix/range.js","webpack://math/./src/expression/embeddedDocs/function/matrix/resize.js","webpack://math/./src/expression/embeddedDocs/function/matrix/reshape.js","webpack://math/./src/expression/embeddedDocs/function/matrix/rotate.js","webpack://math/./src/expression/embeddedDocs/function/matrix/rotationMatrix.js","webpack://math/./src/expression/embeddedDocs/function/matrix/row.js","webpack://math/./src/expression/embeddedDocs/function/matrix/size.js","webpack://math/./src/expression/embeddedDocs/function/matrix/sort.js","webpack://math/./src/expression/embeddedDocs/function/matrix/squeeze.js","webpack://math/./src/expression/embeddedDocs/function/matrix/subset.js","webpack://math/./src/expression/embeddedDocs/function/matrix/trace.js","webpack://math/./src/expression/embeddedDocs/function/matrix/transpose.js","webpack://math/./src/expression/embeddedDocs/function/matrix/zeros.js","webpack://math/./src/expression/embeddedDocs/function/matrix/fft.js","webpack://math/./src/expression/embeddedDocs/function/matrix/ifft.js","webpack://math/./src/expression/embeddedDocs/function/algebra/sylvester.js","webpack://math/./src/expression/embeddedDocs/function/algebra/schur.js","webpack://math/./src/expression/embeddedDocs/function/algebra/lyap.js","webpack://math/./src/expression/embeddedDocs/function/numeric/solveODE.js","webpack://math/./src/expression/embeddedDocs/function/probability/combinations.js","webpack://math/./src/expression/embeddedDocs/function/probability/combinationsWithRep.js","webpack://math/./src/expression/embeddedDocs/function/probability/factorial.js","webpack://math/./src/expression/embeddedDocs/function/probability/gamma.js","webpack://math/./src/expression/embeddedDocs/function/probability/kldivergence.js","webpack://math/./src/expression/embeddedDocs/function/probability/lgamma.js","webpack://math/./src/expression/embeddedDocs/function/probability/multinomial.js","webpack://math/./src/expression/embeddedDocs/function/probability/permutations.js","webpack://math/./src/expression/embeddedDocs/function/probability/pickRandom.js","webpack://math/./src/expression/embeddedDocs/function/probability/random.js","webpack://math/./src/expression/embeddedDocs/function/probability/randomInt.js","webpack://math/./src/expression/embeddedDocs/function/relational/compare.js","webpack://math/./src/expression/embeddedDocs/function/relational/compareNatural.js","webpack://math/./src/expression/embeddedDocs/function/relational/compareText.js","webpack://math/./src/expression/embeddedDocs/function/relational/deepEqual.js","webpack://math/./src/expression/embeddedDocs/function/relational/equal.js","webpack://math/./src/expression/embeddedDocs/function/relational/equalText.js","webpack://math/./src/expression/embeddedDocs/function/relational/larger.js","webpack://math/./src/expression/embeddedDocs/function/relational/largerEq.js","webpack://math/./src/expression/embeddedDocs/function/relational/smaller.js","webpack://math/./src/expression/embeddedDocs/function/relational/smallerEq.js","webpack://math/./src/expression/embeddedDocs/function/relational/unequal.js","webpack://math/./src/expression/embeddedDocs/function/set/setCartesian.js","webpack://math/./src/expression/embeddedDocs/function/set/setDifference.js","webpack://math/./src/expression/embeddedDocs/function/set/setDistinct.js","webpack://math/./src/expression/embeddedDocs/function/set/setIntersect.js","webpack://math/./src/expression/embeddedDocs/function/set/setIsSubset.js","webpack://math/./src/expression/embeddedDocs/function/set/setMultiplicity.js","webpack://math/./src/expression/embeddedDocs/function/set/setPowerset.js","webpack://math/./src/expression/embeddedDocs/function/set/setSize.js","webpack://math/./src/expression/embeddedDocs/function/set/setSymDifference.js","webpack://math/./src/expression/embeddedDocs/function/set/setUnion.js","webpack://math/./src/expression/embeddedDocs/function/signal/zpk2tf.js","webpack://math/./src/expression/embeddedDocs/function/signal/freqz.js","webpack://math/./src/expression/embeddedDocs/function/special/erf.js","webpack://math/./src/expression/embeddedDocs/function/special/zeta.js","webpack://math/./src/expression/embeddedDocs/function/statistics/cumsum.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mad.js","webpack://math/./src/expression/embeddedDocs/function/statistics/max.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mean.js","webpack://math/./src/expression/embeddedDocs/function/statistics/median.js","webpack://math/./src/expression/embeddedDocs/function/statistics/min.js","webpack://math/./src/expression/embeddedDocs/function/statistics/mode.js","webpack://math/./src/expression/embeddedDocs/function/statistics/prod.js","webpack://math/./src/expression/embeddedDocs/function/statistics/quantileSeq.js","webpack://math/./src/expression/embeddedDocs/function/statistics/std.js","webpack://math/./src/expression/embeddedDocs/function/statistics/sum.js","webpack://math/./src/expression/embeddedDocs/function/statistics/variance.js","webpack://math/./src/expression/embeddedDocs/function/statistics/corr.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acos.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acosh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acot.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acoth.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acsc.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/acsch.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asec.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asech.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asin.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/asinh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atan.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atanh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/atan2.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cos.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cosh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/cot.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/coth.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/csc.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/csch.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sec.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sech.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sin.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/sinh.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/tan.js","webpack://math/./src/expression/embeddedDocs/function/trigonometry/tanh.js","webpack://math/./src/expression/embeddedDocs/function/units/to.js","webpack://math/./src/expression/embeddedDocs/function/utils/clone.js","webpack://math/./src/expression/embeddedDocs/function/utils/format.js","webpack://math/./src/expression/embeddedDocs/function/utils/bin.js","webpack://math/./src/expression/embeddedDocs/function/utils/oct.js","webpack://math/./src/expression/embeddedDocs/function/utils/hex.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNaN.js","webpack://math/./src/expression/embeddedDocs/function/utils/isInteger.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNegative.js","webpack://math/./src/expression/embeddedDocs/function/utils/isNumeric.js","webpack://math/./src/expression/embeddedDocs/function/utils/hasNumericValue.js","webpack://math/./src/expression/embeddedDocs/function/utils/isPositive.js","webpack://math/./src/expression/embeddedDocs/function/utils/isPrime.js","webpack://math/./src/expression/embeddedDocs/function/utils/isZero.js","webpack://math/./src/expression/embeddedDocs/function/utils/print.js","webpack://math/./src/expression/embeddedDocs/function/utils/typeOf.js","webpack://math/./src/expression/embeddedDocs/function/utils/numeric.js","webpack://math/./src/expression/function/help.js","webpack://math/./src/type/chain/function/chain.js","webpack://math/./src/function/matrix/det.js","webpack://math/./src/function/matrix/inv.js","webpack://math/./src/function/matrix/pinv.js","webpack://math/./src/function/matrix/eigs.js","webpack://math/./src/function/matrix/eigs/realSymmetric.js","webpack://math/./src/function/matrix/eigs/complexEigs.js","webpack://math/./src/function/matrix/expm.js","webpack://math/./src/function/matrix/sqrtm.js","webpack://math/./src/function/algebra/sylvester.js","webpack://math/./src/function/algebra/decomposition/schur.js","webpack://math/./src/function/algebra/lyap.js","webpack://math/./src/function/arithmetic/divide.js","webpack://math/./src/function/geometry/distance.js","webpack://math/./src/function/geometry/intersect.js","webpack://math/./src/function/statistics/sum.js","webpack://math/./src/function/statistics/cumsum.js","webpack://math/./src/function/statistics/mean.js","webpack://math/./src/function/statistics/median.js","webpack://math/./src/function/statistics/mad.js","webpack://math/./src/function/statistics/variance.js","webpack://math/./src/function/statistics/quantileSeq.js","webpack://math/./src/function/statistics/std.js","webpack://math/./src/function/statistics/corr.js","webpack://math/./src/utils/product.js","webpack://math/./src/plain/number/combinations.js","webpack://math/./src/function/probability/combinations.js","webpack://math/./src/function/probability/combinationsWithRep.js","webpack://math/./src/plain/number/probability.js","webpack://math/./src/function/probability/gamma.js","webpack://math/./src/function/probability/lgamma.js","webpack://math/./src/function/probability/factorial.js","webpack://math/./src/function/probability/kldivergence.js","webpack://math/./src/function/probability/multinomial.js","webpack://math/./src/function/probability/permutations.js","webpack://math/./src/function/probability/util/seededRNG.js","webpack://math/./src/function/probability/pickRandom.js","webpack://math/./src/function/probability/util/randomMatrix.js","webpack://math/./src/function/probability/random.js","webpack://math/./src/function/probability/randomInt.js","webpack://math/./src/function/combinatorics/stirlingS2.js","webpack://math/./src/function/combinatorics/bellNumbers.js","webpack://math/./src/function/combinatorics/catalan.js","webpack://math/./src/function/combinatorics/composition.js","webpack://math/./src/function/algebra/leafCount.js","webpack://math/./src/function/algebra/simplify/wildcards.js","webpack://math/./src/function/algebra/simplify/util.js","webpack://math/./src/function/algebra/simplify.js","webpack://math/./src/function/algebra/simplifyConstant.js","webpack://math/./src/function/algebra/simplifyCore.js","webpack://math/./src/function/algebra/resolve.js","webpack://math/./src/function/algebra/symbolicEqual.js","webpack://math/./src/function/algebra/derivative.js","webpack://math/./src/function/algebra/rationalize.js","webpack://math/./src/function/signal/zpk2tf.js","webpack://math/./src/function/signal/freqz.js","webpack://math/./src/json/reviver.js","webpack://math/./src/json/replacer.js","webpack://math/./src/plain/number/constants.js","webpack://math/./src/constants.js","webpack://math/./src/version.js","webpack://math/./src/type/unit/physicalConstants.js","webpack://math/./src/expression/transform/apply.transform.js","webpack://math/./src/expression/transform/column.transform.js","webpack://math/./src/expression/transform/utils/compileInlineExpression.js","webpack://math/./src/expression/transform/filter.transform.js","webpack://math/./src/expression/transform/forEach.transform.js","webpack://math/./src/expression/transform/index.transform.js","webpack://math/./src/expression/transform/map.transform.js","webpack://math/./src/expression/transform/utils/lastDimToZeroBase.js","webpack://math/./src/expression/transform/max.transform.js","webpack://math/./src/expression/transform/mean.transform.js","webpack://math/./src/expression/transform/min.transform.js","webpack://math/./src/expression/transform/range.transform.js","webpack://math/./src/expression/transform/row.transform.js","webpack://math/./src/expression/transform/subset.transform.js","webpack://math/./src/expression/transform/concat.transform.js","webpack://math/./src/expression/transform/diff.transform.js","webpack://math/./src/expression/transform/std.transform.js","webpack://math/./src/expression/transform/sum.transform.js","webpack://math/./src/expression/transform/quantileSeq.transform.js","webpack://math/./src/expression/transform/cumsum.transform.js","webpack://math/./src/expression/transform/variance.transform.js","webpack://math/./src/expression/transform/print.transform.js","webpack://math/./src/expression/transform/and.transform.js","webpack://math/./src/expression/transform/or.transform.js","webpack://math/./src/expression/transform/bitAnd.transform.js","webpack://math/./src/expression/transform/bitOr.transform.js","webpack://math/./src/core/config.js","webpack://math/./src/core/function/config.js","webpack://math/./src/defaultInstance.js","webpack://math/./src/core/create.js","webpack://math/./src/utils/emitter.js","webpack://math/./src/core/function/import.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"math\"] = factory();\n\telse\n\t\troot[\"math\"] = factory();\n})(this, () => {\nreturn ","/**\n * @license Complex.js v2.1.1 12/05/2020\n *\n * Copyright (c) 2020, Robert Eisele ([email protected])\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: <real>, im: <imaginary> }\n * { arg: <angle>, abs: <radius> }\n * { phi: <angle>, r: <radius> }\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","\"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};","/*\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 <[email protected]>, 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 <[email protected]>\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","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsCallable(argument) is true`\nmodule.exports = function (argument) {\n  if (isCallable(argument)) return argument;\n  throw new $TypeError(tryToString(argument) + ' is not a function');\n};\n","'use strict';\nvar isConstructor = require('../internals/is-constructor');\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\n// `Assert: IsConstructor(argument) is true`\nmodule.exports = function (argument) {\n  if (isConstructor(argument)) return argument;\n  throw new $TypeError(tryToString(argument) + ' is not a constructor');\n};\n","'use strict';\nvar isPossiblePrototype = require('../internals/is-possible-prototype');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument) {\n  if (isPossiblePrototype(argument)) return argument;\n  throw new $TypeError(\"Can't set \" + $String(argument) + ' as a prototype');\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar create = require('../internals/object-create');\nvar defineProperty = require('../internals/object-define-property').f;\n\nvar UNSCOPABLES = wellKnownSymbol('unscopables');\nvar ArrayPrototype = Array.prototype;\n\n// Array.prototype[@@unscopables]\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\nif (ArrayPrototype[UNSCOPABLES] === undefined) {\n  defineProperty(ArrayPrototype, UNSCOPABLES, {\n    configurable: true,\n    value: create(null)\n  });\n}\n\n// add a key to Array.prototype[@@unscopables]\nmodule.exports = function (key) {\n  ArrayPrototype[UNSCOPABLES][key] = true;\n};\n","'use strict';\nvar charAt = require('../internals/string-multibyte').charAt;\n\n// `AdvanceStringIndex` abstract operation\n// https://tc39.es/ecma262/#sec-advancestringindex\nmodule.exports = function (S, index, unicode) {\n  return index + (unicode ? charAt(S, index).length : 1);\n};\n","'use strict';\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (it, Prototype) {\n  if (isPrototypeOf(Prototype, it)) return it;\n  throw new $TypeError('Incorrect invocation');\n};\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nvar $String = String;\nvar $TypeError = TypeError;\n\n// `Assert: Type(argument) is Object`\nmodule.exports = function (argument) {\n  if (isObject(argument)) return argument;\n  throw new $TypeError($String(argument) + ' is not an object');\n};\n","'use strict';\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toAbsoluteIndex = require('../internals/to-absolute-index');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\n// `Array.prototype.{ indexOf, includes }` methods implementation\nvar createMethod = function (IS_INCLUDES) {\n  return function ($this, el, fromIndex) {\n    var O = toIndexedObject($this);\n    var length = lengthOfArrayLike(O);\n    if (length === 0) return !IS_INCLUDES && -1;\n    var index = toAbsoluteIndex(fromIndex, length);\n    var value;\n    // Array#includes uses SameValueZero equality algorithm\n    // eslint-disable-next-line no-self-compare -- NaN check\n    if (IS_INCLUDES && el !== el) while (length > index) {\n      value = O[index++];\n      // eslint-disable-next-line no-self-compare -- NaN check\n      if (value !== value) return true;\n    // Array#indexOf ignores holes, Array#includes - not\n    } else for (;length > index; index++) {\n      if ((IS_INCLUDES || index in O) && O[index] === el) return IS_INCLUDES || index || 0;\n    } return !IS_INCLUDES && -1;\n  };\n};\n\nmodule.exports = {\n  // `Array.prototype.includes` method\n  // https://tc39.es/ecma262/#sec-array.prototype.includes\n  includes: createMethod(true),\n  // `Array.prototype.indexOf` method\n  // https://tc39.es/ecma262/#sec-array.prototype.indexof\n  indexOf: createMethod(false)\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = function (METHOD_NAME, argument) {\n  var method = [][METHOD_NAME];\n  return !!method && fails(function () {\n    // eslint-disable-next-line no-useless-call -- required for testing\n    method.call(null, argument || function () { return 1; }, 1);\n  });\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar toObject = require('../internals/to-object');\nvar IndexedObject = require('../internals/indexed-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\n\nvar $TypeError = TypeError;\n\nvar REDUCE_EMPTY = 'Reduce of empty array with no initial value';\n\n// `Array.prototype.{ reduce, reduceRight }` methods implementation\nvar createMethod = function (IS_RIGHT) {\n  return function (that, callbackfn, argumentsLength, memo) {\n    var O = toObject(that);\n    var self = IndexedObject(O);\n    var length = lengthOfArrayLike(O);\n    aCallable(callbackfn);\n    if (length === 0 && argumentsLength < 2) throw new $TypeError(REDUCE_EMPTY);\n    var index = IS_RIGHT ? length - 1 : 0;\n    var i = IS_RIGHT ? -1 : 1;\n    if (argumentsLength < 2) while (true) {\n      if (index in self) {\n        memo = self[index];\n        index += i;\n        break;\n      }\n      index += i;\n      if (IS_RIGHT ? index < 0 : length <= index) {\n        throw new $TypeError(REDUCE_EMPTY);\n      }\n    }\n    for (;IS_RIGHT ? index >= 0 : length > index; index += i) if (index in self) {\n      memo = callbackfn(memo, self[index], index, O);\n    }\n    return memo;\n  };\n};\n\nmodule.exports = {\n  // `Array.prototype.reduce` method\n  // https://tc39.es/ecma262/#sec-array.prototype.reduce\n  left: createMethod(false),\n  // `Array.prototype.reduceRight` method\n  // https://tc39.es/ecma262/#sec-array.prototype.reduceright\n  right: createMethod(true)\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis([].slice);\n","'use strict';\nvar arraySlice = require('../internals/array-slice');\n\nvar floor = Math.floor;\n\nvar sort = function (array, comparefn) {\n  var length = array.length;\n\n  if (length < 8) {\n    // insertion sort\n    var i = 1;\n    var element, j;\n\n    while (i < length) {\n      j = i;\n      element = array[i];\n      while (j && comparefn(array[j - 1], element) > 0) {\n        array[j] = array[--j];\n      }\n      if (j !== i++) array[j] = element;\n    }\n  } else {\n    // merge sort\n    var middle = floor(length / 2);\n    var left = sort(arraySlice(array, 0, middle), comparefn);\n    var right = sort(arraySlice(array, middle), comparefn);\n    var llength = left.length;\n    var rlength = right.length;\n    var lindex = 0;\n    var rindex = 0;\n\n    while (lindex < llength || rindex < rlength) {\n      array[lindex + rindex] = (lindex < llength && rindex < rlength)\n        ? comparefn(left[lindex], right[rindex]) <= 0 ? left[lindex++] : right[rindex++]\n        : lindex < llength ? left[lindex++] : right[rindex++];\n    }\n  }\n\n  return array;\n};\n\nmodule.exports = sort;\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar SAFE_CLOSING = false;\n\ntry {\n  var called = 0;\n  var iteratorWithReturn = {\n    next: function () {\n      return { done: !!called++ };\n    },\n    'return': function () {\n      SAFE_CLOSING = true;\n    }\n  };\n  iteratorWithReturn[ITERATOR] = function () {\n    return this;\n  };\n  // eslint-disable-next-line es/no-array-from, no-throw-literal -- required for testing\n  Array.from(iteratorWithReturn, function () { throw 2; });\n} catch (error) { /* empty */ }\n\nmodule.exports = function (exec, SKIP_CLOSING) {\n  try {\n    if (!SKIP_CLOSING && !SAFE_CLOSING) return false;\n  } catch (error) { return false; } // workaround of old WebKit + `eval` bug\n  var ITERATION_SUPPORT = false;\n  try {\n    var object = {};\n    object[ITERATOR] = function () {\n      return {\n        next: function () {\n          return { done: ITERATION_SUPPORT = true };\n        }\n      };\n    };\n    exec(object);\n  } catch (error) { /* empty */ }\n  return ITERATION_SUPPORT;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar toString = uncurryThis({}.toString);\nvar stringSlice = uncurryThis(''.slice);\n\nmodule.exports = function (it) {\n  return stringSlice(toString(it), 8, -1);\n};\n","'use strict';\nvar TO_STRING_TAG_SUPPORT = require('../internals/to-string-tag-support');\nvar isCallable = require('../internals/is-callable');\nvar classofRaw = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar $Object = Object;\n\n// ES3 wrong here\nvar CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) === 'Arguments';\n\n// fallback for IE11 Script Access Denied error\nvar tryGet = function (it, key) {\n  try {\n    return it[key];\n  } catch (error) { /* empty */ }\n};\n\n// getting tag from ES6+ `Object.prototype.toString`\nmodule.exports = TO_STRING_TAG_SUPPORT ? classofRaw : function (it) {\n  var O, tag, result;\n  return it === undefined ? 'Undefined' : it === null ? 'Null'\n    // @@toStringTag case\n    : typeof (tag = tryGet(O = $Object(it), TO_STRING_TAG)) == 'string' ? tag\n    // builtinTag case\n    : CORRECT_ARGUMENTS ? classofRaw(O)\n    // ES3 arguments fallback\n    : (result = classofRaw(O)) === 'Object' && isCallable(O.callee) ? 'Arguments' : result;\n};\n","'use strict';\nvar hasOwn = require('../internals/has-own-property');\nvar ownKeys = require('../internals/own-keys');\nvar getOwnPropertyDescriptorModule = require('../internals/object-get-own-property-descriptor');\nvar definePropertyModule = require('../internals/object-define-property');\n\nmodule.exports = function (target, source, exceptions) {\n  var keys = ownKeys(source);\n  var defineProperty = definePropertyModule.f;\n  var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f;\n  for (var i = 0; i < keys.length; i++) {\n    var key = keys[i];\n    if (!hasOwn(target, key) && !(exceptions && hasOwn(exceptions, key))) {\n      defineProperty(target, key, getOwnPropertyDescriptor(source, key));\n    }\n  }\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar definePropertyModule = require('../internals/object-define-property');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\n\nmodule.exports = DESCRIPTORS ? function (object, key, value) {\n  return definePropertyModule.f(object, key, createPropertyDescriptor(1, value));\n} : function (object, key, value) {\n  object[key] = value;\n  return object;\n};\n","'use strict';\nmodule.exports = function (bitmap, value) {\n  return {\n    enumerable: !(bitmap & 1),\n    configurable: !(bitmap & 2),\n    writable: !(bitmap & 4),\n    value: value\n  };\n};\n","'use strict';\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineProperty = require('../internals/object-define-property');\n\nmodule.exports = function (target, name, descriptor) {\n  if (descriptor.get) makeBuiltIn(descriptor.get, name, { getter: true });\n  if (descriptor.set) makeBuiltIn(descriptor.set, name, { setter: true });\n  return defineProperty.f(target, name, descriptor);\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar definePropertyModule = require('../internals/object-define-property');\nvar makeBuiltIn = require('../internals/make-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nmodule.exports = function (O, key, value, options) {\n  if (!options) options = {};\n  var simple = options.enumerable;\n  var name = options.name !== undefined ? options.name : key;\n  if (isCallable(value)) makeBuiltIn(value, name, options);\n  if (options.global) {\n    if (simple) O[key] = value;\n    else defineGlobalProperty(key, value);\n  } else {\n    try {\n      if (!options.unsafe) delete O[key];\n      else if (O[key]) simple = true;\n    } catch (error) { /* empty */ }\n    if (simple) O[key] = value;\n    else definePropertyModule.f(O, key, {\n      value: value,\n      enumerable: false,\n      configurable: !options.nonConfigurable,\n      writable: !options.nonWritable\n    });\n  } return O;\n};\n","'use strict';\nvar global = require('../internals/global');\n\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\n\nmodule.exports = function (key, value) {\n  try {\n    defineProperty(global, key, { value: value, configurable: true, writable: true });\n  } catch (error) {\n    global[key] = value;\n  } return value;\n};\n","'use strict';\nvar tryToString = require('../internals/try-to-string');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (O, P) {\n  if (!delete O[P]) throw new $TypeError('Cannot delete property ' + tryToString(P) + ' of ' + tryToString(O));\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\n// Detect IE8's incomplete defineProperty implementation\nmodule.exports = !fails(function () {\n  // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n  return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] !== 7;\n});\n","'use strict';\nvar global = require('../internals/global');\nvar isObject = require('../internals/is-object');\n\nvar document = global.document;\n// typeof document.createElement is 'object' in old IE\nvar EXISTS = isObject(document) && isObject(document.createElement);\n\nmodule.exports = function (it) {\n  return EXISTS ? document.createElement(it) : {};\n};\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nvar firefox = userAgent.match(/firefox\\/(\\d+)/i);\n\nmodule.exports = !!firefox && +firefox[1];\n","'use strict';\nvar IS_DENO = require('../internals/engine-is-deno');\nvar IS_NODE = require('../internals/engine-is-node');\n\nmodule.exports = !IS_DENO && !IS_NODE\n  && typeof window == 'object'\n  && typeof document == 'object';\n","'use strict';\n/* global Deno -- Deno case */\nmodule.exports = typeof Deno == 'object' && Deno && typeof Deno.version == 'object';\n","'use strict';\nvar UA = require('../internals/engine-user-agent');\n\nmodule.exports = /MSIE|Trident/.test(UA);\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nmodule.exports = /ipad|iphone|ipod/i.test(userAgent) && typeof Pebble != 'undefined';\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\n// eslint-disable-next-line redos/no-vulnerable -- safe\nmodule.exports = /(?:ipad|iphone|ipod).*applewebkit/i.test(userAgent);\n","'use strict';\nvar global = require('../internals/global');\nvar classof = require('../internals/classof-raw');\n\nmodule.exports = classof(global.process) === 'process';\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nmodule.exports = /web0s(?!.*chrome)/i.test(userAgent);\n","'use strict';\nmodule.exports = typeof navigator != 'undefined' && String(navigator.userAgent) || '';\n","'use strict';\nvar global = require('../internals/global');\nvar userAgent = require('../internals/engine-user-agent');\n\nvar process = global.process;\nvar Deno = global.Deno;\nvar versions = process && process.versions || Deno && Deno.version;\nvar v8 = versions && versions.v8;\nvar match, version;\n\nif (v8) {\n  match = v8.split('.');\n  // in old Chrome, versions of V8 isn't V8 = Chrome / 10\n  // but their correct versions are not interesting for us\n  version = match[0] > 0 && match[0] < 4 ? 1 : +(match[0] + match[1]);\n}\n\n// BrowserFS NodeJS `process` polyfill incorrectly set `.v8` to `0.0`\n// so check `userAgent` even if `.v8` exists, but 0\nif (!version && userAgent) {\n  match = userAgent.match(/Edge\\/(\\d+)/);\n  if (!match || match[1] >= 74) {\n    match = userAgent.match(/Chrome\\/(\\d+)/);\n    if (match) version = +match[1];\n  }\n}\n\nmodule.exports = version;\n","'use strict';\nvar userAgent = require('../internals/engine-user-agent');\n\nvar webkit = userAgent.match(/AppleWebKit\\/(\\d+)\\./);\n\nmodule.exports = !!webkit && +webkit[1];\n","'use strict';\n// IE8- don't enum bug keys\nmodule.exports = [\n  'constructor',\n  'hasOwnProperty',\n  'isPrototypeOf',\n  'propertyIsEnumerable',\n  'toLocaleString',\n  'toString',\n  'valueOf'\n];\n","'use strict';\nvar global = require('../internals/global');\nvar getOwnPropertyDescriptor = require('../internals/object-get-own-property-descriptor').f;\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar defineGlobalProperty = require('../internals/define-global-property');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\nvar isForced = require('../internals/is-forced');\n\n/*\n  options.target         - name of the target object\n  options.global         - target is the global object\n  options.stat           - export as static methods of target\n  options.proto          - export as prototype methods of target\n  options.real           - real prototype method for the `pure` version\n  options.forced         - export even if the native feature is available\n  options.bind           - bind methods to the target, required for the `pure` version\n  options.wrap           - wrap constructors to preventing global pollution, required for the `pure` version\n  options.unsafe         - use the simple assignment of property instead of delete + defineProperty\n  options.sham           - add a flag to not completely full polyfills\n  options.enumerable     - export as enumerable property\n  options.dontCallGetSet - prevent calling a getter on target\n  options.name           - the .name of the function if it does not match the key\n*/\nmodule.exports = function (options, source) {\n  var TARGET = options.target;\n  var GLOBAL = options.global;\n  var STATIC = options.stat;\n  var FORCED, target, key, targetProperty, sourceProperty, descriptor;\n  if (GLOBAL) {\n    target = global;\n  } else if (STATIC) {\n    target = global[TARGET] || defineGlobalProperty(TARGET, {});\n  } else {\n    target = global[TARGET] && global[TARGET].prototype;\n  }\n  if (target) for (key in source) {\n    sourceProperty = source[key];\n    if (options.dontCallGetSet) {\n      descriptor = getOwnPropertyDescriptor(target, key);\n      targetProperty = descriptor && descriptor.value;\n    } else targetProperty = target[key];\n    FORCED = isForced(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced);\n    // contained in target\n    if (!FORCED && targetProperty !== undefined) {\n      if (typeof sourceProperty == typeof targetProperty) continue;\n      copyConstructorProperties(sourceProperty, targetProperty);\n    }\n    // add a flag to not completely full polyfills\n    if (options.sham || (targetProperty && targetProperty.sham)) {\n      createNonEnumerableProperty(sourceProperty, 'sham', true);\n    }\n    defineBuiltIn(target, key, sourceProperty, options);\n  }\n};\n","'use strict';\nmodule.exports = function (exec) {\n  try {\n    return !!exec();\n  } catch (error) {\n    return true;\n  }\n};\n","'use strict';\n// TODO: Remove from `core-js@4` since it's moved to entry points\nrequire('../modules/es.regexp.exec');\nvar call = require('../internals/function-call');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar regexpExec = require('../internals/regexp-exec');\nvar fails = require('../internals/fails');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\n\nvar SPECIES = wellKnownSymbol('species');\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (KEY, exec, FORCED, SHAM) {\n  var SYMBOL = wellKnownSymbol(KEY);\n\n  var DELEGATES_TO_SYMBOL = !fails(function () {\n    // String methods call symbol-named RegExp methods\n    var O = {};\n    O[SYMBOL] = function () { return 7; };\n    return ''[KEY](O) !== 7;\n  });\n\n  var DELEGATES_TO_EXEC = DELEGATES_TO_SYMBOL && !fails(function () {\n    // Symbol-named RegExp methods call .exec\n    var execCalled = false;\n    var re = /a/;\n\n    if (KEY === 'split') {\n      // We can't use real regex here since it causes deoptimization\n      // and serious performance degradation in V8\n      // https://github.com/zloirock/core-js/issues/306\n      re = {};\n      // RegExp[@@split] doesn't call the regex's exec method, but first creates\n      // a new one. We need to return the patched regex when creating the new one.\n      re.constructor = {};\n      re.constructor[SPECIES] = function () { return re; };\n      re.flags = '';\n      re[SYMBOL] = /./[SYMBOL];\n    }\n\n    re.exec = function () {\n      execCalled = true;\n      return null;\n    };\n\n    re[SYMBOL]('');\n    return !execCalled;\n  });\n\n  if (\n    !DELEGATES_TO_SYMBOL ||\n    !DELEGATES_TO_EXEC ||\n    FORCED\n  ) {\n    var nativeRegExpMethod = /./[SYMBOL];\n    var methods = exec(SYMBOL, ''[KEY], function (nativeMethod, regexp, str, arg2, forceStringMethod) {\n      var $exec = regexp.exec;\n      if ($exec === regexpExec || $exec === RegExpPrototype.exec) {\n        if (DELEGATES_TO_SYMBOL && !forceStringMethod) {\n          // The native String method already delegates to @@method (this\n          // polyfilled function), leasing to infinite recursion.\n          // We avoid it by directly calling the native @@method method.\n          return { done: true, value: call(nativeRegExpMethod, regexp, str, arg2) };\n        }\n        return { done: true, value: call(nativeMethod, str, regexp, arg2) };\n      }\n      return { done: false };\n    });\n\n    defineBuiltIn(String.prototype, KEY, methods[0]);\n    defineBuiltIn(RegExpPrototype, SYMBOL, methods[1]);\n  }\n\n  if (SHAM) createNonEnumerableProperty(RegExpPrototype[SYMBOL], 'sham', true);\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar apply = FunctionPrototype.apply;\nvar call = FunctionPrototype.call;\n\n// eslint-disable-next-line es/no-reflect -- safe\nmodule.exports = typeof Reflect == 'object' && Reflect.apply || (NATIVE_BIND ? call.bind(apply) : function () {\n  return call.apply(apply, arguments);\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this-clause');\nvar aCallable = require('../internals/a-callable');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar bind = uncurryThis(uncurryThis.bind);\n\n// optional / simple context binding\nmodule.exports = function (fn, that) {\n  aCallable(fn);\n  return that === undefined ? fn : NATIVE_BIND ? bind(fn, that) : function (/* ...args */) {\n    return fn.apply(that, arguments);\n  };\n};\n","'use strict';\nvar fails = require('../internals/fails');\n\nmodule.exports = !fails(function () {\n  // eslint-disable-next-line es/no-function-prototype-bind -- safe\n  var test = (function () { /* empty */ }).bind();\n  // eslint-disable-next-line no-prototype-builtins -- safe\n  return typeof test != 'function' || test.hasOwnProperty('prototype');\n});\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar call = Function.prototype.call;\n\nmodule.exports = NATIVE_BIND ? call.bind(call) : function () {\n  return call.apply(call, arguments);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar hasOwn = require('../internals/has-own-property');\n\nvar FunctionPrototype = Function.prototype;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getDescriptor = DESCRIPTORS && Object.getOwnPropertyDescriptor;\n\nvar EXISTS = hasOwn(FunctionPrototype, 'name');\n// additional protection from minified / mangled / dropped function names\nvar PROPER = EXISTS && (function something() { /* empty */ }).name === 'something';\nvar CONFIGURABLE = EXISTS && (!DESCRIPTORS || (DESCRIPTORS && getDescriptor(FunctionPrototype, 'name').configurable));\n\nmodule.exports = {\n  EXISTS: EXISTS,\n  PROPER: PROPER,\n  CONFIGURABLE: CONFIGURABLE\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\n\nmodule.exports = function (object, key, method) {\n  try {\n    // eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\n    return uncurryThis(aCallable(Object.getOwnPropertyDescriptor(object, key)[method]));\n  } catch (error) { /* empty */ }\n};\n","'use strict';\nvar classofRaw = require('../internals/classof-raw');\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = function (fn) {\n  // Nashorn bug:\n  //   https://github.com/zloirock/core-js/issues/1128\n  //   https://github.com/zloirock/core-js/issues/1130\n  if (classofRaw(fn) === 'Function') return uncurryThis(fn);\n};\n","'use strict';\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar FunctionPrototype = Function.prototype;\nvar call = FunctionPrototype.call;\nvar uncurryThisWithBind = NATIVE_BIND && FunctionPrototype.bind.bind(call, call);\n\nmodule.exports = NATIVE_BIND ? uncurryThisWithBind : function (fn) {\n  return function () {\n    return call.apply(fn, arguments);\n  };\n};\n","'use strict';\nvar global = require('../internals/global');\nvar isCallable = require('../internals/is-callable');\n\nvar aFunction = function (argument) {\n  return isCallable(argument) ? argument : undefined;\n};\n\nmodule.exports = function (namespace, method) {\n  return arguments.length < 2 ? aFunction(global[namespace]) : global[namespace] && global[namespace][method];\n};\n","'use strict';\nvar classof = require('../internals/classof');\nvar getMethod = require('../internals/get-method');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar Iterators = require('../internals/iterators');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar ITERATOR = wellKnownSymbol('iterator');\n\nmodule.exports = function (it) {\n  if (!isNullOrUndefined(it)) return getMethod(it, ITERATOR)\n    || getMethod(it, '@@iterator')\n    || Iterators[classof(it)];\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar getIteratorMethod = require('../internals/get-iterator-method');\n\nvar $TypeError = TypeError;\n\nmodule.exports = function (argument, usingIterator) {\n  var iteratorMethod = arguments.length < 2 ? getIteratorMethod(argument) : usingIterator;\n  if (aCallable(iteratorMethod)) return anObject(call(iteratorMethod, argument));\n  throw new $TypeError(tryToString(argument) + ' is not iterable');\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isArray = require('../internals/is-array');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar toString = require('../internals/to-string');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (replacer) {\n  if (isCallable(replacer)) return replacer;\n  if (!isArray(replacer)) return;\n  var rawLength = replacer.length;\n  var keys = [];\n  for (var i = 0; i < rawLength; i++) {\n    var element = replacer[i];\n    if (typeof element == 'string') push(keys, element);\n    else if (typeof element == 'number' || classof(element) === 'Number' || classof(element) === 'String') push(keys, toString(element));\n  }\n  var keysLength = keys.length;\n  var root = true;\n  return function (key, value) {\n    if (root) {\n      root = false;\n      return value;\n    }\n    if (isArray(this)) return value;\n    for (var j = 0; j < keysLength; j++) if (keys[j] === key) return value;\n  };\n};\n","'use strict';\nvar aCallable = require('../internals/a-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\n// `GetMethod` abstract operation\n// https://tc39.es/ecma262/#sec-getmethod\nmodule.exports = function (V, P) {\n  var func = V[P];\n  return isNullOrUndefined(func) ? undefined : aCallable(func);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar floor = Math.floor;\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n// eslint-disable-next-line redos/no-vulnerable -- safe\nvar SUBSTITUTION_SYMBOLS = /\\$([$&'`]|\\d{1,2}|<[^>]*>)/g;\nvar SUBSTITUTION_SYMBOLS_NO_NAMED = /\\$([$&'`]|\\d{1,2})/g;\n\n// `GetSubstitution` abstract operation\n// https://tc39.es/ecma262/#sec-getsubstitution\nmodule.exports = function (matched, str, position, captures, namedCaptures, replacement) {\n  var tailPos = position + matched.length;\n  var m = captures.length;\n  var symbols = SUBSTITUTION_SYMBOLS_NO_NAMED;\n  if (namedCaptures !== undefined) {\n    namedCaptures = toObject(namedCaptures);\n    symbols = SUBSTITUTION_SYMBOLS;\n  }\n  return replace(replacement, symbols, function (match, ch) {\n    var capture;\n    switch (charAt(ch, 0)) {\n      case '$': return '$';\n      case '&': return matched;\n      case '`': return stringSlice(str, 0, position);\n      case \"'\": return stringSlice(str, tailPos);\n      case '<':\n        capture = namedCaptures[stringSlice(ch, 1, -1)];\n        break;\n      default: // \\d\\d?\n        var n = +ch;\n        if (n === 0) return match;\n        if (n > m) {\n          var f = floor(n / 10);\n          if (f === 0) return match;\n          if (f <= m) return captures[f - 1] === undefined ? charAt(ch, 1) : captures[f - 1] + charAt(ch, 1);\n          return match;\n        }\n        capture = captures[n - 1];\n    }\n    return capture === undefined ? '' : capture;\n  });\n};\n","'use strict';\nvar check = function (it) {\n  return it && it.Math === Math && it;\n};\n\n// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nmodule.exports =\n  // eslint-disable-next-line es/no-global-this -- safe\n  check(typeof globalThis == 'object' && globalThis) ||\n  check(typeof window == 'object' && window) ||\n  // eslint-disable-next-line no-restricted-globals -- safe\n  check(typeof self == 'object' && self) ||\n  check(typeof global == 'object' && global) ||\n  check(typeof this == 'object' && this) ||\n  // eslint-disable-next-line no-new-func -- fallback\n  (function () { return this; })() || Function('return this')();\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toObject = require('../internals/to-object');\n\nvar hasOwnProperty = uncurryThis({}.hasOwnProperty);\n\n// `HasOwnProperty` abstract operation\n// https://tc39.es/ecma262/#sec-hasownproperty\n// eslint-disable-next-line es/no-object-hasown -- safe\nmodule.exports = Object.hasOwn || function hasOwn(it, key) {\n  return hasOwnProperty(toObject(it), key);\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nmodule.exports = function (a, b) {\n  try {\n    // eslint-disable-next-line no-console -- safe\n    arguments.length === 1 ? console.error(a) : console.error(a, b);\n  } catch (error) { /* empty */ }\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\n\nmodule.exports = getBuiltIn('document', 'documentElement');\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\nvar createElement = require('../internals/document-create-element');\n\n// Thanks to IE8 for its funny defineProperty\nmodule.exports = !DESCRIPTORS && !fails(function () {\n  // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n  return Object.defineProperty(createElement('div'), 'a', {\n    get: function () { return 7; }\n  }).a !== 7;\n});\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar classof = require('../internals/classof-raw');\n\nvar $Object = Object;\nvar split = uncurryThis(''.split);\n\n// fallback for non-array-like ES3 and non-enumerable old V8 strings\nmodule.exports = fails(function () {\n  // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346\n  // eslint-disable-next-line no-prototype-builtins -- safe\n  return !$Object('z').propertyIsEnumerable(0);\n}) ? function (it) {\n  return classof(it) === 'String' ? split(it, '') : $Object(it);\n} : $Object;\n","'use strict';\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\n\n// makes subclassing work correct for wrapped built-ins\nmodule.exports = function ($this, dummy, Wrapper) {\n  var NewTarget, NewTargetPrototype;\n  if (\n    // it can work only with native `setPrototypeOf`\n    setPrototypeOf &&\n    // we haven't completely correct pre-ES6 way for getting `new.target`, so use this\n    isCallable(NewTarget = dummy.constructor) &&\n    NewTarget !== Wrapper &&\n    isObject(NewTargetPrototype = NewTarget.prototype) &&\n    NewTargetPrototype !== Wrapper.prototype\n  ) setPrototypeOf($this, NewTargetPrototype);\n  return $this;\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isCallable = require('../internals/is-callable');\nvar store = require('../internals/shared-store');\n\nvar functionToString = uncurryThis(Function.toString);\n\n// this helper broken in `[email protected]`, so we can't use `shared` helper\nif (!isCallable(store.inspectSource)) {\n  store.inspectSource = function (it) {\n    return functionToString(it);\n  };\n}\n\nmodule.exports = store.inspectSource;\n","'use strict';\nvar NATIVE_WEAK_MAP = require('../internals/weak-map-basic-detection');\nvar global = require('../internals/global');\nvar isObject = require('../internals/is-object');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar hasOwn = require('../internals/has-own-property');\nvar shared = require('../internals/shared-store');\nvar sharedKey = require('../internals/shared-key');\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar OBJECT_ALREADY_INITIALIZED = 'Object already initialized';\nvar TypeError = global.TypeError;\nvar WeakMap = global.WeakMap;\nvar set, get, has;\n\nvar enforce = function (it) {\n  return has(it) ? get(it) : set(it, {});\n};\n\nvar getterFor = function (TYPE) {\n  return function (it) {\n    var state;\n    if (!isObject(it) || (state = get(it)).type !== TYPE) {\n      throw new TypeError('Incompatible receiver, ' + TYPE + ' required');\n    } return state;\n  };\n};\n\nif (NATIVE_WEAK_MAP || shared.state) {\n  var store = shared.state || (shared.state = new WeakMap());\n  /* eslint-disable no-self-assign -- prototype methods protection */\n  store.get = store.get;\n  store.has = store.has;\n  store.set = store.set;\n  /* eslint-enable no-self-assign -- prototype methods protection */\n  set = function (it, metadata) {\n    if (store.has(it)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n    metadata.facade = it;\n    store.set(it, metadata);\n    return metadata;\n  };\n  get = function (it) {\n    return store.get(it) || {};\n  };\n  has = function (it) {\n    return store.has(it);\n  };\n} else {\n  var STATE = sharedKey('state');\n  hiddenKeys[STATE] = true;\n  set = function (it, metadata) {\n    if (hasOwn(it, STATE)) throw new TypeError(OBJECT_ALREADY_INITIALIZED);\n    metadata.facade = it;\n    createNonEnumerableProperty(it, STATE, metadata);\n    return metadata;\n  };\n  get = function (it) {\n    return hasOwn(it, STATE) ? it[STATE] : {};\n  };\n  has = function (it) {\n    return hasOwn(it, STATE);\n  };\n}\n\nmodule.exports = {\n  set: set,\n  get: get,\n  has: has,\n  enforce: enforce,\n  getterFor: getterFor\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar Iterators = require('../internals/iterators');\n\nvar ITERATOR = wellKnownSymbol('iterator');\nvar ArrayPrototype = Array.prototype;\n\n// check on default Array iterator\nmodule.exports = function (it) {\n  return it !== undefined && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it);\n};\n","'use strict';\nvar classof = require('../internals/classof-raw');\n\n// `IsArray` abstract operation\n// https://tc39.es/ecma262/#sec-isarray\n// eslint-disable-next-line es/no-array-isarray -- safe\nmodule.exports = Array.isArray || function isArray(argument) {\n  return classof(argument) === 'Array';\n};\n","'use strict';\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot\nvar documentAll = typeof document == 'object' && document.all;\n\n// `IsCallable` abstract operation\n// https://tc39.es/ecma262/#sec-iscallable\n// eslint-disable-next-line unicorn/no-typeof-undefined -- required for testing\nmodule.exports = typeof documentAll == 'undefined' && documentAll !== undefined ? function (argument) {\n  return typeof argument == 'function' || argument === documentAll;\n} : function (argument) {\n  return typeof argument == 'function';\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof');\nvar getBuiltIn = require('../internals/get-built-in');\nvar inspectSource = require('../internals/inspect-source');\n\nvar noop = function () { /* empty */ };\nvar construct = getBuiltIn('Reflect', 'construct');\nvar constructorRegExp = /^\\s*(?:class|function)\\b/;\nvar exec = uncurryThis(constructorRegExp.exec);\nvar INCORRECT_TO_STRING = !constructorRegExp.test(noop);\n\nvar isConstructorModern = function isConstructor(argument) {\n  if (!isCallable(argument)) return false;\n  try {\n    construct(noop, [], argument);\n    return true;\n  } catch (error) {\n    return false;\n  }\n};\n\nvar isConstructorLegacy = function isConstructor(argument) {\n  if (!isCallable(argument)) return false;\n  switch (classof(argument)) {\n    case 'AsyncFunction':\n    case 'GeneratorFunction':\n    case 'AsyncGeneratorFunction': return false;\n  }\n  try {\n    // we can't check .prototype since constructors produced by .bind haven't it\n    // `Function#toString` throws on some built-it function in some legacy engines\n    // (for example, `DOMQuad` and similar in FF41-)\n    return INCORRECT_TO_STRING || !!exec(constructorRegExp, inspectSource(argument));\n  } catch (error) {\n    return true;\n  }\n};\n\nisConstructorLegacy.sham = true;\n\n// `IsConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-isconstructor\nmodule.exports = !construct || fails(function () {\n  var called;\n  return isConstructorModern(isConstructorModern.call)\n    || !isConstructorModern(Object)\n    || !isConstructorModern(function () { called = true; })\n    || called;\n}) ? isConstructorLegacy : isConstructorModern;\n","'use strict';\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\n\nvar replacement = /#|\\.prototype\\./;\n\nvar isForced = function (feature, detection) {\n  var value = data[normalize(feature)];\n  return value === POLYFILL ? true\n    : value === NATIVE ? false\n    : isCallable(detection) ? fails(detection)\n    : !!detection;\n};\n\nvar normalize = isForced.normalize = function (string) {\n  return String(string).replace(replacement, '.').toLowerCase();\n};\n\nvar data = isForced.data = {};\nvar NATIVE = isForced.NATIVE = 'N';\nvar POLYFILL = isForced.POLYFILL = 'P';\n\nmodule.exports = isForced;\n","'use strict';\n// we can't use just `it == null` since of `document.all` special case\n// https://tc39.es/ecma262/#sec-IsHTMLDDA-internal-slot-aec\nmodule.exports = function (it) {\n  return it === null || it === undefined;\n};\n","'use strict';\nvar isCallable = require('../internals/is-callable');\n\nmodule.exports = function (it) {\n  return typeof it == 'object' ? it !== null : isCallable(it);\n};\n","'use strict';\nvar isObject = require('../internals/is-object');\n\nmodule.exports = function (argument) {\n  return isObject(argument) || argument === null;\n};\n","'use strict';\nmodule.exports = false;\n","'use strict';\nvar isObject = require('../internals/is-object');\nvar classof = require('../internals/classof-raw');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar MATCH = wellKnownSymbol('match');\n\n// `IsRegExp` abstract operation\n// https://tc39.es/ecma262/#sec-isregexp\nmodule.exports = function (it) {\n  var isRegExp;\n  return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classof(it) === 'RegExp');\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar $Object = Object;\n\nmodule.exports = USE_SYMBOL_AS_UID ? function (it) {\n  return typeof it == 'symbol';\n} : function (it) {\n  var $Symbol = getBuiltIn('Symbol');\n  return isCallable($Symbol) && isPrototypeOf($Symbol.prototype, $Object(it));\n};\n","'use strict';\nvar bind = require('../internals/function-bind-context');\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar tryToString = require('../internals/try-to-string');\nvar isArrayIteratorMethod = require('../internals/is-array-iterator-method');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar getIterator = require('../internals/get-iterator');\nvar getIteratorMethod = require('../internals/get-iterator-method');\nvar iteratorClose = require('../internals/iterator-close');\n\nvar $TypeError = TypeError;\n\nvar Result = function (stopped, result) {\n  this.stopped = stopped;\n  this.result = result;\n};\n\nvar ResultPrototype = Result.prototype;\n\nmodule.exports = function (iterable, unboundFunction, options) {\n  var that = options && options.that;\n  var AS_ENTRIES = !!(options && options.AS_ENTRIES);\n  var IS_RECORD = !!(options && options.IS_RECORD);\n  var IS_ITERATOR = !!(options && options.IS_ITERATOR);\n  var INTERRUPTED = !!(options && options.INTERRUPTED);\n  var fn = bind(unboundFunction, that);\n  var iterator, iterFn, index, length, result, next, step;\n\n  var stop = function (condition) {\n    if (iterator) iteratorClose(iterator, 'normal', condition);\n    return new Result(true, condition);\n  };\n\n  var callFn = function (value) {\n    if (AS_ENTRIES) {\n      anObject(value);\n      return INTERRUPTED ? fn(value[0], value[1], stop) : fn(value[0], value[1]);\n    } return INTERRUPTED ? fn(value, stop) : fn(value);\n  };\n\n  if (IS_RECORD) {\n    iterator = iterable.iterator;\n  } else if (IS_ITERATOR) {\n    iterator = iterable;\n  } else {\n    iterFn = getIteratorMethod(iterable);\n    if (!iterFn) throw new $TypeError(tryToString(iterable) + ' is not iterable');\n    // optimisation for array iterators\n    if (isArrayIteratorMethod(iterFn)) {\n      for (index = 0, length = lengthOfArrayLike(iterable); length > index; index++) {\n        result = callFn(iterable[index]);\n        if (result && isPrototypeOf(ResultPrototype, result)) return result;\n      } return new Result(false);\n    }\n    iterator = getIterator(iterable, iterFn);\n  }\n\n  next = IS_RECORD ? iterable.next : iterator.next;\n  while (!(step = call(next, iterator)).done) {\n    try {\n      result = callFn(step.value);\n    } catch (error) {\n      iteratorClose(iterator, 'throw', error);\n    }\n    if (typeof result == 'object' && result && isPrototypeOf(ResultPrototype, result)) return result;\n  } return new Result(false);\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar getMethod = require('../internals/get-method');\n\nmodule.exports = function (iterator, kind, value) {\n  var innerResult, innerError;\n  anObject(iterator);\n  try {\n    innerResult = getMethod(iterator, 'return');\n    if (!innerResult) {\n      if (kind === 'throw') throw value;\n      return value;\n    }\n    innerResult = call(innerResult, iterator);\n  } catch (error) {\n    innerError = true;\n    innerResult = error;\n  }\n  if (kind === 'throw') throw value;\n  if (innerError) throw innerResult;\n  anObject(innerResult);\n  return value;\n};\n","'use strict';\nmodule.exports = {};\n","'use strict';\nvar toLength = require('../internals/to-length');\n\n// `LengthOfArrayLike` abstract operation\n// https://tc39.es/ecma262/#sec-lengthofarraylike\nmodule.exports = function (obj) {\n  return toLength(obj.length);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar CONFIGURABLE_FUNCTION_NAME = require('../internals/function-name').CONFIGURABLE;\nvar inspectSource = require('../internals/inspect-source');\nvar InternalStateModule = require('../internals/internal-state');\n\nvar enforceInternalState = InternalStateModule.enforce;\nvar getInternalState = InternalStateModule.get;\nvar $String = String;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar defineProperty = Object.defineProperty;\nvar stringSlice = uncurryThis(''.slice);\nvar replace = uncurryThis(''.replace);\nvar join = uncurryThis([].join);\n\nvar CONFIGURABLE_LENGTH = DESCRIPTORS && !fails(function () {\n  return defineProperty(function () { /* empty */ }, 'length', { value: 8 }).length !== 8;\n});\n\nvar TEMPLATE = String(String).split('String');\n\nvar makeBuiltIn = module.exports = function (value, name, options) {\n  if (stringSlice($String(name), 0, 7) === 'Symbol(') {\n    name = '[' + replace($String(name), /^Symbol\\(([^)]*)\\).*$/, '$1') + ']';\n  }\n  if (options && options.getter) name = 'get ' + name;\n  if (options && options.setter) name = 'set ' + name;\n  if (!hasOwn(value, 'name') || (CONFIGURABLE_FUNCTION_NAME && value.name !== name)) {\n    if (DESCRIPTORS) defineProperty(value, 'name', { value: name, configurable: true });\n    else value.name = name;\n  }\n  if (CONFIGURABLE_LENGTH && options && hasOwn(options, 'arity') && value.length !== options.arity) {\n    defineProperty(value, 'length', { value: options.arity });\n  }\n  try {\n    if (options && hasOwn(options, 'constructor') && options.constructor) {\n      if (DESCRIPTORS) defineProperty(value, 'prototype', { writable: false });\n    // in V8 ~ Chrome 53, prototypes of some methods, like `Array.prototype.values`, are non-writable\n    } else if (value.prototype) value.prototype = undefined;\n  } catch (error) { /* empty */ }\n  var state = enforceInternalState(value);\n  if (!hasOwn(state, 'source')) {\n    state.source = join(TEMPLATE, typeof name == 'string' ? name : '');\n  } return value;\n};\n\n// add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative\n// eslint-disable-next-line no-extend-native -- required\nFunction.prototype.toString = makeBuiltIn(function toString() {\n  return isCallable(this) && getInternalState(this).source || inspectSource(this);\n}, 'toString');\n","'use strict';\nvar ceil = Math.ceil;\nvar floor = Math.floor;\n\n// `Math.trunc` method\n// https://tc39.es/ecma262/#sec-math.trunc\n// eslint-disable-next-line es/no-math-trunc -- safe\nmodule.exports = Math.trunc || function trunc(x) {\n  var n = +x;\n  return (n > 0 ? floor : ceil)(n);\n};\n","'use strict';\nvar global = require('../internals/global');\nvar safeGetBuiltIn = require('../internals/safe-get-built-in');\nvar bind = require('../internals/function-bind-context');\nvar macrotask = require('../internals/task').set;\nvar Queue = require('../internals/queue');\nvar IS_IOS = require('../internals/engine-is-ios');\nvar IS_IOS_PEBBLE = require('../internals/engine-is-ios-pebble');\nvar IS_WEBOS_WEBKIT = require('../internals/engine-is-webos-webkit');\nvar IS_NODE = require('../internals/engine-is-node');\n\nvar MutationObserver = global.MutationObserver || global.WebKitMutationObserver;\nvar document = global.document;\nvar process = global.process;\nvar Promise = global.Promise;\nvar microtask = safeGetBuiltIn('queueMicrotask');\nvar notify, toggle, node, promise, then;\n\n// modern engines have queueMicrotask method\nif (!microtask) {\n  var queue = new Queue();\n\n  var flush = function () {\n    var parent, fn;\n    if (IS_NODE && (parent = process.domain)) parent.exit();\n    while (fn = queue.get()) try {\n      fn();\n    } catch (error) {\n      if (queue.head) notify();\n      throw error;\n    }\n    if (parent) parent.enter();\n  };\n\n  // browsers with MutationObserver, except iOS - https://github.com/zloirock/core-js/issues/339\n  // also except WebOS Webkit https://github.com/zloirock/core-js/issues/898\n  if (!IS_IOS && !IS_NODE && !IS_WEBOS_WEBKIT && MutationObserver && document) {\n    toggle = true;\n    node = document.createTextNode('');\n    new MutationObserver(flush).observe(node, { characterData: true });\n    notify = function () {\n      node.data = toggle = !toggle;\n    };\n  // environments with maybe non-completely correct, but existent Promise\n  } else if (!IS_IOS_PEBBLE && Promise && Promise.resolve) {\n    // Promise.resolve without an argument throws an error in LG WebOS 2\n    promise = Promise.resolve(undefined);\n    // workaround of WebKit ~ iOS Safari 10.1 bug\n    promise.constructor = Promise;\n    then = bind(promise.then, promise);\n    notify = function () {\n      then(flush);\n    };\n  // Node.js without promises\n  } else if (IS_NODE) {\n    notify = function () {\n      process.nextTick(flush);\n    };\n  // for other environments - macrotask based on:\n  // - setImmediate\n  // - MessageChannel\n  // - window.postMessage\n  // - onreadystatechange\n  // - setTimeout\n  } else {\n    // `webpack` dev server bug on IE global methods - use bind(fn, global)\n    macrotask = bind(macrotask, global);\n    notify = function () {\n      macrotask(flush);\n    };\n  }\n\n  microtask = function (fn) {\n    if (!queue.head) notify();\n    queue.add(fn);\n  };\n}\n\nmodule.exports = microtask;\n","'use strict';\nvar aCallable = require('../internals/a-callable');\n\nvar $TypeError = TypeError;\n\nvar PromiseCapability = function (C) {\n  var resolve, reject;\n  this.promise = new C(function ($$resolve, $$reject) {\n    if (resolve !== undefined || reject !== undefined) throw new $TypeError('Bad Promise constructor');\n    resolve = $$resolve;\n    reject = $$reject;\n  });\n  this.resolve = aCallable(resolve);\n  this.reject = aCallable(reject);\n};\n\n// `NewPromiseCapability` abstract operation\n// https://tc39.es/ecma262/#sec-newpromisecapability\nmodule.exports.f = function (C) {\n  return new PromiseCapability(C);\n};\n","'use strict';\n/* global ActiveXObject -- old IE, WSH */\nvar anObject = require('../internals/an-object');\nvar definePropertiesModule = require('../internals/object-define-properties');\nvar enumBugKeys = require('../internals/enum-bug-keys');\nvar hiddenKeys = require('../internals/hidden-keys');\nvar html = require('../internals/html');\nvar documentCreateElement = require('../internals/document-create-element');\nvar sharedKey = require('../internals/shared-key');\n\nvar GT = '>';\nvar LT = '<';\nvar PROTOTYPE = 'prototype';\nvar SCRIPT = 'script';\nvar IE_PROTO = sharedKey('IE_PROTO');\n\nvar EmptyConstructor = function () { /* empty */ };\n\nvar scriptTag = function (content) {\n  return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT;\n};\n\n// Create object with fake `null` prototype: use ActiveX Object with cleared prototype\nvar NullProtoObjectViaActiveX = function (activeXDocument) {\n  activeXDocument.write(scriptTag(''));\n  activeXDocument.close();\n  var temp = activeXDocument.parentWindow.Object;\n  activeXDocument = null; // avoid memory leak\n  return temp;\n};\n\n// Create object with fake `null` prototype: use iframe Object with cleared prototype\nvar NullProtoObjectViaIFrame = function () {\n  // Thrash, waste and sodomy: IE GC bug\n  var iframe = documentCreateElement('iframe');\n  var JS = 'java' + SCRIPT + ':';\n  var iframeDocument;\n  iframe.style.display = 'none';\n  html.appendChild(iframe);\n  // https://github.com/zloirock/core-js/issues/475\n  iframe.src = String(JS);\n  iframeDocument = iframe.contentWindow.document;\n  iframeDocument.open();\n  iframeDocument.write(scriptTag('document.F=Object'));\n  iframeDocument.close();\n  return iframeDocument.F;\n};\n\n// Check for document.domain and active x support\n// No need to use active x approach when document.domain is not set\n// see https://github.com/es-shims/es5-shim/issues/150\n// variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346\n// avoid IE GC bug\nvar activeXDocument;\nvar NullProtoObject = function () {\n  try {\n    activeXDocument = new ActiveXObject('htmlfile');\n  } catch (error) { /* ignore */ }\n  NullProtoObject = typeof document != 'undefined'\n    ? document.domain && activeXDocument\n      ? NullProtoObjectViaActiveX(activeXDocument) // old IE\n      : NullProtoObjectViaIFrame()\n    : NullProtoObjectViaActiveX(activeXDocument); // WSH\n  var length = enumBugKeys.length;\n  while (length--) delete NullProtoObject[PROTOTYPE][enumBugKeys[length]];\n  return NullProtoObject();\n};\n\nhiddenKeys[IE_PROTO] = true;\n\n// `Object.create` method\n// https://tc39.es/ecma262/#sec-object.create\n// eslint-disable-next-line es/no-object-create -- safe\nmodule.exports = Object.create || function create(O, Properties) {\n  var result;\n  if (O !== null) {\n    EmptyConstructor[PROTOTYPE] = anObject(O);\n    result = new EmptyConstructor();\n    EmptyConstructor[PROTOTYPE] = null;\n    // add \"__proto__\" for Object.getPrototypeOf polyfill\n    result[IE_PROTO] = O;\n  } else result = NullProtoObject();\n  return Properties === undefined ? result : definePropertiesModule.f(result, Properties);\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar definePropertyModule = require('../internals/object-define-property');\nvar anObject = require('../internals/an-object');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar objectKeys = require('../internals/object-keys');\n\n// `Object.defineProperties` method\n// https://tc39.es/ecma262/#sec-object.defineproperties\n// eslint-disable-next-line es/no-object-defineproperties -- safe\nexports.f = DESCRIPTORS && !V8_PROTOTYPE_DEFINE_BUG ? Object.defineProperties : function defineProperties(O, Properties) {\n  anObject(O);\n  var props = toIndexedObject(Properties);\n  var keys = objectKeys(Properties);\n  var length = keys.length;\n  var index = 0;\n  var key;\n  while (length > index) definePropertyModule.f(O, key = keys[index++], props[key]);\n  return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\nvar V8_PROTOTYPE_DEFINE_BUG = require('../internals/v8-prototype-define-bug');\nvar anObject = require('../internals/an-object');\nvar toPropertyKey = require('../internals/to-property-key');\n\nvar $TypeError = TypeError;\n// eslint-disable-next-line es/no-object-defineproperty -- safe\nvar $defineProperty = Object.defineProperty;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar ENUMERABLE = 'enumerable';\nvar CONFIGURABLE = 'configurable';\nvar WRITABLE = 'writable';\n\n// `Object.defineProperty` method\n// https://tc39.es/ecma262/#sec-object.defineproperty\nexports.f = DESCRIPTORS ? V8_PROTOTYPE_DEFINE_BUG ? function defineProperty(O, P, Attributes) {\n  anObject(O);\n  P = toPropertyKey(P);\n  anObject(Attributes);\n  if (typeof O === 'function' && P === 'prototype' && 'value' in Attributes && WRITABLE in Attributes && !Attributes[WRITABLE]) {\n    var current = $getOwnPropertyDescriptor(O, P);\n    if (current && current[WRITABLE]) {\n      O[P] = Attributes.value;\n      Attributes = {\n        configurable: CONFIGURABLE in Attributes ? Attributes[CONFIGURABLE] : current[CONFIGURABLE],\n        enumerable: ENUMERABLE in Attributes ? Attributes[ENUMERABLE] : current[ENUMERABLE],\n        writable: false\n      };\n    }\n  } return $defineProperty(O, P, Attributes);\n} : $defineProperty : function defineProperty(O, P, Attributes) {\n  anObject(O);\n  P = toPropertyKey(P);\n  anObject(Attributes);\n  if (IE8_DOM_DEFINE) try {\n    return $defineProperty(O, P, Attributes);\n  } catch (error) { /* empty */ }\n  if ('get' in Attributes || 'set' in Attributes) throw new $TypeError('Accessors not supported');\n  if ('value' in Attributes) O[P] = Attributes.value;\n  return O;\n};\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar call = require('../internals/function-call');\nvar propertyIsEnumerableModule = require('../internals/object-property-is-enumerable');\nvar createPropertyDescriptor = require('../internals/create-property-descriptor');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar toPropertyKey = require('../internals/to-property-key');\nvar hasOwn = require('../internals/has-own-property');\nvar IE8_DOM_DEFINE = require('../internals/ie8-dom-define');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar $getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// `Object.getOwnPropertyDescriptor` method\n// https://tc39.es/ecma262/#sec-object.getownpropertydescriptor\nexports.f = DESCRIPTORS ? $getOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) {\n  O = toIndexedObject(O);\n  P = toPropertyKey(P);\n  if (IE8_DOM_DEFINE) try {\n    return $getOwnPropertyDescriptor(O, P);\n  } catch (error) { /* empty */ }\n  if (hasOwn(O, P)) return createPropertyDescriptor(!call(propertyIsEnumerableModule.f, O, P), O[P]);\n};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\nvar hiddenKeys = enumBugKeys.concat('length', 'prototype');\n\n// `Object.getOwnPropertyNames` method\n// https://tc39.es/ecma262/#sec-object.getownpropertynames\n// eslint-disable-next-line es/no-object-getownpropertynames -- safe\nexports.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) {\n  return internalObjectKeys(O, hiddenKeys);\n};\n","'use strict';\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- safe\nexports.f = Object.getOwnPropertySymbols;\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nmodule.exports = uncurryThis({}.isPrototypeOf);\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar toIndexedObject = require('../internals/to-indexed-object');\nvar indexOf = require('../internals/array-includes').indexOf;\nvar hiddenKeys = require('../internals/hidden-keys');\n\nvar push = uncurryThis([].push);\n\nmodule.exports = function (object, names) {\n  var O = toIndexedObject(object);\n  var i = 0;\n  var result = [];\n  var key;\n  for (key in O) !hasOwn(hiddenKeys, key) && hasOwn(O, key) && push(result, key);\n  // Don't enum bug & hidden keys\n  while (names.length > i) if (hasOwn(O, key = names[i++])) {\n    ~indexOf(result, key) || push(result, key);\n  }\n  return result;\n};\n","'use strict';\nvar internalObjectKeys = require('../internals/object-keys-internal');\nvar enumBugKeys = require('../internals/enum-bug-keys');\n\n// `Object.keys` method\n// https://tc39.es/ecma262/#sec-object.keys\n// eslint-disable-next-line es/no-object-keys -- safe\nmodule.exports = Object.keys || function keys(O) {\n  return internalObjectKeys(O, enumBugKeys);\n};\n","'use strict';\nvar $propertyIsEnumerable = {}.propertyIsEnumerable;\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Nashorn ~ JDK8 bug\nvar NASHORN_BUG = getOwnPropertyDescriptor && !$propertyIsEnumerable.call({ 1: 2 }, 1);\n\n// `Object.prototype.propertyIsEnumerable` method implementation\n// https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable\nexports.f = NASHORN_BUG ? function propertyIsEnumerable(V) {\n  var descriptor = getOwnPropertyDescriptor(this, V);\n  return !!descriptor && descriptor.enumerable;\n} : $propertyIsEnumerable;\n","'use strict';\n/* eslint-disable no-proto -- safe */\nvar uncurryThisAccessor = require('../internals/function-uncurry-this-accessor');\nvar isObject = require('../internals/is-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar aPossiblePrototype = require('../internals/a-possible-prototype');\n\n// `Object.setPrototypeOf` method\n// https://tc39.es/ecma262/#sec-object.setprototypeof\n// Works with __proto__ only. Old v8 can't work with null proto objects.\n// eslint-disable-next-line es/no-object-setprototypeof -- safe\nmodule.exports = Object.setPrototypeOf || ('__proto__' in {} ? function () {\n  var CORRECT_SETTER = false;\n  var test = {};\n  var setter;\n  try {\n    setter = uncurryThisAccessor(Object.prototype, '__proto__', 'set');\n    setter(test, []);\n    CORRECT_SETTER = test instanceof Array;\n  } catch (error) { /* empty */ }\n  return function setPrototypeOf(O, proto) {\n    requireObjectCoercible(O);\n    aPossiblePrototype(proto);\n    if (!isObject(O)) return O;\n    if (CORRECT_SETTER) setter(O, proto);\n    else O.__proto__ = proto;\n    return O;\n  };\n}() : undefined);\n","'use strict';\nvar call = require('../internals/function-call');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\n\nvar $TypeError = TypeError;\n\n// `OrdinaryToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-ordinarytoprimitive\nmodule.exports = function (input, pref) {\n  var fn, val;\n  if (pref === 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n  if (isCallable(fn = input.valueOf) && !isObject(val = call(fn, input))) return val;\n  if (pref !== 'string' && isCallable(fn = input.toString) && !isObject(val = call(fn, input))) return val;\n  throw new $TypeError(\"Can't convert object to primitive value\");\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar getOwnPropertyNamesModule = require('../internals/object-get-own-property-names');\nvar getOwnPropertySymbolsModule = require('../internals/object-get-own-property-symbols');\nvar anObject = require('../internals/an-object');\n\nvar concat = uncurryThis([].concat);\n\n// all object keys, includes non-enumerable and symbols\nmodule.exports = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) {\n  var keys = getOwnPropertyNamesModule.f(anObject(it));\n  var getOwnPropertySymbols = getOwnPropertySymbolsModule.f;\n  return getOwnPropertySymbols ? concat(keys, getOwnPropertySymbols(it)) : keys;\n};\n","'use strict';\nmodule.exports = function (exec) {\n  try {\n    return { error: false, value: exec() };\n  } catch (error) {\n    return { error: true, value: error };\n  }\n};\n","'use strict';\nvar global = require('../internals/global');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar isCallable = require('../internals/is-callable');\nvar isForced = require('../internals/is-forced');\nvar inspectSource = require('../internals/inspect-source');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar IS_BROWSER = require('../internals/engine-is-browser');\nvar IS_DENO = require('../internals/engine-is-deno');\nvar IS_PURE = require('../internals/is-pure');\nvar V8_VERSION = require('../internals/engine-v8-version');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar SPECIES = wellKnownSymbol('species');\nvar SUBCLASSING = false;\nvar NATIVE_PROMISE_REJECTION_EVENT = isCallable(global.PromiseRejectionEvent);\n\nvar FORCED_PROMISE_CONSTRUCTOR = isForced('Promise', function () {\n  var PROMISE_CONSTRUCTOR_SOURCE = inspectSource(NativePromiseConstructor);\n  var GLOBAL_CORE_JS_PROMISE = PROMISE_CONSTRUCTOR_SOURCE !== String(NativePromiseConstructor);\n  // V8 6.6 (Node 10 and Chrome 66) have a bug with resolving custom thenables\n  // https://bugs.chromium.org/p/chromium/issues/detail?id=830565\n  // We can't detect it synchronously, so just check versions\n  if (!GLOBAL_CORE_JS_PROMISE && V8_VERSION === 66) return true;\n  // We need Promise#{ catch, finally } in the pure version for preventing prototype pollution\n  if (IS_PURE && !(NativePromisePrototype['catch'] && NativePromisePrototype['finally'])) return true;\n  // We can't use @@species feature detection in V8 since it causes\n  // deoptimization and performance degradation\n  // https://github.com/zloirock/core-js/issues/679\n  if (!V8_VERSION || V8_VERSION < 51 || !/native code/.test(PROMISE_CONSTRUCTOR_SOURCE)) {\n    // Detect correctness of subclassing with @@species support\n    var promise = new NativePromiseConstructor(function (resolve) { resolve(1); });\n    var FakePromise = function (exec) {\n      exec(function () { /* empty */ }, function () { /* empty */ });\n    };\n    var constructor = promise.constructor = {};\n    constructor[SPECIES] = FakePromise;\n    SUBCLASSING = promise.then(function () { /* empty */ }) instanceof FakePromise;\n    if (!SUBCLASSING) return true;\n  // Unhandled rejections tracking support, NodeJS Promise without it fails @@species test\n  } return !GLOBAL_CORE_JS_PROMISE && (IS_BROWSER || IS_DENO) && !NATIVE_PROMISE_REJECTION_EVENT;\n});\n\nmodule.exports = {\n  CONSTRUCTOR: FORCED_PROMISE_CONSTRUCTOR,\n  REJECTION_EVENT: NATIVE_PROMISE_REJECTION_EVENT,\n  SUBCLASSING: SUBCLASSING\n};\n","'use strict';\nvar global = require('../internals/global');\n\nmodule.exports = global.Promise;\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar newPromiseCapability = require('../internals/new-promise-capability');\n\nmodule.exports = function (C, x) {\n  anObject(C);\n  if (isObject(x) && x.constructor === C) return x;\n  var promiseCapability = newPromiseCapability.f(C);\n  var resolve = promiseCapability.resolve;\n  resolve(x);\n  return promiseCapability.promise;\n};\n","'use strict';\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar checkCorrectnessOfIteration = require('../internals/check-correctness-of-iteration');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\nmodule.exports = FORCED_PROMISE_CONSTRUCTOR || !checkCorrectnessOfIteration(function (iterable) {\n  NativePromiseConstructor.all(iterable).then(undefined, function () { /* empty */ });\n});\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\n\nmodule.exports = function (Target, Source, key) {\n  key in Target || defineProperty(Target, key, {\n    configurable: true,\n    get: function () { return Source[key]; },\n    set: function (it) { Source[key] = it; }\n  });\n};\n","'use strict';\nvar Queue = function () {\n  this.head = null;\n  this.tail = null;\n};\n\nQueue.prototype = {\n  add: function (item) {\n    var entry = { item: item, next: null };\n    var tail = this.tail;\n    if (tail) tail.next = entry;\n    else this.head = entry;\n    this.tail = entry;\n  },\n  get: function () {\n    var entry = this.head;\n    if (entry) {\n      var next = this.head = entry.next;\n      if (next === null) this.tail = null;\n      return entry.item;\n    }\n  }\n};\n\nmodule.exports = Queue;\n","'use strict';\nvar call = require('../internals/function-call');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar classof = require('../internals/classof-raw');\nvar regexpExec = require('../internals/regexp-exec');\n\nvar $TypeError = TypeError;\n\n// `RegExpExec` abstract operation\n// https://tc39.es/ecma262/#sec-regexpexec\nmodule.exports = function (R, S) {\n  var exec = R.exec;\n  if (isCallable(exec)) {\n    var result = call(exec, R, S);\n    if (result !== null) anObject(result);\n    return result;\n  }\n  if (classof(R) === 'RegExp') return call(regexpExec, R, S);\n  throw new $TypeError('RegExp#exec called on incompatible receiver');\n};\n","'use strict';\n/* eslint-disable regexp/no-empty-capturing-group, regexp/no-empty-group, regexp/no-lazy-ends -- testing */\n/* eslint-disable regexp/no-useless-quantifier -- testing */\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toString = require('../internals/to-string');\nvar regexpFlags = require('../internals/regexp-flags');\nvar stickyHelpers = require('../internals/regexp-sticky-helpers');\nvar shared = require('../internals/shared');\nvar create = require('../internals/object-create');\nvar getInternalState = require('../internals/internal-state').get;\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar UNSUPPORTED_NCG = require('../internals/regexp-unsupported-ncg');\n\nvar nativeReplace = shared('native-string-replace', String.prototype.replace);\nvar nativeExec = RegExp.prototype.exec;\nvar patchedExec = nativeExec;\nvar charAt = uncurryThis(''.charAt);\nvar indexOf = uncurryThis(''.indexOf);\nvar replace = uncurryThis(''.replace);\nvar stringSlice = uncurryThis(''.slice);\n\nvar UPDATES_LAST_INDEX_WRONG = (function () {\n  var re1 = /a/;\n  var re2 = /b*/g;\n  call(nativeExec, re1, 'a');\n  call(nativeExec, re2, 'a');\n  return re1.lastIndex !== 0 || re2.lastIndex !== 0;\n})();\n\nvar UNSUPPORTED_Y = stickyHelpers.BROKEN_CARET;\n\n// nonparticipating capturing group, copied from es5-shim's String#split patch.\nvar NPCG_INCLUDED = /()??/.exec('')[1] !== undefined;\n\nvar PATCH = UPDATES_LAST_INDEX_WRONG || NPCG_INCLUDED || UNSUPPORTED_Y || UNSUPPORTED_DOT_ALL || UNSUPPORTED_NCG;\n\nif (PATCH) {\n  patchedExec = function exec(string) {\n    var re = this;\n    var state = getInternalState(re);\n    var str = toString(string);\n    var raw = state.raw;\n    var result, reCopy, lastIndex, match, i, object, group;\n\n    if (raw) {\n      raw.lastIndex = re.lastIndex;\n      result = call(patchedExec, raw, str);\n      re.lastIndex = raw.lastIndex;\n      return result;\n    }\n\n    var groups = state.groups;\n    var sticky = UNSUPPORTED_Y && re.sticky;\n    var flags = call(regexpFlags, re);\n    var source = re.source;\n    var charsAdded = 0;\n    var strCopy = str;\n\n    if (sticky) {\n      flags = replace(flags, 'y', '');\n      if (indexOf(flags, 'g') === -1) {\n        flags += 'g';\n      }\n\n      strCopy = stringSlice(str, re.lastIndex);\n      // Support anchored sticky behavior.\n      if (re.lastIndex > 0 && (!re.multiline || re.multiline && charAt(str, re.lastIndex - 1) !== '\\n')) {\n        source = '(?: ' + source + ')';\n        strCopy = ' ' + strCopy;\n        charsAdded++;\n      }\n      // ^(? + rx + ) is needed, in combination with some str slicing, to\n      // simulate the 'y' flag.\n      reCopy = new RegExp('^(?:' + source + ')', flags);\n    }\n\n    if (NPCG_INCLUDED) {\n      reCopy = new RegExp('^' + source + '$(?!\\\\s)', flags);\n    }\n    if (UPDATES_LAST_INDEX_WRONG) lastIndex = re.lastIndex;\n\n    match = call(nativeExec, sticky ? reCopy : re, strCopy);\n\n    if (sticky) {\n      if (match) {\n        match.input = stringSlice(match.input, charsAdded);\n        match[0] = stringSlice(match[0], charsAdded);\n        match.index = re.lastIndex;\n        re.lastIndex += match[0].length;\n      } else re.lastIndex = 0;\n    } else if (UPDATES_LAST_INDEX_WRONG && match) {\n      re.lastIndex = re.global ? match.index + match[0].length : lastIndex;\n    }\n    if (NPCG_INCLUDED && match && match.length > 1) {\n      // Fix browsers whose `exec` methods don't consistently return `undefined`\n      // for NPCG, like IE8. NOTE: This doesn't work for /(.?)?/\n      call(nativeReplace, match[0], reCopy, function () {\n        for (i = 1; i < arguments.length - 2; i++) {\n          if (arguments[i] === undefined) match[i] = undefined;\n        }\n      });\n    }\n\n    if (match && groups) {\n      match.groups = object = create(null);\n      for (i = 0; i < groups.length; i++) {\n        group = groups[i];\n        object[group[0]] = match[group[1]];\n      }\n    }\n\n    return match;\n  };\n}\n\nmodule.exports = patchedExec;\n","'use strict';\nvar anObject = require('../internals/an-object');\n\n// `RegExp.prototype.flags` getter implementation\n// https://tc39.es/ecma262/#sec-get-regexp.prototype.flags\nmodule.exports = function () {\n  var that = anObject(this);\n  var result = '';\n  if (that.hasIndices) result += 'd';\n  if (that.global) result += 'g';\n  if (that.ignoreCase) result += 'i';\n  if (that.multiline) result += 'm';\n  if (that.dotAll) result += 's';\n  if (that.unicode) result += 'u';\n  if (that.unicodeSets) result += 'v';\n  if (that.sticky) result += 'y';\n  return result;\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar hasOwn = require('../internals/has-own-property');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar regExpFlags = require('../internals/regexp-flags');\n\nvar RegExpPrototype = RegExp.prototype;\n\nmodule.exports = function (R) {\n  var flags = R.flags;\n  return flags === undefined && !('flags' in RegExpPrototype) && !hasOwn(R, 'flags') && isPrototypeOf(RegExpPrototype, R)\n    ? call(regExpFlags, R) : flags;\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('a', 'y') -> /a/y and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nvar UNSUPPORTED_Y = fails(function () {\n  var re = $RegExp('a', 'y');\n  re.lastIndex = 2;\n  return re.exec('abcd') !== null;\n});\n\n// UC Browser bug\n// https://github.com/zloirock/core-js/issues/1008\nvar MISSED_STICKY = UNSUPPORTED_Y || fails(function () {\n  return !$RegExp('a', 'y').sticky;\n});\n\nvar BROKEN_CARET = UNSUPPORTED_Y || fails(function () {\n  // https://bugzilla.mozilla.org/show_bug.cgi?id=773687\n  var re = $RegExp('^r', 'gy');\n  re.lastIndex = 2;\n  return re.exec('str') !== null;\n});\n\nmodule.exports = {\n  BROKEN_CARET: BROKEN_CARET,\n  MISSED_STICKY: MISSED_STICKY,\n  UNSUPPORTED_Y: UNSUPPORTED_Y\n};\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('.', 's') -> /./s and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nmodule.exports = fails(function () {\n  var re = $RegExp('.', 's');\n  return !(re.dotAll && re.test('\\n') && re.flags === 's');\n});\n","'use strict';\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\n// babel-minify and Closure Compiler transpiles RegExp('(?<a>b)', 'g') -> /(?<a>b)/g and it causes SyntaxError\nvar $RegExp = global.RegExp;\n\nmodule.exports = fails(function () {\n  var re = $RegExp('(?<a>b)', 'g');\n  return re.exec('b').groups.a !== 'b' ||\n    'b'.replace(re, '$<a>c') !== 'bc';\n});\n","'use strict';\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\n\nvar $TypeError = TypeError;\n\n// `RequireObjectCoercible` abstract operation\n// https://tc39.es/ecma262/#sec-requireobjectcoercible\nmodule.exports = function (it) {\n  if (isNullOrUndefined(it)) throw new $TypeError(\"Can't call method on \" + it);\n  return it;\n};\n","'use strict';\nvar global = require('../internals/global');\nvar DESCRIPTORS = require('../internals/descriptors');\n\n// eslint-disable-next-line es/no-object-getownpropertydescriptor -- safe\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\n\n// Avoid NodeJS experimental warning\nmodule.exports = function (name) {\n  if (!DESCRIPTORS) return global[name];\n  var descriptor = getOwnPropertyDescriptor(global, name);\n  return descriptor && descriptor.value;\n};\n","'use strict';\nvar getBuiltIn = require('../internals/get-built-in');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar DESCRIPTORS = require('../internals/descriptors');\n\nvar SPECIES = wellKnownSymbol('species');\n\nmodule.exports = function (CONSTRUCTOR_NAME) {\n  var Constructor = getBuiltIn(CONSTRUCTOR_NAME);\n\n  if (DESCRIPTORS && Constructor && !Constructor[SPECIES]) {\n    defineBuiltInAccessor(Constructor, SPECIES, {\n      configurable: true,\n      get: function () { return this; }\n    });\n  }\n};\n","'use strict';\nvar defineProperty = require('../internals/object-define-property').f;\nvar hasOwn = require('../internals/has-own-property');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\n\nmodule.exports = function (target, TAG, STATIC) {\n  if (target && !STATIC) target = target.prototype;\n  if (target && !hasOwn(target, TO_STRING_TAG)) {\n    defineProperty(target, TO_STRING_TAG, { configurable: true, value: TAG });\n  }\n};\n","'use strict';\nvar shared = require('../internals/shared');\nvar uid = require('../internals/uid');\n\nvar keys = shared('keys');\n\nmodule.exports = function (key) {\n  return keys[key] || (keys[key] = uid(key));\n};\n","'use strict';\nvar IS_PURE = require('../internals/is-pure');\nvar globalThis = require('../internals/global');\nvar defineGlobalProperty = require('../internals/define-global-property');\n\nvar SHARED = '__core-js_shared__';\nvar store = module.exports = globalThis[SHARED] || defineGlobalProperty(SHARED, {});\n\n(store.versions || (store.versions = [])).push({\n  version: '3.37.1',\n  mode: IS_PURE ? 'pure' : 'global',\n  copyright: '© 2014-2024 Denis Pushkarev (zloirock.ru)',\n  license: 'https://github.com/zloirock/core-js/blob/v3.37.1/LICENSE',\n  source: 'https://github.com/zloirock/core-js'\n});\n","'use strict';\nvar store = require('../internals/shared-store');\n\nmodule.exports = function (key, value) {\n  return store[key] || (store[key] = value || {});\n};\n","'use strict';\nvar anObject = require('../internals/an-object');\nvar aConstructor = require('../internals/a-constructor');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar SPECIES = wellKnownSymbol('species');\n\n// `SpeciesConstructor` abstract operation\n// https://tc39.es/ecma262/#sec-speciesconstructor\nmodule.exports = function (O, defaultConstructor) {\n  var C = anObject(O).constructor;\n  var S;\n  return C === undefined || isNullOrUndefined(S = anObject(C)[SPECIES]) ? defaultConstructor : aConstructor(S);\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar stringSlice = uncurryThis(''.slice);\n\nvar createMethod = function (CONVERT_TO_STRING) {\n  return function ($this, pos) {\n    var S = toString(requireObjectCoercible($this));\n    var position = toIntegerOrInfinity(pos);\n    var size = S.length;\n    var first, second;\n    if (position < 0 || position >= size) return CONVERT_TO_STRING ? '' : undefined;\n    first = charCodeAt(S, position);\n    return first < 0xD800 || first > 0xDBFF || position + 1 === size\n      || (second = charCodeAt(S, position + 1)) < 0xDC00 || second > 0xDFFF\n        ? CONVERT_TO_STRING\n          ? charAt(S, position)\n          : first\n        : CONVERT_TO_STRING\n          ? stringSlice(S, position, position + 2)\n          : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000;\n  };\n};\n\nmodule.exports = {\n  // `String.prototype.codePointAt` method\n  // https://tc39.es/ecma262/#sec-string.prototype.codepointat\n  codeAt: createMethod(false),\n  // `String.prototype.at` method\n  // https://github.com/mathiasbynens/String.prototype.at\n  charAt: createMethod(true)\n};\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar V8_VERSION = require('../internals/engine-v8-version');\nvar fails = require('../internals/fails');\nvar global = require('../internals/global');\n\nvar $String = global.String;\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nmodule.exports = !!Object.getOwnPropertySymbols && !fails(function () {\n  var symbol = Symbol('symbol detection');\n  // Chrome 38 Symbol has incorrect toString conversion\n  // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n  // nb: Do not call `String` directly to avoid this being optimized out to `symbol+''` which will,\n  // of course, fail.\n  return !$String(symbol) || !(Object(symbol) instanceof Symbol) ||\n    // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n    !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n","'use strict';\nvar global = require('../internals/global');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind-context');\nvar isCallable = require('../internals/is-callable');\nvar hasOwn = require('../internals/has-own-property');\nvar fails = require('../internals/fails');\nvar html = require('../internals/html');\nvar arraySlice = require('../internals/array-slice');\nvar createElement = require('../internals/document-create-element');\nvar validateArgumentsLength = require('../internals/validate-arguments-length');\nvar IS_IOS = require('../internals/engine-is-ios');\nvar IS_NODE = require('../internals/engine-is-node');\n\nvar set = global.setImmediate;\nvar clear = global.clearImmediate;\nvar process = global.process;\nvar Dispatch = global.Dispatch;\nvar Function = global.Function;\nvar MessageChannel = global.MessageChannel;\nvar String = global.String;\nvar counter = 0;\nvar queue = {};\nvar ONREADYSTATECHANGE = 'onreadystatechange';\nvar $location, defer, channel, port;\n\nfails(function () {\n  // Deno throws a ReferenceError on `location` access without `--location` flag\n  $location = global.location;\n});\n\nvar run = function (id) {\n  if (hasOwn(queue, id)) {\n    var fn = queue[id];\n    delete queue[id];\n    fn();\n  }\n};\n\nvar runner = function (id) {\n  return function () {\n    run(id);\n  };\n};\n\nvar eventListener = function (event) {\n  run(event.data);\n};\n\nvar globalPostMessageDefer = function (id) {\n  // old engines have not location.origin\n  global.postMessage(String(id), $location.protocol + '//' + $location.host);\n};\n\n// Node.js 0.9+ & IE10+ has setImmediate, otherwise:\nif (!set || !clear) {\n  set = function setImmediate(handler) {\n    validateArgumentsLength(arguments.length, 1);\n    var fn = isCallable(handler) ? handler : Function(handler);\n    var args = arraySlice(arguments, 1);\n    queue[++counter] = function () {\n      apply(fn, undefined, args);\n    };\n    defer(counter);\n    return counter;\n  };\n  clear = function clearImmediate(id) {\n    delete queue[id];\n  };\n  // Node.js 0.8-\n  if (IS_NODE) {\n    defer = function (id) {\n      process.nextTick(runner(id));\n    };\n  // Sphere (JS game engine) Dispatch API\n  } else if (Dispatch && Dispatch.now) {\n    defer = function (id) {\n      Dispatch.now(runner(id));\n    };\n  // Browsers with MessageChannel, includes WebWorkers\n  // except iOS - https://github.com/zloirock/core-js/issues/624\n  } else if (MessageChannel && !IS_IOS) {\n    channel = new MessageChannel();\n    port = channel.port2;\n    channel.port1.onmessage = eventListener;\n    defer = bind(port.postMessage, port);\n  // Browsers with postMessage, skip WebWorkers\n  // IE8 has postMessage, but it's sync & typeof its postMessage is 'object'\n  } else if (\n    global.addEventListener &&\n    isCallable(global.postMessage) &&\n    !global.importScripts &&\n    $location && $location.protocol !== 'file:' &&\n    !fails(globalPostMessageDefer)\n  ) {\n    defer = globalPostMessageDefer;\n    global.addEventListener('message', eventListener, false);\n  // IE8-\n  } else if (ONREADYSTATECHANGE in createElement('script')) {\n    defer = function (id) {\n      html.appendChild(createElement('script'))[ONREADYSTATECHANGE] = function () {\n        html.removeChild(this);\n        run(id);\n      };\n    };\n  // Rest old browsers\n  } else {\n    defer = function (id) {\n      setTimeout(runner(id), 0);\n    };\n  }\n}\n\nmodule.exports = {\n  set: set,\n  clear: clear\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar max = Math.max;\nvar min = Math.min;\n\n// Helper for a popular repeating case of the spec:\n// Let integer be ? ToInteger(index).\n// If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length).\nmodule.exports = function (index, length) {\n  var integer = toIntegerOrInfinity(index);\n  return integer < 0 ? max(integer + length, 0) : min(integer, length);\n};\n","'use strict';\n// toObject with fallback for non-array-like ES3 strings\nvar IndexedObject = require('../internals/indexed-object');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nmodule.exports = function (it) {\n  return IndexedObject(requireObjectCoercible(it));\n};\n","'use strict';\nvar trunc = require('../internals/math-trunc');\n\n// `ToIntegerOrInfinity` abstract operation\n// https://tc39.es/ecma262/#sec-tointegerorinfinity\nmodule.exports = function (argument) {\n  var number = +argument;\n  // eslint-disable-next-line no-self-compare -- NaN check\n  return number !== number || number === 0 ? 0 : trunc(number);\n};\n","'use strict';\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\n\nvar min = Math.min;\n\n// `ToLength` abstract operation\n// https://tc39.es/ecma262/#sec-tolength\nmodule.exports = function (argument) {\n  var len = toIntegerOrInfinity(argument);\n  return len > 0 ? min(len, 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991\n};\n","'use strict';\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar $Object = Object;\n\n// `ToObject` abstract operation\n// https://tc39.es/ecma262/#sec-toobject\nmodule.exports = function (argument) {\n  return $Object(requireObjectCoercible(argument));\n};\n","'use strict';\nvar call = require('../internals/function-call');\nvar isObject = require('../internals/is-object');\nvar isSymbol = require('../internals/is-symbol');\nvar getMethod = require('../internals/get-method');\nvar ordinaryToPrimitive = require('../internals/ordinary-to-primitive');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar $TypeError = TypeError;\nvar TO_PRIMITIVE = wellKnownSymbol('toPrimitive');\n\n// `ToPrimitive` abstract operation\n// https://tc39.es/ecma262/#sec-toprimitive\nmodule.exports = function (input, pref) {\n  if (!isObject(input) || isSymbol(input)) return input;\n  var exoticToPrim = getMethod(input, TO_PRIMITIVE);\n  var result;\n  if (exoticToPrim) {\n    if (pref === undefined) pref = 'default';\n    result = call(exoticToPrim, input, pref);\n    if (!isObject(result) || isSymbol(result)) return result;\n    throw new $TypeError(\"Can't convert object to primitive value\");\n  }\n  if (pref === undefined) pref = 'number';\n  return ordinaryToPrimitive(input, pref);\n};\n","'use strict';\nvar toPrimitive = require('../internals/to-primitive');\nvar isSymbol = require('../internals/is-symbol');\n\n// `ToPropertyKey` abstract operation\n// https://tc39.es/ecma262/#sec-topropertykey\nmodule.exports = function (argument) {\n  var key = toPrimitive(argument, 'string');\n  return isSymbol(key) ? key : key + '';\n};\n","'use strict';\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar TO_STRING_TAG = wellKnownSymbol('toStringTag');\nvar test = {};\n\ntest[TO_STRING_TAG] = 'z';\n\nmodule.exports = String(test) === '[object z]';\n","'use strict';\nvar classof = require('../internals/classof');\n\nvar $String = String;\n\nmodule.exports = function (argument) {\n  if (classof(argument) === 'Symbol') throw new TypeError('Cannot convert a Symbol value to a string');\n  return $String(argument);\n};\n","'use strict';\nvar $String = String;\n\nmodule.exports = function (argument) {\n  try {\n    return $String(argument);\n  } catch (error) {\n    return 'Object';\n  }\n};\n","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\n\nvar id = 0;\nvar postfix = Math.random();\nvar toString = uncurryThis(1.0.toString);\n\nmodule.exports = function (key) {\n  return 'Symbol(' + (key === undefined ? '' : key) + ')_' + toString(++id + postfix, 36);\n};\n","'use strict';\n/* eslint-disable es/no-symbol -- required for testing */\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nmodule.exports = NATIVE_SYMBOL\n  && !Symbol.sham\n  && typeof Symbol.iterator == 'symbol';\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar fails = require('../internals/fails');\n\n// V8 ~ Chrome 36-\n// https://bugs.chromium.org/p/v8/issues/detail?id=3334\nmodule.exports = DESCRIPTORS && fails(function () {\n  // eslint-disable-next-line es/no-object-defineproperty -- required for testing\n  return Object.defineProperty(function () { /* empty */ }, 'prototype', {\n    value: 42,\n    writable: false\n  }).prototype !== 42;\n});\n","'use strict';\nvar $TypeError = TypeError;\n\nmodule.exports = function (passed, required) {\n  if (passed < required) throw new $TypeError('Not enough arguments');\n  return passed;\n};\n","'use strict';\nvar global = require('../internals/global');\nvar isCallable = require('../internals/is-callable');\n\nvar WeakMap = global.WeakMap;\n\nmodule.exports = isCallable(WeakMap) && /native code/.test(String(WeakMap));\n","'use strict';\nvar global = require('../internals/global');\nvar shared = require('../internals/shared');\nvar hasOwn = require('../internals/has-own-property');\nvar uid = require('../internals/uid');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\nvar USE_SYMBOL_AS_UID = require('../internals/use-symbol-as-uid');\n\nvar Symbol = global.Symbol;\nvar WellKnownSymbolsStore = shared('wks');\nvar createWellKnownSymbol = USE_SYMBOL_AS_UID ? Symbol['for'] || Symbol : Symbol && Symbol.withoutSetter || uid;\n\nmodule.exports = function (name) {\n  if (!hasOwn(WellKnownSymbolsStore, name)) {\n    WellKnownSymbolsStore[name] = NATIVE_SYMBOL && hasOwn(Symbol, name)\n      ? Symbol[name]\n      : createWellKnownSymbol('Symbol.' + name);\n  } return WellKnownSymbolsStore[name];\n};\n","'use strict';\nvar $ = require('../internals/export');\nvar $includes = require('../internals/array-includes').includes;\nvar fails = require('../internals/fails');\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\n// FF99+ bug\nvar BROKEN_ON_SPARSE = fails(function () {\n  // eslint-disable-next-line es/no-array-prototype-includes -- detection\n  return !Array(1).includes();\n});\n\n// `Array.prototype.includes` method\n// https://tc39.es/ecma262/#sec-array.prototype.includes\n$({ target: 'Array', proto: true, forced: BROKEN_ON_SPARSE }, {\n  includes: function includes(el /* , fromIndex = 0 */) {\n    return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined);\n  }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables('includes');\n","'use strict';\nvar $ = require('../internals/export');\nvar $reduce = require('../internals/array-reduce').left;\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\nvar CHROME_VERSION = require('../internals/engine-v8-version');\nvar IS_NODE = require('../internals/engine-is-node');\n\n// Chrome 80-82 has a critical bug\n// https://bugs.chromium.org/p/chromium/issues/detail?id=1049982\nvar CHROME_BUG = !IS_NODE && CHROME_VERSION > 79 && CHROME_VERSION < 83;\nvar FORCED = CHROME_BUG || !arrayMethodIsStrict('reduce');\n\n// `Array.prototype.reduce` method\n// https://tc39.es/ecma262/#sec-array.prototype.reduce\n$({ target: 'Array', proto: true, forced: FORCED }, {\n  reduce: function reduce(callbackfn /* , initialValue */) {\n    var length = arguments.length;\n    return $reduce(this, callbackfn, length, length > 1 ? arguments[1] : undefined);\n  }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\nvar toObject = require('../internals/to-object');\nvar lengthOfArrayLike = require('../internals/length-of-array-like');\nvar deletePropertyOrThrow = require('../internals/delete-property-or-throw');\nvar toString = require('../internals/to-string');\nvar fails = require('../internals/fails');\nvar internalSort = require('../internals/array-sort');\nvar arrayMethodIsStrict = require('../internals/array-method-is-strict');\nvar FF = require('../internals/engine-ff-version');\nvar IE_OR_EDGE = require('../internals/engine-is-ie-or-edge');\nvar V8 = require('../internals/engine-v8-version');\nvar WEBKIT = require('../internals/engine-webkit-version');\n\nvar test = [];\nvar nativeSort = uncurryThis(test.sort);\nvar push = uncurryThis(test.push);\n\n// IE8-\nvar FAILS_ON_UNDEFINED = fails(function () {\n  test.sort(undefined);\n});\n// V8 bug\nvar FAILS_ON_NULL = fails(function () {\n  test.sort(null);\n});\n// Old WebKit\nvar STRICT_METHOD = arrayMethodIsStrict('sort');\n\nvar STABLE_SORT = !fails(function () {\n  // feature detection can be too slow, so check engines versions\n  if (V8) return V8 < 70;\n  if (FF && FF > 3) return;\n  if (IE_OR_EDGE) return true;\n  if (WEBKIT) return WEBKIT < 603;\n\n  var result = '';\n  var code, chr, value, index;\n\n  // generate an array with more 512 elements (Chakra and old V8 fails only in this case)\n  for (code = 65; code < 76; code++) {\n    chr = String.fromCharCode(code);\n\n    switch (code) {\n      case 66: case 69: case 70: case 72: value = 3; break;\n      case 68: case 71: value = 4; break;\n      default: value = 2;\n    }\n\n    for (index = 0; index < 47; index++) {\n      test.push({ k: chr + index, v: value });\n    }\n  }\n\n  test.sort(function (a, b) { return b.v - a.v; });\n\n  for (index = 0; index < test.length; index++) {\n    chr = test[index].k.charAt(0);\n    if (result.charAt(result.length - 1) !== chr) result += chr;\n  }\n\n  return result !== 'DGBEFHACIJK';\n});\n\nvar FORCED = FAILS_ON_UNDEFINED || !FAILS_ON_NULL || !STRICT_METHOD || !STABLE_SORT;\n\nvar getSortCompare = function (comparefn) {\n  return function (x, y) {\n    if (y === undefined) return -1;\n    if (x === undefined) return 1;\n    if (comparefn !== undefined) return +comparefn(x, y) || 0;\n    return toString(x) > toString(y) ? 1 : -1;\n  };\n};\n\n// `Array.prototype.sort` method\n// https://tc39.es/ecma262/#sec-array.prototype.sort\n$({ target: 'Array', proto: true, forced: FORCED }, {\n  sort: function sort(comparefn) {\n    if (comparefn !== undefined) aCallable(comparefn);\n\n    var array = toObject(this);\n\n    if (STABLE_SORT) return comparefn === undefined ? nativeSort(array) : nativeSort(array, comparefn);\n\n    var items = [];\n    var arrayLength = lengthOfArrayLike(array);\n    var itemsLength, index;\n\n    for (index = 0; index < arrayLength; index++) {\n      if (index in array) push(items, array[index]);\n    }\n\n    internalSort(items, getSortCompare(comparefn));\n\n    itemsLength = lengthOfArrayLike(items);\n    index = 0;\n\n    while (index < itemsLength) array[index] = items[index++];\n    while (index < arrayLength) deletePropertyOrThrow(array, index++);\n\n    return array;\n  }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fails = require('../internals/fails');\nvar isCallable = require('../internals/is-callable');\nvar isSymbol = require('../internals/is-symbol');\nvar arraySlice = require('../internals/array-slice');\nvar getReplacerFunction = require('../internals/get-json-replacer-function');\nvar NATIVE_SYMBOL = require('../internals/symbol-constructor-detection');\n\nvar $String = String;\nvar $stringify = getBuiltIn('JSON', 'stringify');\nvar exec = uncurryThis(/./.exec);\nvar charAt = uncurryThis(''.charAt);\nvar charCodeAt = uncurryThis(''.charCodeAt);\nvar replace = uncurryThis(''.replace);\nvar numberToString = uncurryThis(1.0.toString);\n\nvar tester = /[\\uD800-\\uDFFF]/g;\nvar low = /^[\\uD800-\\uDBFF]$/;\nvar hi = /^[\\uDC00-\\uDFFF]$/;\n\nvar WRONG_SYMBOLS_CONVERSION = !NATIVE_SYMBOL || fails(function () {\n  var symbol = getBuiltIn('Symbol')('stringify detection');\n  // MS Edge converts symbol values to JSON as {}\n  return $stringify([symbol]) !== '[null]'\n    // WebKit converts symbol values to JSON as null\n    || $stringify({ a: symbol }) !== '{}'\n    // V8 throws on boxed symbols\n    || $stringify(Object(symbol)) !== '{}';\n});\n\n// https://github.com/tc39/proposal-well-formed-stringify\nvar ILL_FORMED_UNICODE = fails(function () {\n  return $stringify('\\uDF06\\uD834') !== '\"\\\\udf06\\\\ud834\"'\n    || $stringify('\\uDEAD') !== '\"\\\\udead\"';\n});\n\nvar stringifyWithSymbolsFix = function (it, replacer) {\n  var args = arraySlice(arguments);\n  var $replacer = getReplacerFunction(replacer);\n  if (!isCallable($replacer) && (it === undefined || isSymbol(it))) return; // IE8 returns string on undefined\n  args[1] = function (key, value) {\n    // some old implementations (like WebKit) could pass numbers as keys\n    if (isCallable($replacer)) value = call($replacer, this, $String(key), value);\n    if (!isSymbol(value)) return value;\n  };\n  return apply($stringify, null, args);\n};\n\nvar fixIllFormed = function (match, offset, string) {\n  var prev = charAt(string, offset - 1);\n  var next = charAt(string, offset + 1);\n  if ((exec(low, match) && !exec(hi, next)) || (exec(hi, match) && !exec(low, prev))) {\n    return '\\\\u' + numberToString(charCodeAt(match, 0), 16);\n  } return match;\n};\n\nif ($stringify) {\n  // `JSON.stringify` method\n  // https://tc39.es/ecma262/#sec-json.stringify\n  $({ target: 'JSON', stat: true, arity: 3, forced: WRONG_SYMBOLS_CONVERSION || ILL_FORMED_UNICODE }, {\n    // eslint-disable-next-line no-unused-vars -- required for `.length`\n    stringify: function stringify(it, replacer, space) {\n      var args = arraySlice(arguments);\n      var result = apply(WRONG_SYMBOLS_CONVERSION ? stringifyWithSymbolsFix : $stringify, null, args);\n      return ILL_FORMED_UNICODE && typeof result == 'string' ? replace(result, tester, fixIllFormed) : result;\n    }\n  });\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.all` method\n// https://tc39.es/ecma262/#sec-promise.all\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n  all: function all(iterable) {\n    var C = this;\n    var capability = newPromiseCapabilityModule.f(C);\n    var resolve = capability.resolve;\n    var reject = capability.reject;\n    var result = perform(function () {\n      var $promiseResolve = aCallable(C.resolve);\n      var values = [];\n      var counter = 0;\n      var remaining = 1;\n      iterate(iterable, function (promise) {\n        var index = counter++;\n        var alreadyCalled = false;\n        remaining++;\n        call($promiseResolve, C, promise).then(function (value) {\n          if (alreadyCalled) return;\n          alreadyCalled = true;\n          values[index] = value;\n          --remaining || resolve(values);\n        }, reject);\n      });\n      --remaining || resolve(values);\n    });\n    if (result.error) reject(result.value);\n    return capability.promise;\n  }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar getBuiltIn = require('../internals/get-built-in');\nvar isCallable = require('../internals/is-callable');\nvar defineBuiltIn = require('../internals/define-built-in');\n\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\n\n// `Promise.prototype.catch` method\n// https://tc39.es/ecma262/#sec-promise.prototype.catch\n$({ target: 'Promise', proto: true, forced: FORCED_PROMISE_CONSTRUCTOR, real: true }, {\n  'catch': function (onRejected) {\n    return this.then(undefined, onRejected);\n  }\n});\n\n// makes sure that native promise-based APIs `Promise#catch` properly works with patched `Promise#then`\nif (!IS_PURE && isCallable(NativePromiseConstructor)) {\n  var method = getBuiltIn('Promise').prototype['catch'];\n  if (NativePromisePrototype['catch'] !== method) {\n    defineBuiltIn(NativePromisePrototype, 'catch', method, { unsafe: true });\n  }\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar IS_PURE = require('../internals/is-pure');\nvar IS_NODE = require('../internals/engine-is-node');\nvar global = require('../internals/global');\nvar call = require('../internals/function-call');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar setPrototypeOf = require('../internals/object-set-prototype-of');\nvar setToStringTag = require('../internals/set-to-string-tag');\nvar setSpecies = require('../internals/set-species');\nvar aCallable = require('../internals/a-callable');\nvar isCallable = require('../internals/is-callable');\nvar isObject = require('../internals/is-object');\nvar anInstance = require('../internals/an-instance');\nvar speciesConstructor = require('../internals/species-constructor');\nvar task = require('../internals/task').set;\nvar microtask = require('../internals/microtask');\nvar hostReportErrors = require('../internals/host-report-errors');\nvar perform = require('../internals/perform');\nvar Queue = require('../internals/queue');\nvar InternalStateModule = require('../internals/internal-state');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar PromiseConstructorDetection = require('../internals/promise-constructor-detection');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\n\nvar PROMISE = 'Promise';\nvar FORCED_PROMISE_CONSTRUCTOR = PromiseConstructorDetection.CONSTRUCTOR;\nvar NATIVE_PROMISE_REJECTION_EVENT = PromiseConstructorDetection.REJECTION_EVENT;\nvar NATIVE_PROMISE_SUBCLASSING = PromiseConstructorDetection.SUBCLASSING;\nvar getInternalPromiseState = InternalStateModule.getterFor(PROMISE);\nvar setInternalState = InternalStateModule.set;\nvar NativePromisePrototype = NativePromiseConstructor && NativePromiseConstructor.prototype;\nvar PromiseConstructor = NativePromiseConstructor;\nvar PromisePrototype = NativePromisePrototype;\nvar TypeError = global.TypeError;\nvar document = global.document;\nvar process = global.process;\nvar newPromiseCapability = newPromiseCapabilityModule.f;\nvar newGenericPromiseCapability = newPromiseCapability;\n\nvar DISPATCH_EVENT = !!(document && document.createEvent && global.dispatchEvent);\nvar UNHANDLED_REJECTION = 'unhandledrejection';\nvar REJECTION_HANDLED = 'rejectionhandled';\nvar PENDING = 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\nvar HANDLED = 1;\nvar UNHANDLED = 2;\n\nvar Internal, OwnPromiseCapability, PromiseWrapper, nativeThen;\n\n// helpers\nvar isThenable = function (it) {\n  var then;\n  return isObject(it) && isCallable(then = it.then) ? then : false;\n};\n\nvar callReaction = function (reaction, state) {\n  var value = state.value;\n  var ok = state.state === FULFILLED;\n  var handler = ok ? reaction.ok : reaction.fail;\n  var resolve = reaction.resolve;\n  var reject = reaction.reject;\n  var domain = reaction.domain;\n  var result, then, exited;\n  try {\n    if (handler) {\n      if (!ok) {\n        if (state.rejection === UNHANDLED) onHandleUnhandled(state);\n        state.rejection = HANDLED;\n      }\n      if (handler === true) result = value;\n      else {\n        if (domain) domain.enter();\n        result = handler(value); // can throw\n        if (domain) {\n          domain.exit();\n          exited = true;\n        }\n      }\n      if (result === reaction.promise) {\n        reject(new TypeError('Promise-chain cycle'));\n      } else if (then = isThenable(result)) {\n        call(then, result, resolve, reject);\n      } else resolve(result);\n    } else reject(value);\n  } catch (error) {\n    if (domain && !exited) domain.exit();\n    reject(error);\n  }\n};\n\nvar notify = function (state, isReject) {\n  if (state.notified) return;\n  state.notified = true;\n  microtask(function () {\n    var reactions = state.reactions;\n    var reaction;\n    while (reaction = reactions.get()) {\n      callReaction(reaction, state);\n    }\n    state.notified = false;\n    if (isReject && !state.rejection) onUnhandled(state);\n  });\n};\n\nvar dispatchEvent = function (name, promise, reason) {\n  var event, handler;\n  if (DISPATCH_EVENT) {\n    event = document.createEvent('Event');\n    event.promise = promise;\n    event.reason = reason;\n    event.initEvent(name, false, true);\n    global.dispatchEvent(event);\n  } else event = { promise: promise, reason: reason };\n  if (!NATIVE_PROMISE_REJECTION_EVENT && (handler = global['on' + name])) handler(event);\n  else if (name === UNHANDLED_REJECTION) hostReportErrors('Unhandled promise rejection', reason);\n};\n\nvar onUnhandled = function (state) {\n  call(task, global, function () {\n    var promise = state.facade;\n    var value = state.value;\n    var IS_UNHANDLED = isUnhandled(state);\n    var result;\n    if (IS_UNHANDLED) {\n      result = perform(function () {\n        if (IS_NODE) {\n          process.emit('unhandledRejection', value, promise);\n        } else dispatchEvent(UNHANDLED_REJECTION, promise, value);\n      });\n      // Browsers should not trigger `rejectionHandled` event if it was handled here, NodeJS - should\n      state.rejection = IS_NODE || isUnhandled(state) ? UNHANDLED : HANDLED;\n      if (result.error) throw result.value;\n    }\n  });\n};\n\nvar isUnhandled = function (state) {\n  return state.rejection !== HANDLED && !state.parent;\n};\n\nvar onHandleUnhandled = function (state) {\n  call(task, global, function () {\n    var promise = state.facade;\n    if (IS_NODE) {\n      process.emit('rejectionHandled', promise);\n    } else dispatchEvent(REJECTION_HANDLED, promise, state.value);\n  });\n};\n\nvar bind = function (fn, state, unwrap) {\n  return function (value) {\n    fn(state, value, unwrap);\n  };\n};\n\nvar internalReject = function (state, value, unwrap) {\n  if (state.done) return;\n  state.done = true;\n  if (unwrap) state = unwrap;\n  state.value = value;\n  state.state = REJECTED;\n  notify(state, true);\n};\n\nvar internalResolve = function (state, value, unwrap) {\n  if (state.done) return;\n  state.done = true;\n  if (unwrap) state = unwrap;\n  try {\n    if (state.facade === value) throw new TypeError(\"Promise can't be resolved itself\");\n    var then = isThenable(value);\n    if (then) {\n      microtask(function () {\n        var wrapper = { done: false };\n        try {\n          call(then, value,\n            bind(internalResolve, wrapper, state),\n            bind(internalReject, wrapper, state)\n          );\n        } catch (error) {\n          internalReject(wrapper, error, state);\n        }\n      });\n    } else {\n      state.value = value;\n      state.state = FULFILLED;\n      notify(state, false);\n    }\n  } catch (error) {\n    internalReject({ done: false }, error, state);\n  }\n};\n\n// constructor polyfill\nif (FORCED_PROMISE_CONSTRUCTOR) {\n  // 25.4.3.1 Promise(executor)\n  PromiseConstructor = function Promise(executor) {\n    anInstance(this, PromisePrototype);\n    aCallable(executor);\n    call(Internal, this);\n    var state = getInternalPromiseState(this);\n    try {\n      executor(bind(internalResolve, state), bind(internalReject, state));\n    } catch (error) {\n      internalReject(state, error);\n    }\n  };\n\n  PromisePrototype = PromiseConstructor.prototype;\n\n  // eslint-disable-next-line no-unused-vars -- required for `.length`\n  Internal = function Promise(executor) {\n    setInternalState(this, {\n      type: PROMISE,\n      done: false,\n      notified: false,\n      parent: false,\n      reactions: new Queue(),\n      rejection: false,\n      state: PENDING,\n      value: undefined\n    });\n  };\n\n  // `Promise.prototype.then` method\n  // https://tc39.es/ecma262/#sec-promise.prototype.then\n  Internal.prototype = defineBuiltIn(PromisePrototype, 'then', function then(onFulfilled, onRejected) {\n    var state = getInternalPromiseState(this);\n    var reaction = newPromiseCapability(speciesConstructor(this, PromiseConstructor));\n    state.parent = true;\n    reaction.ok = isCallable(onFulfilled) ? onFulfilled : true;\n    reaction.fail = isCallable(onRejected) && onRejected;\n    reaction.domain = IS_NODE ? process.domain : undefined;\n    if (state.state === PENDING) state.reactions.add(reaction);\n    else microtask(function () {\n      callReaction(reaction, state);\n    });\n    return reaction.promise;\n  });\n\n  OwnPromiseCapability = function () {\n    var promise = new Internal();\n    var state = getInternalPromiseState(promise);\n    this.promise = promise;\n    this.resolve = bind(internalResolve, state);\n    this.reject = bind(internalReject, state);\n  };\n\n  newPromiseCapabilityModule.f = newPromiseCapability = function (C) {\n    return C === PromiseConstructor || C === PromiseWrapper\n      ? new OwnPromiseCapability(C)\n      : newGenericPromiseCapability(C);\n  };\n\n  if (!IS_PURE && isCallable(NativePromiseConstructor) && NativePromisePrototype !== Object.prototype) {\n    nativeThen = NativePromisePrototype.then;\n\n    if (!NATIVE_PROMISE_SUBCLASSING) {\n      // make `Promise#then` return a polyfilled `Promise` for native promise-based APIs\n      defineBuiltIn(NativePromisePrototype, 'then', function then(onFulfilled, onRejected) {\n        var that = this;\n        return new PromiseConstructor(function (resolve, reject) {\n          call(nativeThen, that, resolve, reject);\n        }).then(onFulfilled, onRejected);\n      // https://github.com/zloirock/core-js/issues/640\n      }, { unsafe: true });\n    }\n\n    // make `.constructor === Promise` work for native promise-based APIs\n    try {\n      delete NativePromisePrototype.constructor;\n    } catch (error) { /* empty */ }\n\n    // make `instanceof Promise` work for native promise-based APIs\n    if (setPrototypeOf) {\n      setPrototypeOf(NativePromisePrototype, PromisePrototype);\n    }\n  }\n}\n\n$({ global: true, constructor: true, wrap: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n  Promise: PromiseConstructor\n});\n\nsetToStringTag(PromiseConstructor, PROMISE, false, true);\nsetSpecies(PROMISE);\n","'use strict';\n// TODO: Remove this module from `core-js@4` since it's split to modules listed below\nrequire('../modules/es.promise.constructor');\nrequire('../modules/es.promise.all');\nrequire('../modules/es.promise.catch');\nrequire('../modules/es.promise.race');\nrequire('../modules/es.promise.reject');\nrequire('../modules/es.promise.resolve');\n","'use strict';\nvar $ = require('../internals/export');\nvar call = require('../internals/function-call');\nvar aCallable = require('../internals/a-callable');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar perform = require('../internals/perform');\nvar iterate = require('../internals/iterate');\nvar PROMISE_STATICS_INCORRECT_ITERATION = require('../internals/promise-statics-incorrect-iteration');\n\n// `Promise.race` method\n// https://tc39.es/ecma262/#sec-promise.race\n$({ target: 'Promise', stat: true, forced: PROMISE_STATICS_INCORRECT_ITERATION }, {\n  race: function race(iterable) {\n    var C = this;\n    var capability = newPromiseCapabilityModule.f(C);\n    var reject = capability.reject;\n    var result = perform(function () {\n      var $promiseResolve = aCallable(C.resolve);\n      iterate(iterable, function (promise) {\n        call($promiseResolve, C, promise).then(capability.resolve, reject);\n      });\n    });\n    if (result.error) reject(result.value);\n    return capability.promise;\n  }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar newPromiseCapabilityModule = require('../internals/new-promise-capability');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\n\n// `Promise.reject` method\n// https://tc39.es/ecma262/#sec-promise.reject\n$({ target: 'Promise', stat: true, forced: FORCED_PROMISE_CONSTRUCTOR }, {\n  reject: function reject(r) {\n    var capability = newPromiseCapabilityModule.f(this);\n    var capabilityReject = capability.reject;\n    capabilityReject(r);\n    return capability.promise;\n  }\n});\n","'use strict';\nvar $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar IS_PURE = require('../internals/is-pure');\nvar NativePromiseConstructor = require('../internals/promise-native-constructor');\nvar FORCED_PROMISE_CONSTRUCTOR = require('../internals/promise-constructor-detection').CONSTRUCTOR;\nvar promiseResolve = require('../internals/promise-resolve');\n\nvar PromiseConstructorWrapper = getBuiltIn('Promise');\nvar CHECK_WRAPPER = IS_PURE && !FORCED_PROMISE_CONSTRUCTOR;\n\n// `Promise.resolve` method\n// https://tc39.es/ecma262/#sec-promise.resolve\n$({ target: 'Promise', stat: true, forced: IS_PURE || FORCED_PROMISE_CONSTRUCTOR }, {\n  resolve: function resolve(x) {\n    return promiseResolve(CHECK_WRAPPER && this === PromiseConstructorWrapper ? NativePromiseConstructor : this, x);\n  }\n});\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar global = require('../internals/global');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar isForced = require('../internals/is-forced');\nvar inheritIfRequired = require('../internals/inherit-if-required');\nvar createNonEnumerableProperty = require('../internals/create-non-enumerable-property');\nvar create = require('../internals/object-create');\nvar getOwnPropertyNames = require('../internals/object-get-own-property-names').f;\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar isRegExp = require('../internals/is-regexp');\nvar toString = require('../internals/to-string');\nvar getRegExpFlags = require('../internals/regexp-get-flags');\nvar stickyHelpers = require('../internals/regexp-sticky-helpers');\nvar proxyAccessor = require('../internals/proxy-accessor');\nvar defineBuiltIn = require('../internals/define-built-in');\nvar fails = require('../internals/fails');\nvar hasOwn = require('../internals/has-own-property');\nvar enforceInternalState = require('../internals/internal-state').enforce;\nvar setSpecies = require('../internals/set-species');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar UNSUPPORTED_NCG = require('../internals/regexp-unsupported-ncg');\n\nvar MATCH = wellKnownSymbol('match');\nvar NativeRegExp = global.RegExp;\nvar RegExpPrototype = NativeRegExp.prototype;\nvar SyntaxError = global.SyntaxError;\nvar exec = uncurryThis(RegExpPrototype.exec);\nvar charAt = uncurryThis(''.charAt);\nvar replace = uncurryThis(''.replace);\nvar stringIndexOf = uncurryThis(''.indexOf);\nvar stringSlice = uncurryThis(''.slice);\n// TODO: Use only proper RegExpIdentifierName\nvar IS_NCG = /^\\?<[^\\s\\d!#%&*+<=>@^][^\\s!#%&*+<=>@^]*>/;\nvar re1 = /a/g;\nvar re2 = /a/g;\n\n// \"new\" should create a new object, old webkit bug\nvar CORRECT_NEW = new NativeRegExp(re1) !== re1;\n\nvar MISSED_STICKY = stickyHelpers.MISSED_STICKY;\nvar UNSUPPORTED_Y = stickyHelpers.UNSUPPORTED_Y;\n\nvar BASE_FORCED = DESCRIPTORS &&\n  (!CORRECT_NEW || MISSED_STICKY || UNSUPPORTED_DOT_ALL || UNSUPPORTED_NCG || fails(function () {\n    re2[MATCH] = false;\n    // RegExp constructor can alter flags and IsRegExp works correct with @@match\n    return NativeRegExp(re1) !== re1 || NativeRegExp(re2) === re2 || String(NativeRegExp(re1, 'i')) !== '/a/i';\n  }));\n\nvar handleDotAll = function (string) {\n  var length = string.length;\n  var index = 0;\n  var result = '';\n  var brackets = false;\n  var chr;\n  for (; index <= length; index++) {\n    chr = charAt(string, index);\n    if (chr === '\\\\') {\n      result += chr + charAt(string, ++index);\n      continue;\n    }\n    if (!brackets && chr === '.') {\n      result += '[\\\\s\\\\S]';\n    } else {\n      if (chr === '[') {\n        brackets = true;\n      } else if (chr === ']') {\n        brackets = false;\n      } result += chr;\n    }\n  } return result;\n};\n\nvar handleNCG = function (string) {\n  var length = string.length;\n  var index = 0;\n  var result = '';\n  var named = [];\n  var names = create(null);\n  var brackets = false;\n  var ncg = false;\n  var groupid = 0;\n  var groupname = '';\n  var chr;\n  for (; index <= length; index++) {\n    chr = charAt(string, index);\n    if (chr === '\\\\') {\n      chr += charAt(string, ++index);\n    } else if (chr === ']') {\n      brackets = false;\n    } else if (!brackets) switch (true) {\n      case chr === '[':\n        brackets = true;\n        break;\n      case chr === '(':\n        if (exec(IS_NCG, stringSlice(string, index + 1))) {\n          index += 2;\n          ncg = true;\n        }\n        result += chr;\n        groupid++;\n        continue;\n      case chr === '>' && ncg:\n        if (groupname === '' || hasOwn(names, groupname)) {\n          throw new SyntaxError('Invalid capture group name');\n        }\n        names[groupname] = true;\n        named[named.length] = [groupname, groupid];\n        ncg = false;\n        groupname = '';\n        continue;\n    }\n    if (ncg) groupname += chr;\n    else result += chr;\n  } return [result, named];\n};\n\n// `RegExp` constructor\n// https://tc39.es/ecma262/#sec-regexp-constructor\nif (isForced('RegExp', BASE_FORCED)) {\n  var RegExpWrapper = function RegExp(pattern, flags) {\n    var thisIsRegExp = isPrototypeOf(RegExpPrototype, this);\n    var patternIsRegExp = isRegExp(pattern);\n    var flagsAreUndefined = flags === undefined;\n    var groups = [];\n    var rawPattern = pattern;\n    var rawFlags, dotAll, sticky, handled, result, state;\n\n    if (!thisIsRegExp && patternIsRegExp && flagsAreUndefined && pattern.constructor === RegExpWrapper) {\n      return pattern;\n    }\n\n    if (patternIsRegExp || isPrototypeOf(RegExpPrototype, pattern)) {\n      pattern = pattern.source;\n      if (flagsAreUndefined) flags = getRegExpFlags(rawPattern);\n    }\n\n    pattern = pattern === undefined ? '' : toString(pattern);\n    flags = flags === undefined ? '' : toString(flags);\n    rawPattern = pattern;\n\n    if (UNSUPPORTED_DOT_ALL && 'dotAll' in re1) {\n      dotAll = !!flags && stringIndexOf(flags, 's') > -1;\n      if (dotAll) flags = replace(flags, /s/g, '');\n    }\n\n    rawFlags = flags;\n\n    if (MISSED_STICKY && 'sticky' in re1) {\n      sticky = !!flags && stringIndexOf(flags, 'y') > -1;\n      if (sticky && UNSUPPORTED_Y) flags = replace(flags, /y/g, '');\n    }\n\n    if (UNSUPPORTED_NCG) {\n      handled = handleNCG(pattern);\n      pattern = handled[0];\n      groups = handled[1];\n    }\n\n    result = inheritIfRequired(NativeRegExp(pattern, flags), thisIsRegExp ? this : RegExpPrototype, RegExpWrapper);\n\n    if (dotAll || sticky || groups.length) {\n      state = enforceInternalState(result);\n      if (dotAll) {\n        state.dotAll = true;\n        state.raw = RegExpWrapper(handleDotAll(pattern), rawFlags);\n      }\n      if (sticky) state.sticky = true;\n      if (groups.length) state.groups = groups;\n    }\n\n    if (pattern !== rawPattern) try {\n      // fails in old engines, but we have no alternatives for unsupported regex syntax\n      createNonEnumerableProperty(result, 'source', rawPattern === '' ? '(?:)' : rawPattern);\n    } catch (error) { /* empty */ }\n\n    return result;\n  };\n\n  for (var keys = getOwnPropertyNames(NativeRegExp), index = 0; keys.length > index;) {\n    proxyAccessor(RegExpWrapper, NativeRegExp, keys[index++]);\n  }\n\n  RegExpPrototype.constructor = RegExpWrapper;\n  RegExpWrapper.prototype = RegExpPrototype;\n  defineBuiltIn(global, 'RegExp', RegExpWrapper, { constructor: true });\n}\n\n// https://tc39.es/ecma262/#sec-get-regexp-@@species\nsetSpecies('RegExp');\n","'use strict';\nvar DESCRIPTORS = require('../internals/descriptors');\nvar UNSUPPORTED_DOT_ALL = require('../internals/regexp-unsupported-dot-all');\nvar classof = require('../internals/classof-raw');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar getInternalState = require('../internals/internal-state').get;\n\nvar RegExpPrototype = RegExp.prototype;\nvar $TypeError = TypeError;\n\n// `RegExp.prototype.dotAll` getter\n// https://tc39.es/ecma262/#sec-get-regexp.prototype.dotall\nif (DESCRIPTORS && UNSUPPORTED_DOT_ALL) {\n  defineBuiltInAccessor(RegExpPrototype, 'dotAll', {\n    configurable: true,\n    get: function dotAll() {\n      if (this === RegExpPrototype) return;\n      // We can't use InternalStateModule.getterFor because\n      // we don't add metadata for regexps created by a literal.\n      if (classof(this) === 'RegExp') {\n        return !!getInternalState(this).dotAll;\n      }\n      throw new $TypeError('Incompatible receiver, RegExp required');\n    }\n  });\n}\n","'use strict';\nvar $ = require('../internals/export');\nvar exec = require('../internals/regexp-exec');\n\n// `RegExp.prototype.exec` method\n// https://tc39.es/ecma262/#sec-regexp.prototype.exec\n$({ target: 'RegExp', proto: true, forced: /./.exec !== exec }, {\n  exec: exec\n});\n","'use strict';\nvar apply = require('../internals/function-apply');\nvar call = require('../internals/function-call');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar fixRegExpWellKnownSymbolLogic = require('../internals/fix-regexp-well-known-symbol-logic');\nvar fails = require('../internals/fails');\nvar anObject = require('../internals/an-object');\nvar isCallable = require('../internals/is-callable');\nvar isNullOrUndefined = require('../internals/is-null-or-undefined');\nvar toIntegerOrInfinity = require('../internals/to-integer-or-infinity');\nvar toLength = require('../internals/to-length');\nvar toString = require('../internals/to-string');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\nvar advanceStringIndex = require('../internals/advance-string-index');\nvar getMethod = require('../internals/get-method');\nvar getSubstitution = require('../internals/get-substitution');\nvar regExpExec = require('../internals/regexp-exec-abstract');\nvar wellKnownSymbol = require('../internals/well-known-symbol');\n\nvar REPLACE = wellKnownSymbol('replace');\nvar max = Math.max;\nvar min = Math.min;\nvar concat = uncurryThis([].concat);\nvar push = uncurryThis([].push);\nvar stringIndexOf = uncurryThis(''.indexOf);\nvar stringSlice = uncurryThis(''.slice);\n\nvar maybeToString = function (it) {\n  return it === undefined ? it : String(it);\n};\n\n// IE <= 11 replaces $0 with the whole match, as if it was $&\n// https://stackoverflow.com/questions/6024666/getting-ie-to-replace-a-regex-with-the-literal-string-0\nvar REPLACE_KEEPS_$0 = (function () {\n  // eslint-disable-next-line regexp/prefer-escape-replacement-dollar-char -- required for testing\n  return 'a'.replace(/./, '$0') === '$0';\n})();\n\n// Safari <= 13.0.3(?) substitutes nth capture where n>m with an empty string\nvar REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE = (function () {\n  if (/./[REPLACE]) {\n    return /./[REPLACE]('a', '$0') === '';\n  }\n  return false;\n})();\n\nvar REPLACE_SUPPORTS_NAMED_GROUPS = !fails(function () {\n  var re = /./;\n  re.exec = function () {\n    var result = [];\n    result.groups = { a: '7' };\n    return result;\n  };\n  // eslint-disable-next-line regexp/no-useless-dollar-replacements -- false positive\n  return ''.replace(re, '$<a>') !== '7';\n});\n\n// @@replace logic\nfixRegExpWellKnownSymbolLogic('replace', function (_, nativeReplace, maybeCallNative) {\n  var UNSAFE_SUBSTITUTE = REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE ? '$' : '$0';\n\n  return [\n    // `String.prototype.replace` method\n    // https://tc39.es/ecma262/#sec-string.prototype.replace\n    function replace(searchValue, replaceValue) {\n      var O = requireObjectCoercible(this);\n      var replacer = isNullOrUndefined(searchValue) ? undefined : getMethod(searchValue, REPLACE);\n      return replacer\n        ? call(replacer, searchValue, O, replaceValue)\n        : call(nativeReplace, toString(O), searchValue, replaceValue);\n    },\n    // `RegExp.prototype[@@replace]` method\n    // https://tc39.es/ecma262/#sec-regexp.prototype-@@replace\n    function (string, replaceValue) {\n      var rx = anObject(this);\n      var S = toString(string);\n\n      if (\n        typeof replaceValue == 'string' &&\n        stringIndexOf(replaceValue, UNSAFE_SUBSTITUTE) === -1 &&\n        stringIndexOf(replaceValue, '$<') === -1\n      ) {\n        var res = maybeCallNative(nativeReplace, rx, S, replaceValue);\n        if (res.done) return res.value;\n      }\n\n      var functionalReplace = isCallable(replaceValue);\n      if (!functionalReplace) replaceValue = toString(replaceValue);\n\n      var global = rx.global;\n      var fullUnicode;\n      if (global) {\n        fullUnicode = rx.unicode;\n        rx.lastIndex = 0;\n      }\n\n      var results = [];\n      var result;\n      while (true) {\n        result = regExpExec(rx, S);\n        if (result === null) break;\n\n        push(results, result);\n        if (!global) break;\n\n        var matchStr = toString(result[0]);\n        if (matchStr === '') rx.lastIndex = advanceStringIndex(S, toLength(rx.lastIndex), fullUnicode);\n      }\n\n      var accumulatedResult = '';\n      var nextSourcePosition = 0;\n      for (var i = 0; i < results.length; i++) {\n        result = results[i];\n\n        var matched = toString(result[0]);\n        var position = max(min(toIntegerOrInfinity(result.index), S.length), 0);\n        var captures = [];\n        var replacement;\n        // NOTE: This is equivalent to\n        //   captures = result.slice(1).map(maybeToString)\n        // but for some reason `nativeSlice.call(result, 1, result.length)` (called in\n        // the slice polyfill when slicing native arrays) \"doesn't work\" in safari 9 and\n        // causes a crash (https://pastebin.com/N21QzeQA) when trying to debug it.\n        for (var j = 1; j < result.length; j++) push(captures, maybeToString(result[j]));\n        var namedCaptures = result.groups;\n        if (functionalReplace) {\n          var replacerArgs = concat([matched], captures, position, S);\n          if (namedCaptures !== undefined) push(replacerArgs, namedCaptures);\n          replacement = toString(apply(replaceValue, undefined, replacerArgs));\n        } else {\n          replacement = getSubstitution(matched, S, position, captures, namedCaptures, replaceValue);\n        }\n        if (position >= nextSourcePosition) {\n          accumulatedResult += stringSlice(S, nextSourcePosition, position) + replacement;\n          nextSourcePosition = position + matched.length;\n        }\n      }\n\n      return accumulatedResult + stringSlice(S, nextSourcePosition);\n    }\n  ];\n}, !REPLACE_SUPPORTS_NAMED_GROUPS || !REPLACE_KEEPS_$0 || REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE);\n","// `Symbol.prototype.description` getter\n// https://tc39.es/ecma262/#sec-symbol.prototype.description\n'use strict';\nvar $ = require('../internals/export');\nvar DESCRIPTORS = require('../internals/descriptors');\nvar global = require('../internals/global');\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar hasOwn = require('../internals/has-own-property');\nvar isCallable = require('../internals/is-callable');\nvar isPrototypeOf = require('../internals/object-is-prototype-of');\nvar toString = require('../internals/to-string');\nvar defineBuiltInAccessor = require('../internals/define-built-in-accessor');\nvar copyConstructorProperties = require('../internals/copy-constructor-properties');\n\nvar NativeSymbol = global.Symbol;\nvar SymbolPrototype = NativeSymbol && NativeSymbol.prototype;\n\nif (DESCRIPTORS && isCallable(NativeSymbol) && (!('description' in SymbolPrototype) ||\n  // Safari 12 bug\n  NativeSymbol().description !== undefined\n)) {\n  var EmptyStringDescriptionStore = {};\n  // wrap Symbol constructor for correct work with undefined description\n  var SymbolWrapper = function Symbol() {\n    var description = arguments.length < 1 || arguments[0] === undefined ? undefined : toString(arguments[0]);\n    var result = isPrototypeOf(SymbolPrototype, this)\n      ? new NativeSymbol(description)\n      // in Edge 13, String(Symbol(undefined)) === 'Symbol(undefined)'\n      : description === undefined ? NativeSymbol() : NativeSymbol(description);\n    if (description === '') EmptyStringDescriptionStore[result] = true;\n    return result;\n  };\n\n  copyConstructorProperties(SymbolWrapper, NativeSymbol);\n  SymbolWrapper.prototype = SymbolPrototype;\n  SymbolPrototype.constructor = SymbolWrapper;\n\n  var NATIVE_SYMBOL = String(NativeSymbol('description detection')) === 'Symbol(description detection)';\n  var thisSymbolValue = uncurryThis(SymbolPrototype.valueOf);\n  var symbolDescriptiveString = uncurryThis(SymbolPrototype.toString);\n  var regexp = /^Symbol\\((.*)\\)[^)]+$/;\n  var replace = uncurryThis(''.replace);\n  var stringSlice = uncurryThis(''.slice);\n\n  defineBuiltInAccessor(SymbolPrototype, 'description', {\n    configurable: true,\n    get: function description() {\n      var symbol = thisSymbolValue(this);\n      if (hasOwn(EmptyStringDescriptionStore, symbol)) return '';\n      var string = symbolDescriptiveString(symbol);\n      var desc = NATIVE_SYMBOL ? stringSlice(string, 7, -1) : replace(string, regexp, '$1');\n      return desc === '' ? undefined : desc;\n    }\n  });\n\n  $({ global: true, constructor: true, forced: true }, {\n    Symbol: SymbolWrapper\n  });\n}\n","(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global[\"'typed'\"] = factory());\n})(this, (function () { 'use strict';\n\n  function ok() {\n    return true;\n  }\n  function notOk() {\n    return false;\n  }\n  function undef() {\n    return undefined;\n  }\n  const NOT_TYPED_FUNCTION = 'Argument is not a typed-function.';\n\n  /**\n   * @typedef {{\n   *   params: Param[],\n   *   fn: function,\n   *   test: function,\n   *   implementation: function\n   * }} Signature\n   *\n   * @typedef {{\n   *   types: Type[],\n   *   hasAny: boolean,\n   *   hasConversion: boolean,\n   *   restParam: boolean\n   * }} Param\n   *\n   * @typedef {{\n   *   name: string,\n   *   typeIndex: number,\n   *   test: function,\n   *   isAny: boolean,\n   *   conversion?: ConversionDef,\n   *   conversionIndex: number,\n   * }} Type\n   *\n   * @typedef {{\n   *   from: string,\n   *   to: string,\n   *   convert: function (*) : *\n   * }} ConversionDef\n   *\n   * @typedef {{\n   *   name: string,\n   *   test: function(*) : boolean,\n   *   isAny?: boolean\n   * }} TypeDef\n   */\n\n  /**\n   * @returns {() => function}\n   */\n  function create() {\n    // data type tests\n\n    /**\n     * Returns true if the argument is a non-null \"plain\" object\n     */\n    function isPlainObject(x) {\n      return typeof x === 'object' && x !== null && x.constructor === Object;\n    }\n    const _types = [{\n      name: 'number',\n      test: function (x) {\n        return typeof x === 'number';\n      }\n    }, {\n      name: 'string',\n      test: function (x) {\n        return typeof x === 'string';\n      }\n    }, {\n      name: 'boolean',\n      test: function (x) {\n        return typeof x === 'boolean';\n      }\n    }, {\n      name: 'Function',\n      test: function (x) {\n        return typeof x === 'function';\n      }\n    }, {\n      name: 'Array',\n      test: Array.isArray\n    }, {\n      name: 'Date',\n      test: function (x) {\n        return x instanceof Date;\n      }\n    }, {\n      name: 'RegExp',\n      test: function (x) {\n        return x instanceof RegExp;\n      }\n    }, {\n      name: 'Object',\n      test: isPlainObject\n    }, {\n      name: 'null',\n      test: function (x) {\n        return x === null;\n      }\n    }, {\n      name: 'undefined',\n      test: function (x) {\n        return x === undefined;\n      }\n    }];\n    const anyType = {\n      name: 'any',\n      test: ok,\n      isAny: true\n    };\n\n    // Data structures to track the types. As these are local variables in\n    // create(), each typed universe will get its own copy, but the variables\n    // will only be accessible through the (closures of the) functions supplied\n    // as properties of the typed object, not directly.\n    // These will be initialized in clear() below\n    let typeMap; // primary store of all types\n    let typeList; // Array of just type names, for the sake of ordering\n\n    // And similar data structures for the type conversions:\n    let nConversions = 0;\n    // the actual conversions are stored on a property of the destination types\n\n    // This is a temporary object, will be replaced with a function at the end\n    let typed = {\n      createCount: 0\n    };\n\n    /**\n     * Takes a type name and returns the corresponding official type object\n     * for that type.\n     *\n     * @param {string} typeName\n     * @returns {TypeDef} type\n     */\n    function findType(typeName) {\n      const type = typeMap.get(typeName);\n      if (type) {\n        return type;\n      }\n      // Remainder is error handling\n      let message = 'Unknown type \"' + typeName + '\"';\n      const name = typeName.toLowerCase();\n      let otherName;\n      for (otherName of typeList) {\n        if (otherName.toLowerCase() === name) {\n          message += '. Did you mean \"' + otherName + '\" ?';\n          break;\n        }\n      }\n      throw new TypeError(message);\n    }\n\n    /**\n     * Adds an array `types` of type definitions to this typed instance.\n     * Each type definition should be an object with properties:\n     * 'name' - a string giving the name of the type; 'test' - function\n     * returning a boolean that tests membership in the type; and optionally\n     * 'isAny' - true only for the 'any' type.\n     *\n     * The second optional argument, `before`, gives the name of a type that\n     * these types should be added before. The new types are added in the\n     * order specified.\n     * @param {TypeDef[]} types\n     * @param {string | boolean} [beforeSpec='any'] before\n     */\n    function addTypes(types) {\n      let beforeSpec = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'any';\n      const beforeIndex = beforeSpec ? findType(beforeSpec).index : typeList.length;\n      const newTypes = [];\n      for (let i = 0; i < types.length; ++i) {\n        if (!types[i] || typeof types[i].name !== 'string' || typeof types[i].test !== 'function') {\n          throw new TypeError('Object with properties {name: string, test: function} expected');\n        }\n        const typeName = types[i].name;\n        if (typeMap.has(typeName)) {\n          throw new TypeError('Duplicate type name \"' + typeName + '\"');\n        }\n        newTypes.push(typeName);\n        typeMap.set(typeName, {\n          name: typeName,\n          test: types[i].test,\n          isAny: types[i].isAny,\n          index: beforeIndex + i,\n          conversionsTo: [] // Newly added type can't have any conversions to it\n        });\n      }\n      // update the typeList\n      const affectedTypes = typeList.slice(beforeIndex);\n      typeList = typeList.slice(0, beforeIndex).concat(newTypes).concat(affectedTypes);\n      // Fix the indices\n      for (let i = beforeIndex + newTypes.length; i < typeList.length; ++i) {\n        typeMap.get(typeList[i]).index = i;\n      }\n    }\n\n    /**\n     * Removes all types and conversions from this typed instance.\n     * May cause previously constructed typed-functions to throw\n     * strange errors when they are called with types that do not\n     * match any of their signatures.\n     */\n    function clear() {\n      typeMap = new Map();\n      typeList = [];\n      nConversions = 0;\n      addTypes([anyType], false);\n    }\n\n    // initialize the types to the default list\n    clear();\n    addTypes(_types);\n\n    /**\n     * Removes all conversions, leaving the types alone.\n     */\n    function clearConversions() {\n      let typeName;\n      for (typeName of typeList) {\n        typeMap.get(typeName).conversionsTo = [];\n      }\n      nConversions = 0;\n    }\n\n    /**\n     * Find the type names that match a value.\n     * @param {*} value\n     * @return {string[]} Array of names of types for which\n     *                  the type test matches the value.\n     */\n    function findTypeNames(value) {\n      const matches = typeList.filter(name => {\n        const type = typeMap.get(name);\n        return !type.isAny && type.test(value);\n      });\n      if (matches.length) {\n        return matches;\n      }\n      return ['any'];\n    }\n\n    /**\n     * Check if an entity is a typed function created by any instance\n     * @param {any} entity\n     * @returns {boolean}\n     */\n    function isTypedFunction(entity) {\n      return entity && typeof entity === 'function' && '_typedFunctionData' in entity;\n    }\n\n    /**\n     * Find a specific signature from a (composed) typed function, for example:\n     *\n     *   typed.findSignature(fn, ['number', 'string'])\n     *   typed.findSignature(fn, 'number, string')\n     *   typed.findSignature(fn, 'number,string', {exact: true})\n     *\n     * This function findSignature will by default return the best match to\n     * the given signature, possibly employing type conversions.\n     *\n     * The (optional) third argument is a plain object giving options\n     * controlling the signature search. Currently the only implemented\n     * option is `exact`: if specified as true (default is false), only\n     * exact matches will be returned (i.e. signatures for which `fn` was\n     * directly defined). Note that a (possibly different) type matching\n     * `any`, or one or more instances of TYPE matching `...TYPE` are\n     * considered exact matches in this regard, as no conversions are used.\n     *\n     * This function returns a \"signature\" object, as does `typed.resolve()`,\n     * which is a plain object with four keys: `params` (the array of parameters\n     * for this signature), `fn` (the originally supplied function for this\n     * signature), `test` (a generated function that determines if an argument\n     * list matches this signature, and `implementation` (the function to call\n     * on a matching argument list, that performs conversions if necessary and\n     * then calls the originally supplied function).\n     *\n     * @param {Function} fn                   A typed-function\n     * @param {string | string[]} signature\n     *     Signature to be found, can be an array or a comma separated string.\n     * @param {object} options  Controls the signature search as documented\n     * @return {{ params: Param[], fn: function, test: function, implementation: function }}\n     *     Returns the matching signature, or throws an error when no signature\n     *     is found.\n     */\n    function findSignature(fn, signature, options) {\n      if (!isTypedFunction(fn)) {\n        throw new TypeError(NOT_TYPED_FUNCTION);\n      }\n\n      // Canonicalize input\n      const exact = options && options.exact;\n      const stringSignature = Array.isArray(signature) ? signature.join(',') : signature;\n      const params = parseSignature(stringSignature);\n      const canonicalSignature = stringifyParams(params);\n\n      // First hope we get lucky and exactly match a signature\n      if (!exact || canonicalSignature in fn.signatures) {\n        // OK, we can check the internal signatures\n        const match = fn._typedFunctionData.signatureMap.get(canonicalSignature);\n        if (match) {\n          return match;\n        }\n      }\n\n      // Oh well, we did not; so we have to go back and check the parameters\n      // one by one, in order to catch things like `any` and rest params.\n      // Note here we can assume there is at least one parameter, because\n      // the empty signature would have matched successfully above.\n      const nParams = params.length;\n      let remainingSignatures;\n      if (exact) {\n        remainingSignatures = [];\n        let name;\n        for (name in fn.signatures) {\n          remainingSignatures.push(fn._typedFunctionData.signatureMap.get(name));\n        }\n      } else {\n        remainingSignatures = fn._typedFunctionData.signatures;\n      }\n      for (let i = 0; i < nParams; ++i) {\n        const want = params[i];\n        const filteredSignatures = [];\n        let possibility;\n        for (possibility of remainingSignatures) {\n          const have = getParamAtIndex(possibility.params, i);\n          if (!have || want.restParam && !have.restParam) {\n            continue;\n          }\n          if (!have.hasAny) {\n            // have to check all of the wanted types are available\n            const haveTypes = paramTypeSet(have);\n            if (want.types.some(wtype => !haveTypes.has(wtype.name))) {\n              continue;\n            }\n          }\n          // OK, this looks good\n          filteredSignatures.push(possibility);\n        }\n        remainingSignatures = filteredSignatures;\n        if (remainingSignatures.length === 0) break;\n      }\n      // Return the first remaining signature that was totally matched:\n      let candidate;\n      for (candidate of remainingSignatures) {\n        if (candidate.params.length <= nParams) {\n          return candidate;\n        }\n      }\n      throw new TypeError('Signature not found (signature: ' + (fn.name || 'unnamed') + '(' + stringifyParams(params, ', ') + '))');\n    }\n\n    /**\n     * Find the proper function to call for a specific signature from\n     * a (composed) typed function, for example:\n     *\n     *   typed.find(fn, ['number', 'string'])\n     *   typed.find(fn, 'number, string')\n     *   typed.find(fn, 'number,string', {exact: true})\n     *\n     * This function find will by default return the best match to\n     * the given signature, possibly employing type conversions (and returning\n     * a function that will perform those conversions as needed). The\n     * (optional) third argument is a plain object giving options contolling\n     * the signature search. Currently only the option `exact` is implemented,\n     * which defaults to \"false\". If `exact` is specified as true, then only\n     * exact matches will be returned (i.e. signatures for which `fn` was\n     * directly defined). Uses of `any` and `...TYPE` are considered exact if\n     * no conversions are necessary to apply the corresponding function.\n     *\n     * @param {Function} fn                   A typed-function\n     * @param {string | string[]} signature\n     *     Signature to be found, can be an array or a comma separated string.\n     * @param {object} options  Controls the signature match as documented\n     * @return {function}\n     *     Returns the function to call for the given signature, or throws an\n     *     error if no match is found.\n     */\n    function find(fn, signature, options) {\n      return findSignature(fn, signature, options).implementation;\n    }\n\n    /**\n     * Convert a given value to another data type, specified by type name.\n     *\n     * @param {*} value\n     * @param {string} typeName\n     */\n    function convert(value, typeName) {\n      // check conversion is needed\n      const type = findType(typeName);\n      if (type.test(value)) {\n        return value;\n      }\n      const conversions = type.conversionsTo;\n      if (conversions.length === 0) {\n        throw new Error('There are no conversions to ' + typeName + ' defined.');\n      }\n      for (let i = 0; i < conversions.length; i++) {\n        const fromType = findType(conversions[i].from);\n        if (fromType.test(value)) {\n          return conversions[i].convert(value);\n        }\n      }\n      throw new Error('Cannot convert ' + value + ' to ' + typeName);\n    }\n\n    /**\n     * Stringify parameters in a normalized way\n     * @param {Param[]} params\n     * @param {string} [','] separator\n     * @return {string}\n     */\n    function stringifyParams(params) {\n      let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ',';\n      return params.map(p => p.name).join(separator);\n    }\n\n    /**\n     * Parse a parameter, like \"...number | boolean\"\n     * @param {string} param\n     * @return {Param} param\n     */\n    function parseParam(param) {\n      const restParam = param.indexOf('...') === 0;\n      const types = !restParam ? param : param.length > 3 ? param.slice(3) : 'any';\n      const typeDefs = types.split('|').map(s => findType(s.trim()));\n      let hasAny = false;\n      let paramName = restParam ? '...' : '';\n      const exactTypes = typeDefs.map(function (type) {\n        hasAny = type.isAny || hasAny;\n        paramName += type.name + '|';\n        return {\n          name: type.name,\n          typeIndex: type.index,\n          test: type.test,\n          isAny: type.isAny,\n          conversion: null,\n          conversionIndex: -1\n        };\n      });\n      return {\n        types: exactTypes,\n        name: paramName.slice(0, -1),\n        // remove trailing '|' from above\n        hasAny,\n        hasConversion: false,\n        restParam\n      };\n    }\n\n    /**\n     * Expands a parsed parameter with the types available from currently\n     * defined conversions.\n     * @param {Param} param\n     * @return {Param} param\n     */\n    function expandParam(param) {\n      const typeNames = param.types.map(t => t.name);\n      const matchingConversions = availableConversions(typeNames);\n      let hasAny = param.hasAny;\n      let newName = param.name;\n      const convertibleTypes = matchingConversions.map(function (conversion) {\n        const type = findType(conversion.from);\n        hasAny = type.isAny || hasAny;\n        newName += '|' + conversion.from;\n        return {\n          name: conversion.from,\n          typeIndex: type.index,\n          test: type.test,\n          isAny: type.isAny,\n          conversion,\n          conversionIndex: conversion.index\n        };\n      });\n      return {\n        types: param.types.concat(convertibleTypes),\n        name: newName,\n        hasAny,\n        hasConversion: convertibleTypes.length > 0,\n        restParam: param.restParam\n      };\n    }\n\n    /**\n     * Return the set of type names in a parameter.\n     * Caches the result for efficiency\n     *\n     * @param {Param} param\n     * @return {Set<string>} typenames\n     */\n    function paramTypeSet(param) {\n      if (!param.typeSet) {\n        param.typeSet = new Set();\n        param.types.forEach(type => param.typeSet.add(type.name));\n      }\n      return param.typeSet;\n    }\n\n    /**\n     * Parse a signature with comma separated parameters,\n     * like \"number | boolean, ...string\"\n     *\n     * @param {string} signature\n     * @return {Param[]} params\n     */\n    function parseSignature(rawSignature) {\n      const params = [];\n      if (typeof rawSignature !== 'string') {\n        throw new TypeError('Signatures must be strings');\n      }\n      const signature = rawSignature.trim();\n      if (signature === '') {\n        return params;\n      }\n      const rawParams = signature.split(',');\n      for (let i = 0; i < rawParams.length; ++i) {\n        const parsedParam = parseParam(rawParams[i].trim());\n        if (parsedParam.restParam && i !== rawParams.length - 1) {\n          throw new SyntaxError('Unexpected rest parameter \"' + rawParams[i] + '\": ' + 'only allowed for the last parameter');\n        }\n        // if invalid, short-circuit (all the types may have been filtered)\n        if (parsedParam.types.length === 0) {\n          return null;\n        }\n        params.push(parsedParam);\n      }\n      return params;\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      const param = last(params);\n      return param ? param.restParam : false;\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      } else if (param.types.length === 1) {\n        return findType(param.types[0].name).test;\n      } else if (param.types.length === 2) {\n        const test0 = findType(param.types[0].name).test;\n        const test1 = findType(param.types[1].name).test;\n        return function or(x) {\n          return test0(x) || test1(x);\n        };\n      } else {\n        // param.types.length > 2\n        const tests = param.types.map(function (type) {\n          return findType(type.name).test;\n        });\n        return function or(x) {\n          for (let 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      let tests, test0, test1;\n      if (hasRestParam(params)) {\n        // variable arguments like '...number'\n        tests = initial(params).map(compileTest);\n        const varIndex = tests.length;\n        const lastTest = compileTest(last(params));\n        const testRestParam = function (args) {\n          for (let i = varIndex; i < args.length; i++) {\n            if (!lastTest(args[i])) {\n              return false;\n            }\n          }\n          return true;\n        };\n        return function testArgs(args) {\n          for (let 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      } else {\n        // no variable arguments\n        if (params.length === 0) {\n          return function testArgs(args) {\n            return args.length === 0;\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        } 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        } else {\n          // arguments.length > 2\n          tests = params.map(compileTest);\n          return function testArgs(args) {\n            for (let 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 Params list.\n     * Handles rest parameters.\n     * @param {Param[]} params\n     * @param {number} index\n     * @return {Param | null} Returns the matching parameter when found,\n     *                        null otherwise.\n     */\n    function getParamAtIndex(params, index) {\n      return index < params.length ? params[index] : hasRestParam(params) ? last(params) : null;\n    }\n\n    /**\n     * Get all type names of a parameter\n     * @param {Params[]} params\n     * @param {number} index\n     * @return {string[]} Returns an array with type names\n     */\n    function getTypeSetAtIndex(params, index) {\n      const param = getParamAtIndex(params, index);\n      if (!param) {\n        return new Set();\n      }\n      return paramTypeSet(param);\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      const typeSet = new Set();\n      signatures.forEach(signature => {\n        const paramSet = getTypeSetAtIndex(signature.params, index);\n        let name;\n        for (name of paramSet) {\n          typeSet.add(name);\n        }\n      });\n      return typeSet.has('any') ? ['any'] : Array.from(typeSet);\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      let err, expected;\n      const _name = name || 'unnamed';\n\n      // test for wrong type at some index\n      let matchingSignatures = signatures;\n      let index;\n      for (index = 0; index < args.length; index++) {\n        const nextMatchingDefs = [];\n        matchingSignatures.forEach(signature => {\n          const param = getParamAtIndex(signature.params, index);\n          const test = compileTest(param);\n          if ((index < signature.params.length || hasRestParam(signature.params)) && test(args[index])) {\n            nextMatchingDefs.push(signature);\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            const actualTypes = findTypeNames(args[index]);\n            err = new TypeError('Unexpected type of argument in function ' + _name + ' (expected: ' + expected.join(' or ') + ', actual: ' + actualTypes.join(' | ') + ', index: ' + index + ')');\n            err.data = {\n              category: 'wrongType',\n              fn: _name,\n              index,\n              actual: actualTypes,\n              expected\n            };\n            return err;\n          }\n        } else {\n          matchingSignatures = nextMatchingDefs;\n        }\n      }\n\n      // test for too few arguments\n      const 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 + ' (expected: ' + expected.join(' or ') + ', index: ' + args.length + ')');\n        err.data = {\n          category: 'tooFewArgs',\n          fn: _name,\n          index: args.length,\n          expected\n        };\n        return err;\n      }\n\n      // test for too many arguments\n      const maxLength = Math.max.apply(null, lengths);\n      if (args.length > maxLength) {\n        err = new TypeError('Too many arguments in function ' + _name + ' (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      // Generic error\n      const argTypes = [];\n      for (let i = 0; i < args.length; ++i) {\n        argTypes.push(findTypeNames(args[i]).join('|'));\n      }\n      err = new TypeError('Arguments of type \"' + argTypes.join(', ') + '\" do not match any of the defined signatures of function ' + _name + '.');\n      err.data = {\n        category: 'mismatch',\n        actual: argTypes\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      let min = typeList.length + 1;\n      for (let 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      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      let min = nConversions + 1;\n      for (let 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      return min;\n    }\n\n    /**\n     * Compare two params\n     * @param {Param} param1\n     * @param {Param} param2\n     * @return {number} returns -1 when param1 must get a lower\n     *                  index than param2, 1 when the opposite,\n     *                  or zero when both are equal\n     */\n    function compareParams(param1, param2) {\n      // We compare a number of metrics on a param in turn:\n      // 1) 'any' parameters are the least preferred\n      if (param1.hasAny) {\n        if (!param2.hasAny) {\n          return 1;\n        }\n      } else if (param2.hasAny) {\n        return -1;\n      }\n\n      // 2) Prefer non-rest to rest parameters\n      if (param1.restParam) {\n        if (!param2.restParam) {\n          return 1;\n        }\n      } else if (param2.restParam) {\n        return -1;\n      }\n\n      // 3) Prefer exact type match to conversions\n      if (param1.hasConversion) {\n        if (!param2.hasConversion) {\n          return 1;\n        }\n      } else if (param2.hasConversion) {\n        return -1;\n      }\n\n      // 4) Prefer lower type index:\n      const typeDiff = getLowestTypeIndex(param1) - getLowestTypeIndex(param2);\n      if (typeDiff < 0) {\n        return -1;\n      }\n      if (typeDiff > 0) {\n        return 1;\n      }\n\n      // 5) Prefer lower conversion index\n      const convDiff = getLowestConversionIndex(param1) - getLowestConversionIndex(param2);\n      if (convDiff < 0) {\n        return -1;\n      }\n      if (convDiff > 0) {\n        return 1;\n      }\n\n      // Don't have a basis for preference\n      return 0;\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      const pars1 = signature1.params;\n      const pars2 = signature2.params;\n      const last1 = last(pars1);\n      const last2 = last(pars2);\n      const hasRest1 = hasRestParam(pars1);\n      const hasRest2 = hasRestParam(pars2);\n      // We compare a number of metrics on signatures in turn:\n      // 1) An \"any rest param\" is least preferred\n      if (hasRest1 && last1.hasAny) {\n        if (!hasRest2 || !last2.hasAny) {\n          return 1;\n        }\n      } else if (hasRest2 && last2.hasAny) {\n        return -1;\n      }\n\n      // 2) Minimize the number of 'any' parameters\n      let any1 = 0;\n      let conv1 = 0;\n      let par;\n      for (par of pars1) {\n        if (par.hasAny) ++any1;\n        if (par.hasConversion) ++conv1;\n      }\n      let any2 = 0;\n      let conv2 = 0;\n      for (par of pars2) {\n        if (par.hasAny) ++any2;\n        if (par.hasConversion) ++conv2;\n      }\n      if (any1 !== any2) {\n        return any1 - any2;\n      }\n\n      // 3) A conversion rest param is less preferred\n      if (hasRest1 && last1.hasConversion) {\n        if (!hasRest2 || !last2.hasConversion) {\n          return 1;\n        }\n      } else if (hasRest2 && last2.hasConversion) {\n        return -1;\n      }\n\n      // 4) Minimize the number of conversions\n      if (conv1 !== conv2) {\n        return conv1 - conv2;\n      }\n\n      // 5) Prefer no rest param\n      if (hasRest1) {\n        if (!hasRest2) {\n          return 1;\n        }\n      } else if (hasRest2) {\n        return -1;\n      }\n\n      // 6) Prefer shorter with rest param, longer without\n      const lengthCriterion = (pars1.length - pars2.length) * (hasRest1 ? -1 : 1);\n      if (lengthCriterion !== 0) {\n        return lengthCriterion;\n      }\n\n      // Signatures are identical in each of the above metrics.\n      // In particular, they are the same length.\n      // We can therefore compare the parameters one by one.\n      // First we count which signature has more preferred parameters.\n      const comparisons = [];\n      let tc = 0;\n      for (let i = 0; i < pars1.length; ++i) {\n        const thisComparison = compareParams(pars1[i], pars2[i]);\n        comparisons.push(thisComparison);\n        tc += thisComparison;\n      }\n      if (tc !== 0) {\n        return tc;\n      }\n\n      // They have the same number of preferred parameters, so go by the\n      // earliest parameter in which we have a preference.\n      // In other words, dispatch is driven somewhat more by earlier\n      // parameters than later ones.\n      let c;\n      for (c of comparisons) {\n        if (c !== 0) {\n          return c;\n        }\n      }\n\n      // It's a tossup:\n      return 0;\n    }\n\n    /**\n     * Produce a list of all conversions from distinct types to one of\n     * the given types.\n     *\n     * @param {string[]} typeNames\n     * @return {ConversionDef[]} Returns the conversions that are available\n     *                        resulting in any given type (if any)\n     */\n    function availableConversions(typeNames) {\n      if (typeNames.length === 0) {\n        return [];\n      }\n      const types = typeNames.map(findType);\n      if (typeNames.length > 1) {\n        types.sort((t1, t2) => t1.index - t2.index);\n      }\n      let matches = types[0].conversionsTo;\n      if (typeNames.length === 1) {\n        return matches;\n      }\n      matches = matches.concat([]); // shallow copy the matches\n      // Since the types are now in index order, we just want the first\n      // occurrence of any from type:\n      const knownTypes = new Set(typeNames);\n      for (let i = 1; i < types.length; ++i) {\n        let newMatch;\n        for (newMatch of types[i].conversionsTo) {\n          if (!knownTypes.has(newMatch.from)) {\n            matches.push(newMatch);\n            knownTypes.add(newMatch.from);\n          }\n        }\n      }\n      return matches;\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      let fnConvert = fn;\n\n      // TODO: can we make this wrapper function smarter/simpler?\n\n      if (params.some(p => p.hasConversion)) {\n        const restParam = hasRestParam(params);\n        const compiledConversions = params.map(compileArgConversion);\n        fnConvert = function convertArgs() {\n          const args = [];\n          const last = restParam ? arguments.length - 1 : arguments.length;\n          for (let 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          return fn.apply(this, args);\n        };\n      }\n      let fnPreprocess = fnConvert;\n      if (hasRestParam(params)) {\n        const offset = params.length - 1;\n        fnPreprocess = function preprocessRestParams() {\n          return fnConvert.apply(this, slice(arguments, 0, offset).concat([slice(arguments, offset)]));\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      let test0, test1, conversion0, conversion1;\n      const tests = [];\n      const conversions = [];\n      param.types.forEach(function (type) {\n        if (type.conversion) {\n          tests.push(findType(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        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        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        default:\n          return function convertArg(arg) {\n            for (let 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     * 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     * @return {Param[]}\n     */\n    function splitParams(params) {\n      function _splitParams(params, index, paramsSoFar) {\n        if (index < params.length) {\n          const param = params[index];\n          let resultingParams = [];\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            const exactTypes = param.types.filter(isExactType);\n            if (exactTypes.length < param.types.length) {\n              resultingParams.push({\n                types: exactTypes,\n                name: '...' + exactTypes.map(t => t.name).join('|'),\n                hasAny: exactTypes.some(t => t.isAny),\n                hasConversion: false,\n                restParam: true\n              });\n            }\n            resultingParams.push(param);\n          } else {\n            // split all the types of a regular parameter into one type per param\n            resultingParams = param.types.map(function (type) {\n              return {\n                types: [type],\n                name: type.name,\n                hasAny: type.isAny,\n                hasConversion: type.conversion,\n                restParam: false\n              };\n            });\n          }\n\n          // recurse over the groups with types\n          return flatMap(resultingParams, function (nextParam) {\n            return _splitParams(params, index + 1, paramsSoFar.concat([nextParam]));\n          });\n        } else {\n          // we've reached the end of the parameters.\n          return [paramsSoFar];\n        }\n      }\n      return _splitParams(params, 0, []);\n    }\n\n    /**\n     * Test whether two param lists represent conflicting signatures\n     * @param {Param[]} params1\n     * @param {Param[]} params2\n     * @return {boolean} Returns true when the signatures conflict, false otherwise.\n     */\n    function conflicting(params1, params2) {\n      const ii = Math.max(params1.length, params2.length);\n      for (let i = 0; i < ii; i++) {\n        const typeSet1 = getTypeSetAtIndex(params1, i);\n        const typeSet2 = getTypeSetAtIndex(params2, i);\n        let overlap = false;\n        let name;\n        for (name of typeSet2) {\n          if (typeSet1.has(name)) {\n            overlap = true;\n            break;\n          }\n        }\n        if (!overlap) {\n          return false;\n        }\n      }\n      const len1 = params1.length;\n      const len2 = params2.length;\n      const restParam1 = hasRestParam(params1);\n      const restParam2 = hasRestParam(params2);\n      return restParam1 ? restParam2 ? len1 === len2 : len2 >= len1 : restParam2 ? len1 >= len2 : len1 === len2;\n    }\n\n    /**\n     * Helper function for `resolveReferences` that returns a copy of\n     * functionList wihe any prior resolutions cleared out, in case we are\n     * recycling signatures from a prior typed function construction.\n     *\n     * @param {Array.<function|typed-reference>} functionList\n     * @return {Array.<function|typed-reference>}\n     */\n    function clearResolutions(functionList) {\n      return functionList.map(fn => {\n        if (isReferToSelf(fn)) {\n          return referToSelf(fn.referToSelf.callback);\n        }\n        if (isReferTo(fn)) {\n          return makeReferTo(fn.referTo.references, fn.referTo.callback);\n        }\n        return fn;\n      });\n    }\n\n    /**\n     * Take a list of references, a list of functions functionList, and a\n     * signatureMap indexing signatures into functionList, and return\n     * the list of resolutions, or a false-y value if they don't all\n     * resolve in a valid way (yet).\n     *\n     * @param {string[]} references\n     * @param {Array<function|typed-reference} functionList\n     * @param {Object.<string, integer>} signatureMap\n     * @return {function[] | false} resolutions\n     */\n    function collectResolutions(references, functionList, signatureMap) {\n      const resolvedReferences = [];\n      let reference;\n      for (reference of references) {\n        let resolution = signatureMap[reference];\n        if (typeof resolution !== 'number') {\n          throw new TypeError('No definition for referenced signature \"' + reference + '\"');\n        }\n        resolution = functionList[resolution];\n        if (typeof resolution !== 'function') {\n          return false;\n        }\n        resolvedReferences.push(resolution);\n      }\n      return resolvedReferences;\n    }\n\n    /**\n     * Resolve any references in the functionList for the typed function\n     * itself. The signatureMap tells which index in the functionList a\n     * given signature should be mapped to (for use in resolving typed.referTo)\n     * and self provides the destions of a typed.referToSelf.\n     *\n     * @param {Array<function | typed-reference-object>} functionList\n     * @param {Object.<string, function>} signatureMap\n     * @param {function} self  The typed-function itself\n     * @return {Array<function>} The list of resolved functions\n     */\n    function resolveReferences(functionList, signatureMap, self) {\n      const resolvedFunctions = clearResolutions(functionList);\n      const isResolved = new Array(resolvedFunctions.length).fill(false);\n      let leftUnresolved = true;\n      while (leftUnresolved) {\n        leftUnresolved = false;\n        let nothingResolved = true;\n        for (let i = 0; i < resolvedFunctions.length; ++i) {\n          if (isResolved[i]) continue;\n          const fn = resolvedFunctions[i];\n          if (isReferToSelf(fn)) {\n            resolvedFunctions[i] = fn.referToSelf.callback(self);\n            // Preserve reference in case signature is reused someday:\n            resolvedFunctions[i].referToSelf = fn.referToSelf;\n            isResolved[i] = true;\n            nothingResolved = false;\n          } else if (isReferTo(fn)) {\n            const resolvedReferences = collectResolutions(fn.referTo.references, resolvedFunctions, signatureMap);\n            if (resolvedReferences) {\n              resolvedFunctions[i] = fn.referTo.callback.apply(this, resolvedReferences);\n              // Preserve reference in case signature is reused someday:\n              resolvedFunctions[i].referTo = fn.referTo;\n              isResolved[i] = true;\n              nothingResolved = false;\n            } else {\n              leftUnresolved = true;\n            }\n          }\n        }\n        if (nothingResolved && leftUnresolved) {\n          throw new SyntaxError('Circular reference detected in resolving typed.referTo');\n        }\n      }\n      return resolvedFunctions;\n    }\n\n    /**\n     * Validate whether any of the function bodies contains a self-reference\n     * usage like `this(...)` or `this.signatures`. This self-referencing is\n     * deprecated since typed-function v3. It has been replaced with\n     * the functions typed.referTo and typed.referToSelf.\n     * @param {Object.<string, function>} signaturesMap\n     */\n    function validateDeprecatedThis(signaturesMap) {\n      // TODO: remove this deprecation warning logic some day (it's introduced in v3)\n\n      // match occurrences like 'this(' and 'this.signatures'\n      const deprecatedThisRegex = /\\bthis(\\(|\\.signatures\\b)/;\n      Object.keys(signaturesMap).forEach(signature => {\n        const fn = signaturesMap[signature];\n        if (deprecatedThisRegex.test(fn.toString())) {\n          throw new SyntaxError('Using `this` to self-reference a function ' + 'is deprecated since typed-function@3. ' + 'Use typed.referTo and typed.referToSelf instead.');\n        }\n      });\n    }\n\n    /**\n     * Create a typed function\n     * @param {String} name               The name for the typed function\n     * @param {Object.<string, function>} rawSignaturesMap\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, rawSignaturesMap) {\n      typed.createCount++;\n      if (Object.keys(rawSignaturesMap).length === 0) {\n        throw new SyntaxError('No signatures provided');\n      }\n      if (typed.warnAgainstDeprecatedThis) {\n        validateDeprecatedThis(rawSignaturesMap);\n      }\n\n      // Main processing loop for signatures\n      const parsedParams = [];\n      const originalFunctions = [];\n      const signaturesMap = {};\n      const preliminarySignatures = []; // may have duplicates from conversions\n      let signature;\n      for (signature in rawSignaturesMap) {\n        // A) Protect against polluted Object prototype:\n        if (!Object.prototype.hasOwnProperty.call(rawSignaturesMap, signature)) {\n          continue;\n        }\n        // B) Parse the signature\n        const params = parseSignature(signature);\n        if (!params) continue;\n        // C) Check for conflicts\n        parsedParams.forEach(function (pp) {\n          if (conflicting(pp, params)) {\n            throw new TypeError('Conflicting signatures \"' + stringifyParams(pp) + '\" and \"' + stringifyParams(params) + '\".');\n          }\n        });\n        parsedParams.push(params);\n        // D) Store the provided function and add conversions\n        const functionIndex = originalFunctions.length;\n        originalFunctions.push(rawSignaturesMap[signature]);\n        const conversionParams = params.map(expandParam);\n        // E) Split the signatures and collect them up\n        let sp;\n        for (sp of splitParams(conversionParams)) {\n          const spName = stringifyParams(sp);\n          preliminarySignatures.push({\n            params: sp,\n            name: spName,\n            fn: functionIndex\n          });\n          if (sp.every(p => !p.hasConversion)) {\n            signaturesMap[spName] = functionIndex;\n          }\n        }\n      }\n      preliminarySignatures.sort(compareSignatures);\n\n      // Note the forward reference to theTypedFn\n      const resolvedFunctions = resolveReferences(originalFunctions, signaturesMap, theTypedFn);\n\n      // Fill in the proper function for each signature\n      let s;\n      for (s in signaturesMap) {\n        if (Object.prototype.hasOwnProperty.call(signaturesMap, s)) {\n          signaturesMap[s] = resolvedFunctions[signaturesMap[s]];\n        }\n      }\n      const signatures = [];\n      const internalSignatureMap = new Map(); // benchmarks faster than object\n      for (s of preliminarySignatures) {\n        // Note it's only safe to eliminate duplicates like this\n        // _after_ the signature sorting step above; otherwise we might\n        // remove the wrong one.\n        if (!internalSignatureMap.has(s.name)) {\n          s.fn = resolvedFunctions[s.fn];\n          signatures.push(s);\n          internalSignatureMap.set(s.name, s);\n        }\n      }\n\n      // we create a highly optimized checks for the first couple of signatures with max 2 arguments\n      const ok0 = signatures[0] && signatures[0].params.length <= 2 && !hasRestParam(signatures[0].params);\n      const ok1 = signatures[1] && signatures[1].params.length <= 2 && !hasRestParam(signatures[1].params);\n      const ok2 = signatures[2] && signatures[2].params.length <= 2 && !hasRestParam(signatures[2].params);\n      const ok3 = signatures[3] && signatures[3].params.length <= 2 && !hasRestParam(signatures[3].params);\n      const ok4 = signatures[4] && signatures[4].params.length <= 2 && !hasRestParam(signatures[4].params);\n      const ok5 = signatures[5] && signatures[5].params.length <= 2 && !hasRestParam(signatures[5].params);\n      const allOk = ok0 && ok1 && ok2 && ok3 && ok4 && ok5;\n\n      // compile the tests\n      for (let i = 0; i < signatures.length; ++i) {\n        signatures[i].test = compileTests(signatures[i].params);\n      }\n      const test00 = ok0 ? compileTest(signatures[0].params[0]) : notOk;\n      const test10 = ok1 ? compileTest(signatures[1].params[0]) : notOk;\n      const test20 = ok2 ? compileTest(signatures[2].params[0]) : notOk;\n      const test30 = ok3 ? compileTest(signatures[3].params[0]) : notOk;\n      const test40 = ok4 ? compileTest(signatures[4].params[0]) : notOk;\n      const test50 = ok5 ? compileTest(signatures[5].params[0]) : notOk;\n      const test01 = ok0 ? compileTest(signatures[0].params[1]) : notOk;\n      const test11 = ok1 ? compileTest(signatures[1].params[1]) : notOk;\n      const test21 = ok2 ? compileTest(signatures[2].params[1]) : notOk;\n      const test31 = ok3 ? compileTest(signatures[3].params[1]) : notOk;\n      const test41 = ok4 ? compileTest(signatures[4].params[1]) : notOk;\n      const test51 = ok5 ? compileTest(signatures[5].params[1]) : notOk;\n\n      // compile the functions\n      for (let i = 0; i < signatures.length; ++i) {\n        signatures[i].implementation = compileArgsPreprocessing(signatures[i].params, signatures[i].fn);\n      }\n      const fn0 = ok0 ? signatures[0].implementation : undef;\n      const fn1 = ok1 ? signatures[1].implementation : undef;\n      const fn2 = ok2 ? signatures[2].implementation : undef;\n      const fn3 = ok3 ? signatures[3].implementation : undef;\n      const fn4 = ok4 ? signatures[4].implementation : undef;\n      const fn5 = ok5 ? signatures[5].implementation : undef;\n      const len0 = ok0 ? signatures[0].params.length : -1;\n      const len1 = ok1 ? signatures[1].params.length : -1;\n      const len2 = ok2 ? signatures[2].params.length : -1;\n      const len3 = ok3 ? signatures[3].params.length : -1;\n      const len4 = ok4 ? signatures[4].params.length : -1;\n      const len5 = ok5 ? signatures[5].params.length : -1;\n\n      // simple and generic, but also slow\n      const iStart = allOk ? 6 : 0;\n      const iEnd = signatures.length;\n      // de-reference ahead for execution speed:\n      const tests = signatures.map(s => s.test);\n      const fns = signatures.map(s => s.implementation);\n      const generic = function generic() {\n\n        for (let i = iStart; i < iEnd; i++) {\n          if (tests[i](arguments)) {\n            return fns[i].apply(this, arguments);\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      function theTypedFn(arg0, arg1) {\n\n        if (arguments.length === len0 && test00(arg0) && test01(arg1)) {\n          return fn0.apply(this, arguments);\n        }\n        if (arguments.length === len1 && test10(arg0) && test11(arg1)) {\n          return fn1.apply(this, arguments);\n        }\n        if (arguments.length === len2 && test20(arg0) && test21(arg1)) {\n          return fn2.apply(this, arguments);\n        }\n        if (arguments.length === len3 && test30(arg0) && test31(arg1)) {\n          return fn3.apply(this, arguments);\n        }\n        if (arguments.length === len4 && test40(arg0) && test41(arg1)) {\n          return fn4.apply(this, arguments);\n        }\n        if (arguments.length === len5 && test50(arg0) && test51(arg1)) {\n          return fn5.apply(this, arguments);\n        }\n        return generic.apply(this, arguments);\n      }\n\n      // attach name the typed function\n      try {\n        Object.defineProperty(theTypedFn, 'name', {\n          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      // This property is close to the original collection of signatures\n      // used to create the typed-function, just with unions split:\n      theTypedFn.signatures = signaturesMap;\n\n      // Store internal data for functions like resolve, find, etc.\n      // Also serves as the flag that this is a typed-function\n      theTypedFn._typedFunctionData = {\n        signatures,\n        signatureMap: internalSignatureMap\n      };\n      return theTypedFn;\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     * Return all but the last items of an array or function Arguments\n     * @param {Array | Arguments} arr\n     * @return {Array}\n     */\n    function initial(arr) {\n      return slice(arr, 0, arr.length - 1);\n    }\n\n    /**\n     * return the last item of an array or function Arguments\n     * @param {Array | Arguments} 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     * 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 (let i = 0; i < arr.length; i++) {\n        if (test(arr[i])) {\n          return arr[i];\n        }\n      }\n      return undefined;\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     * Create a reference callback to one or multiple signatures\n     *\n     * Syntax:\n     *\n     *     typed.referTo(signature1, signature2, ..., function callback(fn1, fn2, ...) {\n     *       // ...\n     *     })\n     *\n     * @returns {{referTo: {references: string[], callback}}}\n     */\n    function referTo() {\n      const references = initial(arguments).map(s => stringifyParams(parseSignature(s)));\n      const callback = last(arguments);\n      if (typeof callback !== 'function') {\n        throw new TypeError('Callback function expected as last argument');\n      }\n      return makeReferTo(references, callback);\n    }\n    function makeReferTo(references, callback) {\n      return {\n        referTo: {\n          references,\n          callback\n        }\n      };\n    }\n\n    /**\n     * Create a reference callback to the typed-function itself\n     *\n     * @param {(self: function) => function} callback\n     * @returns {{referToSelf: { callback: function }}}\n     */\n    function referToSelf(callback) {\n      if (typeof callback !== 'function') {\n        throw new TypeError('Callback function expected as first argument');\n      }\n      return {\n        referToSelf: {\n          callback\n        }\n      };\n    }\n\n    /**\n     * Test whether something is a referTo object, holding a list with reference\n     * signatures and a callback.\n     *\n     * @param {Object | function} objectOrFn\n     * @returns {boolean}\n     */\n    function isReferTo(objectOrFn) {\n      return objectOrFn && typeof objectOrFn.referTo === 'object' && Array.isArray(objectOrFn.referTo.references) && typeof objectOrFn.referTo.callback === 'function';\n    }\n\n    /**\n     * Test whether something is a referToSelf object, holding a callback where\n     * to pass `self`.\n     *\n     * @param {Object | function} objectOrFn\n     * @returns {boolean}\n     */\n    function isReferToSelf(objectOrFn) {\n      return objectOrFn && typeof objectOrFn.referToSelf === 'object' && typeof objectOrFn.referToSelf.callback === 'function';\n    }\n\n    /**\n     * Check if name is (A) new, (B) a match, or (C) a mismatch; and throw\n     * an error in case (C).\n     *\n     * @param { string | undefined } nameSoFar\n     * @param { string | undefined } newName\n     * @returns { string } updated name\n     */\n    function checkName(nameSoFar, newName) {\n      if (!nameSoFar) {\n        return newName;\n      }\n      if (newName && newName !== nameSoFar) {\n        const err = new Error('Function names do not match (expected: ' + nameSoFar + ', actual: ' + newName + ')');\n        err.data = {\n          actual: newName,\n          expected: nameSoFar\n        };\n        throw err;\n      }\n      return nameSoFar;\n    }\n\n    /**\n     * Retrieve the implied name from an object with signature keys\n     * and function values, checking whether all value names match\n     *\n     * @param { {string: function} } obj\n     */\n    function getObjectName(obj) {\n      let name;\n      for (const key in obj) {\n        // Only pay attention to own properties, and only if their values\n        // are typed functions or functions with a signature property\n        if (Object.prototype.hasOwnProperty.call(obj, key) && (isTypedFunction(obj[key]) || typeof obj[key].signature === 'string')) {\n          name = checkName(name, obj[key].name);\n        }\n      }\n      return name;\n    }\n\n    /**\n     * Copy all of the signatures from the second argument into the first,\n     * which is modified by side effect, checking for conflicts\n     *\n     * @param {Object.<string, function|typed-reference>} dest\n     * @param {Object.<string, function|typed-reference>} source\n     */\n    function mergeSignatures(dest, source) {\n      let key;\n      for (key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          if (key in dest) {\n            if (source[key] !== dest[key]) {\n              const err = new Error('Signature \"' + key + '\" is defined twice');\n              err.data = {\n                signature: key,\n                sourceFunction: source[key],\n                destFunction: dest[key]\n              };\n              throw err;\n            }\n            // else: both signatures point to the same function, that's fine\n          }\n          dest[key] = source[key];\n        }\n      }\n    }\n    const saveTyped = typed;\n\n    /**\n     * Originally the main function was a typed function itself, but then\n     * it might not be able to generate error messages if the client\n     * replaced the type system with different names.\n     *\n     * Main entry: typed([name], functions/objects with signatures...)\n     *\n     * Assembles and returns a new typed-function from the given items\n     * that provide signatures and implementations, each of which may be\n     * * a plain object mapping (string) signatures to implementing functions,\n     * * a previously constructed typed function, or\n     * * any other single function with a string-valued property `signature`.\n      * The name of the resulting typed-function will be given by the\n     * string-valued name argument if present, or if not, by the name\n     * of any of the arguments that have one, as long as any that do are\n     * consistent with each other. If no name is specified, the name will be\n     * an empty string.\n     *\n     * @param {string} maybeName [optional]\n     * @param {(function|object)[]} signature providers\n     * @returns {typed-function}\n     */\n    typed = function (maybeName) {\n      const named = typeof maybeName === 'string';\n      const start = named ? 1 : 0;\n      let name = named ? maybeName : '';\n      const allSignatures = {};\n      for (let i = start; i < arguments.length; ++i) {\n        const item = arguments[i];\n        let theseSignatures = {};\n        let thisName;\n        if (typeof item === 'function') {\n          thisName = item.name;\n          if (typeof item.signature === 'string') {\n            // Case 1: Ordinary function with a string 'signature' property\n            theseSignatures[item.signature] = item;\n          } else if (isTypedFunction(item)) {\n            // Case 2: Existing typed function\n            theseSignatures = item.signatures;\n          }\n        } else if (isPlainObject(item)) {\n          // Case 3: Plain object, assume keys = signatures, values = functions\n          theseSignatures = item;\n          if (!named) {\n            thisName = getObjectName(item);\n          }\n        }\n        if (Object.keys(theseSignatures).length === 0) {\n          const err = new TypeError('Argument to \\'typed\\' at index ' + i + ' is not a (typed) function, ' + 'nor an object with signatures as keys and functions as values.');\n          err.data = {\n            index: i,\n            argument: item\n          };\n          throw err;\n        }\n        if (!named) {\n          name = checkName(name, thisName);\n        }\n        mergeSignatures(allSignatures, theseSignatures);\n      }\n      return createTypedFunction(name || '', allSignatures);\n    };\n    typed.create = create;\n    typed.createCount = saveTyped.createCount;\n    typed.onMismatch = _onMismatch;\n    typed.throwMismatchError = _onMismatch;\n    typed.createError = createError;\n    typed.clear = clear;\n    typed.clearConversions = clearConversions;\n    typed.addTypes = addTypes;\n    typed._findType = findType; // For unit testing only\n    typed.referTo = referTo;\n    typed.referToSelf = referToSelf;\n    typed.convert = convert;\n    typed.findSignature = findSignature;\n    typed.find = find;\n    typed.isTypedFunction = isTypedFunction;\n    typed.warnAgainstDeprecatedThis = true;\n\n    /**\n     * add a type (convenience wrapper for typed.addTypes)\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      let before = 'any';\n      if (beforeObjectTest !== false && typeMap.has('Object')) {\n        before = 'Object';\n      }\n      typed.addTypes([type], before);\n    };\n\n    /**\n     * Verify that the ConversionDef conversion has a valid format.\n     *\n     * @param {conversionDef} conversion\n     * @return {void}\n     * @throws {TypeError|SyntaxError}\n     */\n    function _validateConversion(conversion) {\n      if (!conversion || typeof conversion.from !== 'string' || typeof conversion.to !== 'string' || typeof conversion.convert !== 'function') {\n        throw new TypeError('Object with properties {from: string, to: string, convert: function} expected');\n      }\n      if (conversion.to === conversion.from) {\n        throw new SyntaxError('Illegal to define conversion from \"' + conversion.from + '\" to itself.');\n      }\n    }\n\n    /**\n     * Add a conversion\n     *\n     * @param {ConversionDef} conversion\n     * @param {{override: boolean}} [options]\n     * @returns {void}\n     * @throws {TypeError}\n     */\n    typed.addConversion = function (conversion) {\n      let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n        override: false\n      };\n      _validateConversion(conversion);\n      const to = findType(conversion.to);\n      const existing = to.conversionsTo.find(other => other.from === conversion.from);\n      if (existing) {\n        if (options && options.override) {\n          typed.removeConversion({\n            from: existing.from,\n            to: conversion.to,\n            convert: existing.convert\n          });\n        } else {\n          throw new Error('There is already a conversion from \"' + conversion.from + '\" to \"' + to.name + '\"');\n        }\n      }\n      to.conversionsTo.push({\n        from: conversion.from,\n        convert: conversion.convert,\n        index: nConversions++\n      });\n    };\n\n    /**\n     * Convenience wrapper to call addConversion on each conversion in a list.\n     *\n     * @param {ConversionDef[]} conversions\n     * @param {{override: boolean}} [options]\n     * @returns {void}\n     * @throws {TypeError}\n     */\n    typed.addConversions = function (conversions, options) {\n      conversions.forEach(conversion => typed.addConversion(conversion, options));\n    };\n\n    /**\n     * Remove the specified conversion. The format is the same as for\n     * addConversion, and the convert function must match or an error\n     * is thrown.\n     *\n     * @param {{from: string, to: string, convert: function}} conversion\n     * @returns {void}\n     * @throws {TypeError|SyntaxError|Error}\n     */\n    typed.removeConversion = function (conversion) {\n      _validateConversion(conversion);\n      const to = findType(conversion.to);\n      const existingConversion = findInArray(to.conversionsTo, c => c.from === conversion.from);\n      if (!existingConversion) {\n        throw new Error('Attempt to remove nonexistent conversion from ' + conversion.from + ' to ' + conversion.to);\n      }\n      if (existingConversion.convert !== conversion.convert) {\n        throw new Error('Conversion to remove does not match existing conversion');\n      }\n      const index = to.conversionsTo.indexOf(existingConversion);\n      to.conversionsTo.splice(index, 1);\n    };\n\n    /**\n     * Produce the specific signature that a typed function\n     * will execute on the given arguments. Here, a \"signature\" is an\n     * object with properties 'params', 'test', 'fn', and 'implementation'.\n     * This last property is a function that converts params as necessary\n     * and then calls 'fn'. Returns null if there is no matching signature.\n     * @param {typed-function} tf\n     * @param {any[]} argList\n     * @returns {{params: string, test: function, fn: function, implementation: function}}\n     */\n    typed.resolve = function (tf, argList) {\n      if (!isTypedFunction(tf)) {\n        throw new TypeError(NOT_TYPED_FUNCTION);\n      }\n      const sigs = tf._typedFunctionData.signatures;\n      for (let i = 0; i < sigs.length; ++i) {\n        if (sigs[i].test(argList)) {\n          return sigs[i];\n        }\n      }\n      return null;\n    };\n    return typed;\n  }\n  var typedFunction = create();\n\n  return typedFunction;\n\n}));\n//# sourceMappingURL=typed-function.js.map\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\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};","// 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.\n\nexport function isNumber (x) {\n  return typeof x === 'number'\n}\n\nexport function isBigNumber (x) {\n  if (\n    !x || typeof x !== 'object' ||\n    typeof x.constructor !== 'function'\n  ) {\n    return false\n  }\n\n  if (\n    x.isBigNumber === true &&\n    typeof x.constructor.prototype === 'object' &&\n    x.constructor.prototype.isBigNumber === true\n  ) {\n    return true\n  }\n\n  if (\n    typeof x.constructor.isDecimal === 'function' &&\n    x.constructor.isDecimal(x) === true\n  ) {\n    return true\n  }\n\n  return false\n}\n\nexport function isBigInt (x) {\n  return typeof x === 'bigint'\n}\n\nexport function isComplex (x) {\n  return (x && typeof x === 'object' && Object.getPrototypeOf(x).isComplex === true) || false\n}\n\nexport function isFraction (x) {\n  return (x && typeof x === 'object' && Object.getPrototypeOf(x).isFraction === true) || false\n}\n\nexport function isUnit (x) {\n  return (x && x.constructor.prototype.isUnit === true) || false\n}\n\nexport function isString (x) {\n  return typeof x === 'string'\n}\n\nexport const isArray = Array.isArray\n\nexport function isMatrix (x) {\n  return (x && x.constructor.prototype.isMatrix === true) || false\n}\n\n/**\n * Test whether a value is a collection: an Array or Matrix\n * @param {*} x\n * @returns {boolean} isCollection\n */\nexport function isCollection (x) {\n  return Array.isArray(x) || isMatrix(x)\n}\n\nexport function isDenseMatrix (x) {\n  return (x && x.isDenseMatrix && x.constructor.prototype.isMatrix === true) || false\n}\n\nexport function isSparseMatrix (x) {\n  return (x && x.isSparseMatrix && x.constructor.prototype.isMatrix === true) || false\n}\n\nexport function isRange (x) {\n  return (x && x.constructor.prototype.isRange === true) || false\n}\n\nexport function isIndex (x) {\n  return (x && x.constructor.prototype.isIndex === true) || false\n}\n\nexport function isBoolean (x) {\n  return typeof x === 'boolean'\n}\n\nexport function isResultSet (x) {\n  return (x && x.constructor.prototype.isResultSet === true) || false\n}\n\nexport function isHelp (x) {\n  return (x && x.constructor.prototype.isHelp === true) || false\n}\n\nexport function isFunction (x) {\n  return typeof x === 'function'\n}\n\nexport function isDate (x) {\n  return x instanceof Date\n}\n\nexport function isRegExp (x) {\n  return x instanceof RegExp\n}\n\nexport function isObject (x) {\n  return !!(x &&\n    typeof x === 'object' &&\n    x.constructor === Object &&\n    !isComplex(x) &&\n    !isFraction(x))\n}\n\nexport function isNull (x) {\n  return x === null\n}\n\nexport function isUndefined (x) {\n  return x === undefined\n}\n\nexport function isAccessorNode (x) {\n  return (x && x.isAccessorNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isArrayNode (x) {\n  return (x && x.isArrayNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isAssignmentNode (x) {\n  return (x && x.isAssignmentNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isBlockNode (x) {\n  return (x && x.isBlockNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isConditionalNode (x) {\n  return (x && x.isConditionalNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isConstantNode (x) {\n  return (x && x.isConstantNode === true && x.constructor.prototype.isNode === true) || false\n}\n\n/* Very specialized: returns true for those nodes which in the numerator of\n   a fraction means that the division in that fraction has precedence over implicit\n   multiplication, e.g. -2/3 x parses as (-2/3) x and 3/4 x parses as (3/4) x but\n   6!/8 x parses as 6! / (8x). It is located here because it is shared between\n   parse.js and OperatorNode.js (for parsing and printing, respectively).\n\n   This should *not* be exported from mathjs, unlike most of the tests here.\n   Its name does not start with 'is' to prevent utils/snapshot.js from thinking\n   it should be exported.\n*/\nexport function rule2Node (node) {\n  return isConstantNode(node) ||\n    (isOperatorNode(node) &&\n     node.args.length === 1 &&\n     isConstantNode(node.args[0]) &&\n     '-+~'.includes(node.op))\n}\n\nexport function isFunctionAssignmentNode (x) {\n  return (x && x.isFunctionAssignmentNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isFunctionNode (x) {\n  return (x && x.isFunctionNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isIndexNode (x) {\n  return (x && x.isIndexNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isNode (x) {\n  return (x && x.isNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isObjectNode (x) {\n  return (x && x.isObjectNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isOperatorNode (x) {\n  return (x && x.isOperatorNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isParenthesisNode (x) {\n  return (x && x.isParenthesisNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isRangeNode (x) {\n  return (x && x.isRangeNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isRelationalNode (x) {\n  return (x && x.isRelationalNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isSymbolNode (x) {\n  return (x && x.isSymbolNode === true && x.constructor.prototype.isNode === true) || false\n}\n\nexport function isChain (x) {\n  return (x && x.constructor.prototype.isChain === true) || false\n}\n\nexport function typeOf (x) {\n  const t = typeof x\n\n  if (t === 'object') {\n    if (x === null) return 'null'\n    if (isBigNumber(x)) return 'BigNumber' // Special: weird mashup with Decimal\n    if (x.constructor && x.constructor.name) return x.constructor.name\n\n    return 'Object' // just in case\n  }\n\n  return t // can be 'string', 'number', 'boolean', 'function', 'bigint', ...\n}\n","import { isBigNumber, isNumber, isObject } from './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 */\nexport function isInteger (value) {\n  if (typeof value === 'boolean') {\n    return true\n  }\n\n  return isFinite(value)\n    ? (value === Math.round(value))\n    : false\n}\n\n/**\n * Check if a string contains an integer\n * @param {string} str\n * @return {boolean} isInteger\n */\nexport function isIntegerStr (str) {\n  // regex matching strings like \"123\" and \"-123\"\n  return /^-?\\d+$/.test(str)\n}\n\n/**\n * Ensure the number type is compatible with the provided value.\n * If not, return 'number' instead.\n *\n * For example:\n *\n *     safeNumberType('2.3', { number: 'bigint', numberFallback: 'number' })\n *\n * will return 'number' and not 'bigint' because trying to create a bigint with\n * value 2.3 would throw an exception.\n *\n * @param {string} numberStr\n * @param {{\n *   number: 'number' | 'BigNumber' | 'bigint' | 'Fraction'\n *   numberFallback: 'number' | 'BigNumber'\n * }} config\n * @returns {'number' | 'BigNumber' | 'bigint' | 'Fraction'}\n */\nexport function safeNumberType (numberStr, config) {\n  if (config.number === 'bigint' && !isIntegerStr(numberStr)) {\n    return config.numberFallback\n  }\n\n  return config.number\n}\n\n/**\n * Calculate the sign of a number\n * @param {number} x\n * @returns {number}\n */\nexport const sign = 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/**\n * Calculate the base-2 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\nexport const log2 = Math.log2 || function log2 (x) {\n  return Math.log(x) / Math.LN2\n}\n\n/**\n * Calculate the base-10 logarithm of a number\n * @param {number} x\n * @returns {number}\n */\nexport const log10 = Math.log10 || function log10 (x) {\n  return Math.log(x) / Math.LN10\n}\n\n/**\n * Calculate the natural logarithm of a number + 1\n * @param {number} x\n * @returns {number}\n */\nexport const log1p = Math.log1p || function (x) {\n  return Math.log(x + 1)\n}\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 */\nexport const cbrt = Math.cbrt || function cbrt (x) {\n  if (x === 0) {\n    return x\n  }\n\n  const negate = x < 0\n  let result\n  if (negate) {\n    x = -x\n  }\n\n  if (isFinite(x)) {\n    result = Math.exp(Math.log(x) / 3)\n    // from https://en.wikipedia.org/wiki/Cube_root#Numerical_methods\n    result = (x / (result * result) + (2 * result)) / 3\n  } else {\n    result = x\n  }\n\n  return negate ? -result : result\n}\n\n/**\n * Calculates exponentiation minus 1\n * @param {number} x\n * @return {number} res\n */\nexport const expm1 = Math.expm1 || function expm1 (x) {\n  return (x >= 2e-4 || x <= -2e-4)\n    ? Math.exp(x) - 1\n    : x + x * x / 2 + x * x * x / 6\n}\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 */\nfunction formatNumberToBase (n, base, size) {\n  const prefixes = { 2: '0b', 8: '0o', 16: '0x' }\n  const prefix = prefixes[base]\n  let suffix = ''\n  if (size) {\n    if (size < 1) {\n      throw new Error('size must be in greater than 0')\n    }\n    if (!isInteger(size)) {\n      throw new Error('size must be an integer')\n    }\n    if (n > 2 ** (size - 1) - 1 || n < -(2 ** (size - 1))) {\n      throw new Error(`Value must be in range [-2^${size - 1}, 2^${size - 1}-1]`)\n    }\n    if (!isInteger(n)) {\n      throw new Error('Value must be an integer')\n    }\n    if (n < 0) {\n      n = n + 2 ** size\n    }\n    suffix = `i${size}`\n  }\n  let sign = ''\n  if (n < 0) {\n    n = -n\n    sign = '-'\n  }\n  return `${sign}${prefix}${n.toString(base)}${suffix}`\n}\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 */\nexport function format (value, options) {\n  if (typeof options === 'function') {\n    // handle format(value, fn)\n    return options(value)\n  }\n\n  // handle special cases\n  if (value === Infinity) {\n    return 'Infinity'\n  } else if (value === -Infinity) {\n    return '-Infinity'\n  } else if (isNaN(value)) {\n    return 'NaN'\n  }\n\n  const { notation, precision, wordSize } = normalizeFormatOptions(options)\n\n  // handle the various notations\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)\n        .replace(/((\\.\\d*?)(0+))($|e)/, function () {\n          const digits = arguments[2]\n          const e = arguments[4]\n          return (digits !== '.') ? digits + e : e\n        })\n\n    default:\n      throw new Error('Unknown notation \"' + notation + '\". ' +\n        'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.')\n  }\n}\n\n/**\n * Normalize format options into an object:\n *   {\n *     notation: string,\n *     precision: number | undefined,\n *     wordSize: number | undefined\n *   }\n */\nexport function normalizeFormatOptions (options) {\n  // default values for options\n  let notation = 'auto'\n  let precision\n  let wordSize\n\n  if (options !== undefined) {\n    if (isNumber(options)) {\n      precision = options\n    } else if (isBigNumber(options)) {\n      precision = options.toNumber()\n    } else if (isObject(options)) {\n      if (options.precision !== undefined) {\n        precision = _toNumberOrThrow(options.precision, () => {\n          throw new Error('Option \"precision\" must be a number or BigNumber')\n        })\n      }\n\n      if (options.wordSize !== undefined) {\n        wordSize = _toNumberOrThrow(options.wordSize, () => {\n          throw new Error('Option \"wordSize\" must be a number or BigNumber')\n        })\n      }\n\n      if (options.notation) {\n        notation = options.notation\n      }\n    } else {\n      throw new Error('Unsupported type of options, number, BigNumber, or object expected')\n    }\n  }\n\n  return { notation, precision, wordSize }\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 */\nexport function splitNumber (value) {\n  // parse the input value\n  const match = String(value).toLowerCase().match(/^(-?)(\\d+\\.?\\d*)(e([+-]?\\d+))?$/)\n  if (!match) {\n    throw new SyntaxError('Invalid number ' + value)\n  }\n\n  const sign = match[1]\n  const digits = match[2]\n  let exponent = parseFloat(match[4] || '0')\n\n  const dot = digits.indexOf('.')\n  exponent += (dot !== -1) ? (dot - 1) : (digits.length - 1)\n\n  const coefficients = digits\n    .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    })\n    .replace(/0*$/, '') // remove trailing zeros\n    .split('')\n    .map(function (d) {\n      return parseInt(d)\n    })\n\n  if (coefficients.length === 0) {\n    coefficients.push(0)\n    exponent++\n  }\n\n  return { sign, coefficients, 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 */\nexport function toEngineering (value, precision) {\n  if (isNaN(value) || !isFinite(value)) {\n    return String(value)\n  }\n\n  const split = splitNumber(value)\n  const rounded = roundDigits(split, precision)\n\n  const e = rounded.exponent\n  const c = rounded.coefficients\n\n  // find nearest lower multiple of 3 for exponent\n  const newExp = e % 3 === 0 ? e : (e < 0 ? (e - 3) - (e % 3) : e - (e % 3))\n\n  if (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    const missingZeros = Math.abs(e - newExp) - (c.length - 1)\n    for (let i = 0; i < missingZeros; i++) {\n      c.push(0)\n    }\n  }\n\n  // find difference in exponents\n  let expDiff = Math.abs(e - newExp)\n  let decimalIdx = 1\n\n  // push decimal index over by expDiff times\n  while (expDiff > 0) {\n    decimalIdx++\n    expDiff--\n  }\n\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  const decimals = c.slice(decimalIdx).join('')\n  const decimalVal = ((isNumber(precision) && decimals.length) || decimals.match(/[1-9]/)) ? ('.' + decimals) : ''\n\n  const str = c.slice(0, decimalIdx).join('') +\n    decimalVal +\n    'e' + (e >= 0 ? '+' : '') + newExp.toString()\n  return rounded.sign + str\n}\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 */\nexport function toFixed (value, precision) {\n  if (isNaN(value) || !isFinite(value)) {\n    return String(value)\n  }\n\n  const splitValue = splitNumber(value)\n  const rounded = (typeof precision === 'number')\n    ? roundDigits(splitValue, splitValue.exponent + 1 + precision)\n    : splitValue\n  let c = rounded.coefficients\n  let p = rounded.exponent + 1 // exponent may have changed\n\n  // append zeros if needed\n  const pp = p + (precision || 0)\n  if (c.length < pp) {\n    c = c.concat(zeros(pp - c.length))\n  }\n\n  // prepend zeros if needed\n  if (p < 0) {\n    c = zeros(-p + 1).concat(c)\n    p = 1\n  }\n\n  // insert a dot if needed\n  if (p < c.length) {\n    c.splice(p, 0, (p === 0) ? '0.' : '.')\n  }\n\n  return rounded.sign + c.join('')\n}\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 */\nexport function toExponential (value, precision) {\n  if (isNaN(value) || !isFinite(value)) {\n    return String(value)\n  }\n\n  // round if needed, else create a clone\n  const split = splitNumber(value)\n  const rounded = precision ? roundDigits(split, precision) : split\n  let c = rounded.coefficients\n  const e = rounded.exponent\n\n  // append zeros if needed\n  if (c.length < precision) {\n    c = c.concat(zeros(precision - c.length))\n  }\n\n  // format as `C.CCCe+EEE` or `C.CCCe-EEE`\n  const first = c.shift()\n  return rounded.sign + first + (c.length > 0 ? ('.' + c.join('')) : '') +\n    'e' + (e >= 0 ? '+' : '') + e\n}\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 */\nexport function toPrecision (value, precision, options) {\n  if (isNaN(value) || !isFinite(value)) {\n    return String(value)\n  }\n\n  // determine lower and upper bound for exponential notation.\n  const lowerExp = _toNumberOrDefault(options?.lowerExp, -3)\n  const upperExp = _toNumberOrDefault(options?.upperExp, 5)\n\n  const split = splitNumber(value)\n  const rounded = precision ? roundDigits(split, precision) : split\n  if (rounded.exponent < lowerExp || rounded.exponent >= upperExp) {\n    // exponential notation\n    return toExponential(value, precision)\n  } else {\n    let c = rounded.coefficients\n    const e = rounded.exponent\n\n    // append trailing zeros\n    if (c.length < precision) {\n      c = c.concat(zeros(precision - c.length))\n    }\n\n    // append trailing zeros\n    // TODO: simplify the next statement\n    c = c.concat(zeros(e - c.length + 1 +\n      (c.length < precision ? precision - c.length : 0)))\n\n    // prepend zeros\n    c = zeros(-e).concat(c)\n\n    const dot = e > 0 ? e : 0\n    if (dot < c.length - 1) {\n      c.splice(dot + 1, 0, '.')\n    }\n\n    return rounded.sign + c.join('')\n  }\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 */\nexport function roundDigits (split, precision) {\n  // create a clone\n  const rounded = {\n    sign: split.sign,\n    coefficients: split.coefficients,\n    exponent: split.exponent\n  }\n  const c = rounded.coefficients\n\n  // prepend zeros if needed\n  while (precision <= 0) {\n    c.unshift(0)\n    rounded.exponent++\n    precision++\n  }\n\n  if (c.length > precision) {\n    const removed = c.splice(precision, c.length - precision)\n\n    if (removed[0] >= 5) {\n      let i = precision - 1\n      c[i]++\n      while (c[i] === 10) {\n        c.pop()\n        if (i === 0) {\n          c.unshift(0)\n          rounded.exponent++\n          i++\n        }\n        i--\n        c[i]++\n      }\n    }\n  }\n\n  return rounded\n}\n\n/**\n * Create an array filled with zeros.\n * @param {number} length\n * @return {Array}\n */\nfunction zeros (length) {\n  const arr = []\n  for (let i = 0; i < length; i++) {\n    arr.push(0)\n  }\n  return arr\n}\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 */\nexport function digits (value) {\n  return value\n    .toExponential()\n    .replace(/e.*$/, '') // remove exponential notation\n    .replace(/^0\\.?0*|\\./, '') // remove decimal point and leading zeros\n    .length\n}\n\n/**\n * Minimum number added to one that makes the result different than one\n */\nexport const DBL_EPSILON = Number.EPSILON || 2.2204460492503130808472633361816E-16\n\n/**\n * Compares two floating point numbers.\n * @param {number} a - First value to compare\n * @param {number} b - Second value to compare\n * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0.\n * @param {number} [absTol=1e-12] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0.\n * @return {boolean} whether the two numbers are nearly equal\n *\n * @throws {Error} If `relTol` is less than or equal to 0.\n * @throws {Error} If `absTol` is less than 0.\n *\n * @example\n * nearlyEqual(1.000000001, 1.0, 1e-8);            // true\n * nearlyEqual(1.000000002, 1.0, 0);            // false\n * nearlyEqual(1.0, 1.009, undefined, 0.01);       // true\n * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true\n */\nexport function nearlyEqual (a, b, relTol = 1e-8, absTol = 0) {\n  if (relTol <= 0) {\n    throw new Error('Relative tolerance must be greater than 0')\n  }\n\n  if (absTol < 0) {\n    throw new Error('Absolute tolerance must be at least 0')\n  }\n\n  // NaN\n  if (isNaN(a) || isNaN(b)) {\n    return false\n  }\n\n  if (!isFinite(a) || !isFinite(b)) {\n    return a === b\n  }\n\n  if (a === b) {\n    return true\n  }\n\n  // abs(a-b) <= max(rel_tol * max(abs(a), abs(b)), abs_tol)\n  return Math.abs(a - b) <= Math.max(relTol * Math.max(Math.abs(a), Math.abs(b)), absTol)\n}\n\n/**\n * Calculate the hyperbolic arccos of a number\n * @param {number} x\n * @return {number}\n */\nexport const acosh = Math.acosh || function (x) {\n  return Math.log(Math.sqrt(x * x - 1) + x)\n}\n\nexport const asinh = Math.asinh || function (x) {\n  return Math.log(Math.sqrt(x * x + 1) + x)\n}\n\n/**\n * Calculate the hyperbolic arctangent of a number\n * @param {number} x\n * @return {number}\n */\nexport const atanh = Math.atanh || function (x) {\n  return Math.log((1 + x) / (1 - x)) / 2\n}\n\n/**\n * Calculate the hyperbolic cosine of a number\n * @param {number} x\n * @returns {number}\n */\nexport const cosh = Math.cosh || function (x) {\n  return (Math.exp(x) + Math.exp(-x)) / 2\n}\n\n/**\n * Calculate the hyperbolic sine of a number\n * @param {number} x\n * @returns {number}\n */\nexport const sinh = Math.sinh || function (x) {\n  return (Math.exp(x) - Math.exp(-x)) / 2\n}\n\n/**\n * Calculate the hyperbolic tangent of a number\n * @param {number} x\n * @returns {number}\n */\nexport const tanh = Math.tanh || function (x) {\n  const e = Math.exp(2 * x)\n  return (e - 1) / (e + 1)\n}\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 */\nexport function copysign (x, y) {\n  const signx = x > 0 ? true : x < 0 ? false : 1 / x === Infinity\n  const signy = y > 0 ? true : y < 0 ? false : 1 / y === Infinity\n  return signx ^ signy ? -x : x\n}\n\nfunction _toNumberOrThrow (value, onError) {\n  if (isNumber(value)) {\n    return value\n  } else if (isBigNumber(value)) {\n    return value.toNumber()\n  } else {\n    onError()\n  }\n}\n\nfunction _toNumberOrDefault (value, defaultValue) {\n  if (isNumber(value)) {\n    return value\n  } else if (isBigNumber(value)) {\n    return value.toNumber()\n  } else {\n    return defaultValue\n  }\n}\n","import { isBigNumber, isObject } from './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 */\nexport function clone (x) {\n  const type = typeof x\n\n  // immutable primitive types\n  if (type === 'number' || type === 'bigint' || type === 'string' || type === 'boolean' ||\n      x === null || x === undefined) {\n    return x\n  }\n\n  // use clone function of the object when available\n  if (typeof x.clone === 'function') {\n    return x.clone()\n  }\n\n  // array\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 (isBigNumber(x)) return x // bignumbers are immutable\n\n  // object\n  if (isObject(x)) {\n    return mapObject(x, clone)\n  }\n\n  throw new TypeError(`Cannot clone: unknown type of value (value: ${x})`)\n}\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 */\nexport function mapObject (object, callback) {\n  const clone = {}\n\n  for (const key in object) {\n    if (hasOwnProperty(object, key)) {\n      clone[key] = callback(object[key])\n    }\n  }\n\n  return clone\n}\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 */\nexport function extend (a, b) {\n  for (const prop in b) {\n    if (hasOwnProperty(b, prop)) {\n      a[prop] = b[prop]\n    }\n  }\n  return a\n}\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 */\nexport function 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 (const 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        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  return a\n}\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 */\nexport function deepStrictEqual (a, b) {\n  let prop, i, len\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    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    for (prop in b) {\n      // noinspection JSUnfilteredForInLoop\n      if (!(prop in a)) {\n        return false\n      }\n    }\n    return true\n  } else {\n    return (a === b)\n  }\n}\n\n/**\n * Recursively flatten a nested object.\n * @param {Object} nestedObject\n * @return {Object} Returns the flattened object\n */\nexport function deepFlatten (nestedObject) {\n  const flattenedObject = {}\n\n  _deepFlatten(nestedObject, flattenedObject)\n\n  return flattenedObject\n}\n\n// helper function used by deepFlatten\nfunction _deepFlatten (nestedObject, flattenedObject) {\n  for (const prop in nestedObject) {\n    if (hasOwnProperty(nestedObject, prop)) {\n      const value = nestedObject[prop]\n      if (typeof value === 'object' && value !== null) {\n        _deepFlatten(value, flattenedObject)\n      } else {\n        flattenedObject[prop] = value\n      }\n    }\n  }\n}\n\n/**\n * Test whether the current JavaScript engine supports Object.defineProperty\n * @returns {boolean} returns true if supported\n */\nexport function canDefineProperty () {\n  // test needed for broken IE8 implementation\n  try {\n    if (Object.defineProperty) {\n      Object.defineProperty({}, 'x', { get: function () { return null } })\n      return true\n    }\n  } catch (e) {}\n\n  return false\n}\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 */\nexport function lazy (object, prop, valueResolver) {\n  let _uninitialized = true\n  let _value\n\n  Object.defineProperty(object, prop, {\n    get: function () {\n      if (_uninitialized) {\n        _value = valueResolver()\n        _uninitialized = false\n      }\n      return _value\n    },\n\n    set: function (value) {\n      _value = value\n      _uninitialized = false\n    },\n\n    configurable: true,\n    enumerable: true\n  })\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 */\nexport function traverse (object, path) {\n  if (path && typeof path === 'string') {\n    return traverse(object, path.split('.'))\n  }\n\n  let obj = object\n\n  if (path) {\n    for (let i = 0; i < path.length; i++) {\n      const key = path[i]\n      if (!(key in obj)) {\n        obj[key] = {}\n      }\n      obj = obj[key]\n    }\n  }\n\n  return obj\n}\n\n/**\n * A safe hasOwnProperty\n * @param {Object} object\n * @param {string} property\n */\nexport function hasOwnProperty (object, property) {\n  return object && Object.hasOwnProperty.call(object, property)\n}\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 */\nexport function isLegacyFactory (object) {\n  return object && typeof object.factory === 'function'\n}\n\n/**\n * Get a nested property from an object\n * @param {Object} object\n * @param {string | string[]} path\n * @returns {Object}\n */\nexport function 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  let child = object\n\n  for (let i = 0; i < path.length; i++) {\n    const key = path[i]\n    child = child ? child[key] : undefined\n  }\n\n  return child\n}\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 */\nexport function 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  let child = object\n  for (let i = 0; i < path.length - 1; i++) {\n    const key = path[i]\n    if (child[key] === undefined) {\n      child[key] = {}\n    }\n    child = child[key]\n  }\n\n  if (path.length > 0) {\n    const lastKey = path[path.length - 1]\n    child[lastKey] = value\n  }\n\n  return object\n}\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 */\nexport function pick (object, properties, transform) {\n  const copy = {}\n\n  for (let i = 0; i < properties.length; i++) {\n    const key = properties[i]\n    const value = get(object, key)\n    if (value !== undefined) {\n      set(copy, key, transform ? transform(value, key) : value)\n    }\n  }\n\n  return copy\n}\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 */\nexport function pickShallow (object, properties) {\n  const copy = {}\n\n  for (let i = 0; i < properties.length; i++) {\n    const key = properties[i]\n    const value = object[key]\n    if (value !== undefined) {\n      copy[key] = value\n    }\n  }\n\n  return copy\n}\n\n// helper function to test whether a string contains a path like 'user.name'\nfunction isPath (str) {\n  return str.includes('.')\n}\n","import { pickShallow } from './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 */\nexport function 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    const deps = pickShallow(scope, dependencies.map(stripOptionalNotation))\n\n    assertDependencies(name, dependencies, scope)\n\n    return create(deps)\n  }\n\n  assertAndCreate.isFactory = true\n  assertAndCreate.fn = name\n  assertAndCreate.dependencies = dependencies.slice().sort()\n  if (meta) {\n    assertAndCreate.meta = meta\n  }\n\n  return assertAndCreate\n}\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 */\nexport function sortFactories (factories) {\n  const factoriesByName = {}\n\n  factories.forEach(factory => {\n    factoriesByName[factory.fn] = factory\n  })\n\n  function containsDependency (factory, dependency) {\n    // TODO: detect circular references\n    if (isFactory(factory)) {\n      if (factory.dependencies.includes(dependency.fn || dependency.name)) {\n        return true\n      }\n\n      if (factory.dependencies.some(d => containsDependency(factoriesByName[d], dependency))) {\n        return true\n      }\n    }\n\n    return false\n  }\n\n  const sorted = []\n\n  function addFactory (factory) {\n    let index = 0\n    while (index < sorted.length && !containsDependency(sorted[index], factory)) {\n      index++\n    }\n\n    sorted.splice(index, 0, factory)\n  }\n\n  // sort regular factory functions\n  factories\n    .filter(isFactory)\n    .forEach(addFactory)\n\n  // sort legacy factory functions AFTER the regular factory functions\n  factories\n    .filter(factory => !isFactory(factory))\n    .forEach(addFactory)\n\n  return sorted\n}\n\n// TODO: comment or cleanup if unused in the end\nexport function create (factories, scope = {}) {\n  sortFactories(factories)\n    .forEach(factory => factory(scope))\n\n  return scope\n}\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 */\nexport function isFactory (obj) {\n  return typeof obj === 'function' &&\n    typeof obj.fn === 'string' &&\n    Array.isArray(obj.dependencies)\n}\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 */\nexport function assertDependencies (name, dependencies, scope) {\n  const allDefined = dependencies\n    .filter(dependency => !isOptionalDependency(dependency)) // filter optionals\n    .every(dependency => scope[dependency] !== undefined)\n\n  if (!allDefined) {\n    const missingDependencies = dependencies.filter(dependency => scope[dependency] === undefined)\n\n    // TODO: create a custom error class for this, a MathjsError or something like that\n    throw new Error(`Cannot create function \"${name}\", ` +\n      `some dependencies are missing: ${missingDependencies.map(d => `\"${d}\"`).join(', ')}.`)\n  }\n}\n\nexport function isOptionalDependency (dependency) {\n  return dependency && dependency[0] === '?'\n}\n\nexport function stripOptionalNotation (dependency) {\n  return dependency && dependency[0] === '?'\n    ? dependency.slice(1)\n    : dependency\n}\n","import { hasOwnProperty } from './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/**\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?\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((prop) => hasOwnProperty(object, prop))\n}\n\nfunction hasSafeProperty (object, prop) {\n  return prop in object\n}\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 */\nfunction isSafeProperty (object, prop) {\n  if (!object || typeof object !== 'object') {\n    return false\n  }\n  // SAFE: whitelisted\n  // e.g length\n  if (hasOwnProperty(safeNativeProperties, prop)) {\n    return true\n  }\n  // UNSAFE: inherited from Object prototype\n  // e.g constructor\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  }\n  // UNSAFE: inherited from Function prototype\n  // e.g call, apply\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  return true\n}\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 * @return {function} Returns the method when valid\n */\nfunction getSafeMethod (object, method) {\n  if (!isSafeMethod(object, method)) {\n    throw new Error('No access to method \"' + method + '\"')\n  }\n\n  return object[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 */\nfunction isSafeMethod (object, method) {\n  if (object === null || object === undefined || typeof object[method] !== 'function') {\n    return false\n  }\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  if (hasOwnProperty(object, method) &&\n      (Object.getPrototypeOf && (method in Object.getPrototypeOf(object)))) {\n    return false\n  }\n  // SAFE: whitelisted\n  // e.g toString\n  if (hasOwnProperty(safeNativeMethods, method)) {\n    return true\n  }\n  // UNSAFE: inherited from Object prototype\n  // e.g constructor\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  }\n  // UNSAFE: inherited from Function prototype\n  // e.g call, apply\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  return true\n}\n\nfunction isPlainObject (object) {\n  return typeof object === 'object' && object && object.constructor === Object\n}\n\nconst safeNativeProperties = {\n  length: true,\n  name: true\n}\n\nconst safeNativeMethods = {\n  toString: true,\n  valueOf: true,\n  toLocaleString: true\n}\n\nexport { getSafeProperty }\nexport { setSafeProperty }\nexport { isSafeProperty }\nexport { hasSafeProperty }\nexport { getSafeProperties }\nexport { getSafeMethod }\nexport { isSafeMethod }\nexport { isPlainObject }\n","import { setSafeProperty, hasSafeProperty, getSafeProperty } from './customs.js'\nimport { isObject } from './is.js'\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 */\nexport class ObjectWrappingMap {\n  constructor (object) {\n    this.wrappedObject = object\n\n    this[Symbol.iterator] = this.entries\n  }\n\n  keys () {\n    return Object.keys(this.wrappedObject).values()\n  }\n\n  get (key) {\n    return getSafeProperty(this.wrappedObject, key)\n  }\n\n  set (key, value) {\n    setSafeProperty(this.wrappedObject, key, value)\n    return this\n  }\n\n  has (key) {\n    return hasSafeProperty(this.wrappedObject, key)\n  }\n\n  entries () {\n    return mapIterator(this.keys(), key => [key, this.get(key)])\n  }\n\n  forEach (callback) {\n    for (const key of this.keys()) {\n      callback(this.get(key), key, this)\n    }\n  }\n\n  delete (key) {\n    delete this.wrappedObject[key]\n  }\n\n  clear () {\n    for (const key of this.keys()) {\n      this.delete(key)\n    }\n  }\n\n  get size () {\n    return Object.keys(this.wrappedObject).length\n  }\n}\n\n/**\n * Create a map with two partitions: a and b.\n * The set with bKeys determines which keys/values are read/written to map b,\n * all other values are read/written to map a\n *\n * For example:\n *\n *   const a = new Map()\n *   const b = new Map()\n *   const p = new PartitionedMap(a, b, new Set(['x', 'y']))\n *\n * In this case, values `x` and `y` are read/written to map `b`,\n * all other values are read/written to map `a`.\n */\nexport class PartitionedMap {\n  /**\n   * @param {Map} a\n   * @param {Map} b\n   * @param {Set} bKeys\n   */\n  constructor (a, b, bKeys) {\n    this.a = a\n    this.b = b\n    this.bKeys = bKeys\n\n    this[Symbol.iterator] = this.entries\n  }\n\n  get (key) {\n    return this.bKeys.has(key)\n      ? this.b.get(key)\n      : this.a.get(key)\n  }\n\n  set (key, value) {\n    if (this.bKeys.has(key)) {\n      this.b.set(key, value)\n    } else {\n      this.a.set(key, value)\n    }\n    return this\n  }\n\n  has (key) {\n    return this.b.has(key) || this.a.has(key)\n  }\n\n  keys () {\n    return new Set([\n      ...this.a.keys(),\n      ...this.b.keys()\n    ])[Symbol.iterator]()\n  }\n\n  entries () {\n    return mapIterator(this.keys(), key => [key, this.get(key)])\n  }\n\n  forEach (callback) {\n    for (const key of this.keys()) {\n      callback(this.get(key), key, this)\n    }\n  }\n\n  delete (key) {\n    return this.bKeys.has(key)\n      ? this.b.delete(key)\n      : this.a.delete(key)\n  }\n\n  clear () {\n    this.a.clear()\n    this.b.clear()\n  }\n\n  get size () {\n    return [...this.keys()].length\n  }\n}\n\n/**\n * Create a new iterator that maps over the provided iterator, applying a mapping function to each item\n */\nfunction mapIterator (it, callback) {\n  return {\n    next: () => {\n      const n = it.next()\n      return (n.done)\n        ? n\n        : {\n            value: callback(n.value),\n            done: false\n          }\n    }\n  }\n}\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 */\nexport function createEmptyMap () {\n  return new Map()\n}\n\n/**\n * Creates a Map from the given object.\n *\n * @param { Map | { [key: string]: unknown } | undefined } mapOrObject\n * @returns\n */\nexport function createMap (mapOrObject) {\n  if (!mapOrObject) {\n    return createEmptyMap()\n  }\n  if (isMap(mapOrObject)) {\n    return mapOrObject\n  }\n  if (isObject(mapOrObject)) {\n    return new ObjectWrappingMap(mapOrObject)\n  }\n\n  throw new Error('createMap can create maps from objects or Maps')\n}\n\n/**\n * Unwraps a map into an object.\n *\n * @param {Map} map\n * @returns { [key: string]: unknown }\n */\nexport function toObject (map) {\n  if (map instanceof ObjectWrappingMap) {\n    return map.wrappedObject\n  }\n  const object = {}\n  for (const key of map.keys()) {\n    const value = map.get(key)\n    setSafeProperty(object, key, value)\n  }\n  return object\n}\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 */\nexport function 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  return object instanceof Map ||\n    object instanceof ObjectWrappingMap ||\n    (\n      typeof object.set === 'function' &&\n      typeof object.get === 'function' &&\n      typeof object.keys === 'function' &&\n      typeof object.has === 'function'\n    )\n}\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 */\nexport function assign (map, ...objects) {\n  for (const args of objects) {\n    if (!args) {\n      continue\n    }\n    if (isMap(args)) {\n      for (const key of args.keys()) {\n        map.set(key, args.get(key))\n      }\n    } else if (isObject(args)) {\n      for (const key of Object.keys(args)) {\n        map.set(key, args[key])\n      }\n    }\n  }\n  return map\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<string, function>} signatures   Object with one or multiple function signatures\n * @returns {function} The created typed-function.\n */\n\nimport {\n  isAccessorNode,\n  isArray,\n  isArrayNode,\n  isAssignmentNode,\n  isBigNumber,\n  isBlockNode,\n  isBoolean,\n  isChain,\n  isCollection,\n  isComplex,\n  isConditionalNode,\n  isConstantNode,\n  isDate,\n  isDenseMatrix,\n  isFraction,\n  isFunction,\n  isFunctionAssignmentNode,\n  isFunctionNode,\n  isHelp,\n  isIndex,\n  isIndexNode,\n  isMatrix,\n  isNode,\n  isNull,\n  isNumber,\n  isObject,\n  isObjectNode,\n  isOperatorNode,\n  isParenthesisNode,\n  isRange,\n  isRangeNode,\n  isRelationalNode,\n  isRegExp,\n  isResultSet,\n  isSparseMatrix,\n  isString,\n  isSymbolNode,\n  isUndefined,\n  isUnit, isBigInt\n} from '../../utils/is.js'\nimport typedFunction from 'typed-function'\nimport { digits } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { isMap } from '../../utils/map.js'\n\n// returns a new instance of typed-function\nlet _createTyped = function () {\n  // initially, return the original instance of typed-function\n  // consecutively, return a new instance from typed.create.\n  _createTyped = typedFunction.create\n  return typedFunction\n}\n\nconst dependencies = [\n  '?BigNumber',\n  '?Complex',\n  '?DenseMatrix',\n  '?Fraction'\n]\n\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 */\nexport const createTyped = /* #__PURE__ */ factory('typed', dependencies, function createTyped ({ BigNumber, Complex, DenseMatrix, Fraction }) {\n  // TODO: typed-function must be able to silently ignore signatures with unknown data types\n\n  // get a new instance of typed-function\n  const typed = _createTyped()\n\n  // 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  typed.clear()\n  typed.addTypes([\n    { name: 'number', test: isNumber },\n    { name: 'Complex', test: isComplex },\n    { name: 'BigNumber', test: isBigNumber },\n    { name: 'bigint', test: isBigInt },\n    { name: 'Fraction', test: isFraction },\n    { name: 'Unit', test: isUnit },\n    // The following type matches a valid variable name, i.e., an alphanumeric\n    // string starting with an alphabetic character. It is used (at least)\n    // in the definition of the derivative() function, as the argument telling\n    // what to differentiate over must (currently) be a variable.\n    {\n      name: 'identifier',\n      test: s => isString && /^\\p{L}[\\p{L}\\d]*$/u.test(s)\n    },\n    { name: 'string', test: isString },\n    { name: 'Chain', test: isChain },\n    { name: 'Array', test: isArray },\n    { name: 'Matrix', test: isMatrix },\n    { name: 'DenseMatrix', test: isDenseMatrix },\n    { name: 'SparseMatrix', test: isSparseMatrix },\n    { name: 'Range', test: isRange },\n    { name: 'Index', test: isIndex },\n    { name: 'boolean', test: isBoolean },\n    { name: 'ResultSet', test: isResultSet },\n    { name: 'Help', test: isHelp },\n    { name: 'function', test: isFunction },\n    { name: 'Date', test: isDate },\n    { name: 'RegExp', test: isRegExp },\n    { name: 'null', test: isNull },\n    { name: 'undefined', test: isUndefined },\n\n    { name: 'AccessorNode', test: isAccessorNode },\n    { name: 'ArrayNode', test: isArrayNode },\n    { name: 'AssignmentNode', test: isAssignmentNode },\n    { name: 'BlockNode', test: isBlockNode },\n    { name: 'ConditionalNode', test: isConditionalNode },\n    { name: 'ConstantNode', test: isConstantNode },\n    { name: 'FunctionNode', test: isFunctionNode },\n    { name: 'FunctionAssignmentNode', test: isFunctionAssignmentNode },\n    { name: 'IndexNode', test: isIndexNode },\n    { name: 'Node', test: isNode },\n    { name: 'ObjectNode', test: isObjectNode },\n    { name: 'OperatorNode', test: isOperatorNode },\n    { name: 'ParenthesisNode', test: isParenthesisNode },\n    { name: 'RangeNode', test: isRangeNode },\n    { name: 'RelationalNode', test: isRelationalNode },\n    { name: 'SymbolNode', test: isSymbolNode },\n\n    { name: 'Map', test: isMap },\n    { name: 'Object', test: isObject } // order 'Object' last, it matches on other classes too\n  ])\n\n  typed.addConversions([\n    {\n      from: 'number',\n      to: 'BigNumber',\n      convert: function (x) {\n        if (!BigNumber) {\n          throwNoBignumber(x)\n        }\n\n        // note: conversion from number to BigNumber can fail if x has >15 digits\n        if (digits(x) > 15) {\n          throw new TypeError('Cannot implicitly convert a number with >15 significant digits to BigNumber ' +\n            '(value: ' + x + '). ' +\n            'Use function bignumber(x) to convert to BigNumber.')\n        }\n        return new BigNumber(x)\n      }\n    }, {\n      from: 'number',\n      to: 'Complex',\n      convert: function (x) {\n        if (!Complex) {\n          throwNoComplex(x)\n        }\n\n        return new Complex(x, 0)\n      }\n    }, {\n      from: 'BigNumber',\n      to: 'Complex',\n      convert: function (x) {\n        if (!Complex) {\n          throwNoComplex(x)\n        }\n\n        return new Complex(x.toNumber(), 0)\n      }\n    }, {\n      from: 'bigint',\n      to: 'number',\n      convert: function (x) {\n        if (x > Number.MAX_SAFE_INTEGER) {\n          throw new TypeError('Cannot implicitly convert bigint to number: ' +\n            'value exceeds the max safe integer value (value: ' + x + ')')\n        }\n\n        return Number(x)\n      }\n    }, {\n      from: 'bigint',\n      to: 'BigNumber',\n      convert: function (x) {\n        if (!BigNumber) {\n          throwNoBignumber(x)\n        }\n\n        return new BigNumber(x.toString())\n      }\n    }, {\n      from: 'bigint',\n      to: 'Fraction',\n      convert: function (x) {\n        if (!Fraction) {\n          throwNoFraction(x)\n        }\n\n        return new Fraction(x.toString())\n      }\n    }, {\n      from: 'Fraction',\n      to: 'BigNumber',\n      convert: function (x) {\n        throw new TypeError('Cannot implicitly convert a Fraction to BigNumber or vice versa. ' +\n          '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 (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 (x) {\n        if (!Fraction) {\n          throwNoFraction(x)\n        }\n\n        const f = new Fraction(x)\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 ' +\n            '(value: ' + x + '). ' +\n            'Use function fraction(x) to convert to Fraction.')\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 (x) {\n        const n = Number(x)\n        if (isNaN(n)) {\n          throw new Error('Cannot convert \"' + x + '\" to a number')\n        }\n        return n\n      }\n    }, {\n      from: 'string',\n      to: 'BigNumber',\n      convert: function (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: 'bigint',\n      convert: function (x) {\n        try {\n          return BigInt(x)\n        } catch (err) {\n          throw new Error('Cannot convert \"' + x + '\" to BigInt')\n        }\n      }\n    }, {\n      from: 'string',\n      to: 'Fraction',\n      convert: function (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 (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 (x) {\n        return +x\n      }\n    }, {\n      from: 'boolean',\n      to: 'BigNumber',\n      convert: function (x) {\n        if (!BigNumber) {\n          throwNoBignumber(x)\n        }\n\n        return new BigNumber(+x)\n      }\n    }, {\n      from: 'boolean',\n      to: 'bigint',\n      convert: function (x) {\n        return BigInt(+x)\n      }\n    }, {\n      from: 'boolean',\n      to: 'Fraction',\n      convert: function (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 (x) {\n        return String(x)\n      }\n    }, {\n      from: 'Array',\n      to: 'Matrix',\n      convert: function (array) {\n        if (!DenseMatrix) {\n          throwNoMatrix()\n        }\n\n        return new DenseMatrix(array)\n      }\n    }, {\n      from: 'Matrix',\n      to: 'Array',\n      convert: function (matrix) {\n        return matrix.valueOf()\n      }\n    }\n  ])\n\n  // Provide a suggestion on how to call a function elementwise\n  // This was added primarily as guidance for the v10 -> v11 transition,\n  // and could potentially be removed in the future if it no longer seems\n  // to be helpful.\n  typed.onMismatch = (name, args, signatures) => {\n    const usualError = typed.createError(name, args, signatures)\n    if (['wrongType', 'mismatch'].includes(usualError.data.category) &&\n        args.length === 1 && isCollection(args[0]) &&\n        // check if the function can be unary:\n        signatures.some(sig => !sig.params.includes(','))) {\n      const err = new TypeError(\n        `Function '${name}' doesn't apply to matrices. To call it ` +\n          `elementwise on a matrix 'M', try 'map(M, ${name})'.`)\n      err.data = usualError.data\n      throw err\n    }\n    throw usualError\n  }\n\n  // Provide a suggestion on how to call a function elementwise\n  // This was added primarily as guidance for the v10 -> v11 transition,\n  // and could potentially be removed in the future if it no longer seems\n  // to be helpful.\n  typed.onMismatch = (name, args, signatures) => {\n    const usualError = typed.createError(name, args, signatures)\n    if (['wrongType', 'mismatch'].includes(usualError.data.category) &&\n        args.length === 1 && isCollection(args[0]) &&\n        // check if the function can be unary:\n        signatures.some(sig => !sig.params.includes(','))) {\n      const err = new TypeError(\n        `Function '${name}' doesn't apply to matrices. To call it ` +\n          `elementwise on a matrix 'M', try 'map(M, ${name})'.`)\n      err.data = usualError.data\n      throw err\n    }\n    throw usualError\n  }\n\n  return typed\n})\n\nfunction throwNoBignumber (x) {\n  throw new Error(`Cannot convert value ${x} into a BigNumber: no class 'BigNumber' provided`)\n}\n\nfunction throwNoComplex (x) {\n  throw new Error(`Cannot convert value ${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 ${x} into a Fraction, no class 'Fraction' provided.`)\n}\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'ResultSet'\nconst dependencies = []\n\nexport const createResultSet = /* #__PURE__ */ factory(name, dependencies, () => {\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  /**\n   * Attach type information\n   */\n  ResultSet.prototype.type = 'ResultSet'\n  ResultSet.prototype.isResultSet = true\n\n  /**\n   * Returns the array with results hold by this ResultSet\n   * @memberof ResultSet\n   * @returns {Array} entries\n   */\n  ResultSet.prototype.valueOf = function () {\n    return this.entries\n  }\n\n  /**\n   * Returns the stringified results of the ResultSet\n   * @memberof ResultSet\n   * @returns {string} string\n   */\n  ResultSet.prototype.toString = function () {\n    return '[' + this.entries.join(', ') + ']'\n  }\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  ResultSet.prototype.toJSON = function () {\n    return {\n      mathjs: 'ResultSet',\n      entries: this.entries\n    }\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  ResultSet.fromJSON = function (json) {\n    return new ResultSet(json.entries)\n  }\n\n  return ResultSet\n}, { isClass: true })\n","/*!\r\n *  decimal.js v10.4.3\r\n *  An arbitrary-precision Decimal type for JavaScript.\r\n *  https://github.com/MikeMcl/decimal.js\r\n *  Copyright (c) 2022 Michael Mclaughlin <[email protected]>\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\nvar 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  inexact, 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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nP.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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nvar 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction 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\nfunction trunc(x) {\r\n  return finalise(x = new this(x), x.e + 1, 1);\r\n}\r\n\r\n\r\nP[Symbol.for('nodejs.util.inspect.custom')] = P.toString;\r\nP[Symbol.toStringTag] = 'Decimal';\r\n\r\n// Create and configure initial Decimal constructor.\r\nexport var Decimal = P.constructor = clone(DEFAULTS);\r\n\r\n// Create the internal constants from their string values.\r\nLN10 = new Decimal(LN10);\r\nPI = new Decimal(PI);\r\n\r\nexport default Decimal;\r\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'BigNumber'\nconst dependencies = ['?on', 'config']\n\nexport const createBigNumberClass = /* #__PURE__ */ factory(name, dependencies, ({ on, config }) => {\n  const BigNumber = Decimal.clone({ precision: config.precision, modulo: Decimal.EUCLID })\n  BigNumber.prototype = Object.create(BigNumber.prototype)\n\n  /**\n   * Attach type information\n   */\n  BigNumber.prototype.type = 'BigNumber'\n  BigNumber.prototype.isBigNumber = true\n\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  BigNumber.prototype.toJSON = function () {\n    return {\n      mathjs: 'BigNumber',\n      value: this.toString()\n    }\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  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({ precision: curr.precision })\n      }\n    })\n  }\n\n  return BigNumber\n}, { isClass: true })\n","import Complex from 'complex.js'\nimport { format } from '../../utils/number.js'\nimport { isNumber, isUnit } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Complex'\nconst dependencies = []\n\nexport const createComplexClass = /* #__PURE__ */ factory(name, dependencies, () => {\n  /**\n   * Attach type information\n   */\n  Object.defineProperty(Complex, 'name', { value: 'Complex' })\n  Complex.prototype.constructor = Complex\n  Complex.prototype.type = 'Complex'\n  Complex.prototype.isComplex = true\n\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  Complex.prototype.toJSON = function () {\n    return {\n      mathjs: 'Complex',\n      re: this.re,\n      im: this.im\n    }\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  Complex.prototype.toPolar = function () {\n    return {\n      r: this.abs(),\n      phi: this.arg()\n    }\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  Complex.prototype.format = function (options) {\n    let str = ''\n    let im = this.im\n    let re = this.re\n    const strRe = format(this.re, options)\n    const strIm = format(this.im, options)\n\n    // round either re or im when smaller than the configured precision\n    const precision = isNumber(options) ? options : options ? options.precision : null\n    if (precision !== null) {\n      const epsilon = Math.pow(10, -precision)\n      if (Math.abs(re / im) < epsilon) {\n        re = 0\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    return str\n  }\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  Complex.fromPolar = function (args) {\n    switch (arguments.length) {\n      case 1:\n      {\n        const arg = arguments[0]\n        if (typeof arg === 'object') {\n          return Complex(arg)\n        } else {\n          throw new TypeError('Input has to be an object with r and phi keys.')\n        }\n      }\n      case 2:\n      {\n        const r = arguments[0]\n        let phi = arguments[1]\n        if (isNumber(r)) {\n          if (isUnit(phi) && phi.hasBase('ANGLE')) {\n            // convert unit to a number in radians\n            phi = phi.toNumber('rad')\n          }\n\n          if (isNumber(phi)) {\n            return new Complex({ r, phi })\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.prototype.valueOf = Complex.prototype.toString\n\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  Complex.fromJSON = function (json) {\n    return new Complex(json)\n  }\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  Complex.compare = function (a, b) {\n    if (a.re > b.re) { return 1 }\n    if (a.re < b.re) { return -1 }\n\n    if (a.im > b.im) { return 1 }\n    if (a.im < b.im) { return -1 }\n\n    return 0\n  }\n\n  return Complex\n}, { isClass: true })\n","/**\n * @license Fraction.js v4.3.7 31/08/2023\n * https://www.xarg.org/2014/03/rational-numbers-in-javascript/\n *\n * Copyright (c) 2023, Robert Eisele ([email protected])\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 => <numerator>, 1 => <denominator> ]\n * [ n => <numerator>, d => <denominator> ]\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\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\nvar MAX_CYCLE_LEN = 2000;\n\n// Parsed data to avoid calling \"new\" all the time\nvar P = {\n  \"s\": 1,\n  \"n\": 0,\n  \"d\": 1\n};\n\nfunction assign(n, s) {\n\n  if (isNaN(n = parseInt(n, 10))) {\n    throw InvalidParameter();\n  }\n  return n * s;\n}\n\n// Creates a new Fraction internally without the need of the bulky constructor\nfunction newFraction(n, d) {\n\n  if (d === 0) {\n    throw 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\nfunction 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\nvar 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 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 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 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 InvalidParameter();\n    }\n\n  if (d === 0) {\n    throw DivisionByZero();\n  }\n\n  P[\"s\"] = s < 0 ? -1 : 1;\n  P[\"n\"] = Math.abs(n);\n  P[\"d\"] = Math.abs(d);\n};\n\nfunction 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\nfunction 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\nfunction 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\nfunction 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 */\nexport default 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\nvar DivisionByZero = function() { return new Error(\"Division by Zero\"); };\nvar InvalidParameter = function() { return new Error(\"Invalid argument\"); };\nvar NonIntegerParameter = function() { return new Error(\"Parameters must be integer\"); };\n\nFraction.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 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 number\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   * Rounds a rational number to a multiple of another rational number\n   *\n   * Ex: new Fraction('0.9').roundTo(\"1/8\") => 7 / 8\n   **/\n  \"roundTo\": function(a, b) {\n\n    /*\n    k * x/y ≤ a/b < (k+1) * x/y\n    ⇔ k ≤ a/b / (x/y) < (k+1)\n    ⇔ k = floor(a/b * y/x)\n    */\n\n    parse(a, b);\n\n    return newFraction(this['s'] * Math.round(this['n'] * P['d'] / (this['d'] * P['n'])) * P['n'], P['d']);\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 (Math.abs(s['sub'](thisABS).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","import Fraction from 'fraction.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Fraction'\nconst dependencies = []\n\nexport const createFractionClass = /* #__PURE__ */ factory(name, dependencies, () => {\n  /**\n   * Attach type information\n   */\n  Object.defineProperty(Fraction, 'name', { value: 'Fraction' })\n  Fraction.prototype.constructor = Fraction\n  Fraction.prototype.type = 'Fraction'\n  Fraction.prototype.isFraction = true\n\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  Fraction.prototype.toJSON = function () {\n    return {\n      mathjs: 'Fraction',\n      n: this.s * this.n,\n      d: this.d\n    }\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  Fraction.fromJSON = function (json) {\n    return new Fraction(json)\n  }\n\n  return Fraction\n}, { isClass: true })\n","import { isBigNumber } from '../../utils/is.js'\nimport { format, sign } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Range'\nconst dependencies = []\n\nexport const createRangeClass = /* #__PURE__ */ factory(name, dependencies, () => {\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    const hasStart = start !== null && start !== undefined\n    const hasEnd = end !== null && end !== undefined\n    const hasStep = step !== null && step !== undefined\n\n    if (hasStart) {\n      if (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    if (hasEnd) {\n      if (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    if (hasStep) {\n      if (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  /**\n   * Attach type information\n   */\n  Range.prototype.type = 'Range'\n  Range.prototype.isRange = true\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   * @memberof Range\n   * @param {string} str\n   * @return {Range | null} range\n   */\n  Range.parse = function (str) {\n    if (typeof str !== 'string') {\n      return null\n    }\n\n    const args = str.split(':')\n    const nums = args.map(function (arg) {\n      return parseFloat(arg)\n    })\n\n    const invalid = nums.some(function (num) {\n      return isNaN(num)\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      case 3:\n        return new Range(nums[0], nums[2], nums[1])\n      default:\n        return null\n    }\n  }\n\n  /**\n   * Create a clone of the range\n   * @return {Range} clone\n   */\n  Range.prototype.clone = function () {\n    return new Range(this.start, this.end, this.step)\n  }\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  Range.prototype.size = function () {\n    let len = 0\n    const start = this.start\n    const step = this.step\n    const end = this.end\n    const diff = end - start\n\n    if (sign(step) === 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    return [len]\n  }\n\n  /**\n   * Calculate the minimum value in the range\n   * @memberof Range\n   * @return {number | undefined} min\n   */\n  Range.prototype.min = function () {\n    const 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  /**\n   * Calculate the maximum value in the range\n   * @memberof Range\n   * @return {number | undefined} max\n   */\n  Range.prototype.max = function () {\n    const 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  /**\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  Range.prototype.forEach = function (callback) {\n    let x = this.start\n    const step = this.step\n    const end = this.end\n    let 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  /**\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  Range.prototype.map = function (callback) {\n    const array = []\n    this.forEach(function (value, index, obj) {\n      array[index[0]] = callback(value, index, obj)\n    })\n    return array\n  }\n\n  /**\n   * Create an Array with a copy of the Ranges data\n   * @memberof Range\n   * @returns {Array} array\n   */\n  Range.prototype.toArray = function () {\n    const array = []\n    this.forEach(function (value, index) {\n      array[index[0]] = value\n    })\n    return array\n  }\n\n  /**\n   * Get the primitive value of the Range, a one dimensional array\n   * @memberof Range\n   * @returns {Array} array\n   */\n  Range.prototype.valueOf = function () {\n    // TODO: implement a caching mechanism for range.valueOf()\n    return this.toArray()\n  }\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  Range.prototype.format = function (options) {\n    let str = format(this.start, options)\n\n    if (this.step !== 1) {\n      str += ':' + format(this.step, options)\n    }\n    str += ':' + format(this.end, options)\n    return str\n  }\n\n  /**\n   * Get a string representation of the range.\n   * @memberof Range\n   * @returns {string}\n   */\n  Range.prototype.toString = function () {\n    return this.format()\n  }\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  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  /**\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  Range.fromJSON = function (json) {\n    return new Range(json.start, json.end, json.step)\n  }\n\n  return Range\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'Matrix'\nconst dependencies = []\n\nexport const createMatrixClass = /* #__PURE__ */ factory(name, dependencies, () => {\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  /**\n   * Attach type information\n   */\n  Matrix.prototype.type = 'Matrix'\n  Matrix.prototype.isMatrix = true\n\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  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  /**\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  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  /**\n   * Create a new Matrix With the type of the current matrix instance\n   * @param {Array | Object} data\n   * @param {string} [datatype]\n   */\n  Matrix.prototype.create = function (data, datatype) {\n    throw new Error('Cannot invoke create on a Matrix interface')\n  }\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  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  /**\n   * Get a single element from the matrix.\n   * @param {number[]} index   Zero-based index\n   * @return {*} value\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  /**\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  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  /**\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  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  /**\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  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  /**\n   * Create a clone of the matrix\n   * @return {Matrix} clone\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  /**\n   * Retrieve the size of the matrix.\n   * @returns {number[]} size\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  /**\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  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  /**\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  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  /**\n   * Iterate over the matrix elements\n   * @return {Iterable<{ value, index: number[] }>}\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  /**\n   * Create an Array with a copy of the data of the Matrix\n   * @returns {Array} array\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  /**\n   * Get the primitive value of the Matrix: a multidimensional array\n   * @returns {Array} array\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  /**\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  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  /**\n   * Get a string representation of the matrix\n   * @returns {string} str\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}, { isClass: true })\n","function _extends() {\n  return _extends = Object.assign ? Object.assign.bind() : function (n) {\n    for (var e = 1; e < arguments.length; e++) {\n      var t = arguments[e];\n      for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n    }\n    return n;\n  }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","import { isBigNumber, isNumber } from '../is.js'\nimport { isInteger, normalizeFormatOptions } from '../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  const BigNumberCtor = n.constructor\n  const big2 = new BigNumberCtor(2)\n  let suffix = ''\n  if (size) {\n    if (size < 1) {\n      throw new Error('size must be in greater than 0')\n    }\n    if (!isInteger(size)) {\n      throw new Error('size must be an integer')\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^${size - 1}, 2^${size - 1}-1]`)\n    }\n    if (!n.isInteger()) {\n      throw new Error('Value must be an integer')\n    }\n    if (n.lessThan(0)) {\n      n = n.add(big2.pow(size))\n    }\n    suffix = `i${size}`\n  }\n  switch (base) {\n    case 2: return `${n.toBinary()}${suffix}`\n    case 8: return `${n.toOctal()}${suffix}`\n    case 16: return `${n.toHexadecimal()}${suffix}`\n    default: throw new Error(`Base ${base} not supported `)\n  }\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 | BigNumber} [options]\n * @return {string} str The formatted value\n */\nexport function format (value, options) {\n  if (typeof options === 'function') {\n    // handle format(value, fn)\n    return options(value)\n  }\n\n  // handle special cases\n  if (!value.isFinite()) {\n    return value.isNaN() ? 'NaN' : (value.gt(0) ? 'Infinity' : '-Infinity')\n  }\n\n  const { notation, precision, wordSize } = normalizeFormatOptions(options)\n\n  // handle the various notations\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      const lowerExp = _toNumberOrDefault(options?.lowerExp, -3)\n      const upperExp = _toNumberOrDefault(options?.upperExp, 5)\n\n      // handle special case zero\n      if (value.isZero()) return '0'\n\n      // determine whether or not to output exponential notation\n      let str\n      const rounded = value.toSignificantDigits(precision)\n      const exp = rounded.e\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      }\n\n      // remove trailing zeros after the decimal point\n      return str.replace(/((\\.\\d*?)(0+))($|e)/, function () {\n        const digits = arguments[2]\n        const e = arguments[4]\n        return (digits !== '.') ? digits + e : e\n      })\n    }\n    default:\n      throw new Error('Unknown notation \"' + notation + '\". ' +\n          'Choose \"auto\", \"exponential\", \"fixed\", \"bin\", \"oct\", or \"hex.')\n  }\n}\n\n/**\n * Format a BigNumber in engineering notation. Like '1.23e+6', '2.3e+0', '3.500e-3'\n * @param {BigNumber} value\n * @param {number} [precision]        Optional number of significant figures to return.\n */\nexport function toEngineering (value, precision) {\n  // find nearest lower multiple of 3 for exponent\n  const e = value.e\n  const newExp = e % 3 === 0 ? e : (e < 0 ? (e - 3) - (e % 3) : e - (e % 3))\n\n  // find difference in exponents, and calculate the value without exponent\n  const valueWithoutExp = value.mul(Math.pow(10, -newExp))\n\n  let valueStr = valueWithoutExp.toPrecision(precision)\n  if (valueStr.includes('e')) {\n    const BigNumber = value.constructor\n    valueStr = new BigNumber(valueStr).toFixed()\n  }\n\n  return valueStr + 'e' + (e >= 0 ? '+' : '') + newExp.toString()\n}\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 */\nexport function 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/**\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 */\nexport function toFixed (value, precision) {\n  return value.toFixed(precision)\n}\n\nfunction _toNumberOrDefault (value, defaultValue) {\n  if (isNumber(value)) {\n    return value\n  } else if (isBigNumber(value)) {\n    return value.toNumber()\n  } else {\n    return defaultValue\n  }\n}\n","import { isBigNumber, isString, typeOf } from './is.js'\nimport { format as formatNumber } from './number.js'\nimport { format as formatBigNumber } from './bignumber/formatter.js'\n\n/**\n * Check if a text ends with a certain string.\n * @param {string} text\n * @param {string} search\n */\nexport function endsWith (text, search) {\n  const start = text.length - search.length\n  const end = text.length\n  return (text.substring(start, end) === search)\n}\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 */\nexport function format (value, options) {\n  const result = _format(value, options)\n  if (options && typeof options === 'object' && 'truncate' in options &&\n      result.length > options.truncate) {\n    return result.substring(0, options.truncate - 3) + '...'\n  }\n  return result\n}\n\nfunction _format (value, options) {\n  if (typeof value === 'number') {\n    return formatNumber(value, options)\n  }\n\n  if (isBigNumber(value)) {\n    return formatBigNumber(value, options)\n  }\n\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  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 (isString(value)) {\n    return stringify(value)\n  }\n\n  if (typeof value === 'function') {\n    return value.syntax ? String(value.syntax) : 'function'\n  }\n\n  if (value && typeof 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      const entries = Object.keys(value).map(key => {\n        return stringify(key) + ': ' + format(value[key], options)\n      })\n\n      return '{' + entries.join(', ') + '}'\n    }\n  }\n\n  return String(value)\n}\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 */\nexport function stringify (value) {\n  const text = String(value)\n  let escaped = ''\n  let i = 0\n  while (i < text.length) {\n    const c = text.charAt(i)\n    escaped += (c in controlCharacters) ? controlCharacters[c] : c\n    i++\n  }\n\n  return '\"' + escaped + '\"'\n}\n\nconst controlCharacters = {\n  '\"': '\\\\\"',\n  '\\\\': '\\\\\\\\',\n  '\\b': '\\\\b',\n  '\\f': '\\\\f',\n  '\\n': '\\\\n',\n  '\\r': '\\\\r',\n  '\\t': '\\\\t'\n}\n\n/**\n * Escape special HTML characters\n * @param {*} value\n * @return {string}\n */\nexport function escape (value) {\n  let text = String(value)\n  text = text.replace(/&/g, '&amp;')\n    .replace(/\"/g, '&quot;')\n    .replace(/'/g, '&#39;')\n    .replace(/</g, '&lt;')\n    .replace(/>/g, '&gt;')\n\n  return text\n}\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 */\nfunction formatArray (array, options) {\n  if (Array.isArray(array)) {\n    let str = '['\n    const len = array.length\n    for (let i = 0; i < len; i++) {\n      if (i !== 0) {\n        str += ', '\n      }\n      str += formatArray(array[i], options)\n    }\n    str += ']'\n    return str\n  } else {\n    return format(array, options)\n  }\n}\n\n/**\n * Check whether a value looks like a Fraction (unsafe duck-type check)\n * @param {*} value\n * @return {boolean}\n */\nfunction looksLikeFraction (value) {\n  return (value &&\n      typeof value === 'object' &&\n      typeof value.s === 'number' &&\n      typeof value.n === 'number' &&\n      typeof value.d === 'number') || false\n}\n\n/**\n * Compare two strings\n * @param {string} x\n * @param {string} y\n * @returns {number}\n */\nexport function compareText (x, y) {\n  // we don't want to convert numbers to string, only accept string input\n  if (!isString(x)) {\n    throw new TypeError('Unexpected type of argument in function compareText ' +\n      '(expected: string or Array or Matrix, actual: ' + typeOf(x) + ', index: 0)')\n  }\n  if (!isString(y)) {\n    throw new TypeError('Unexpected type of argument in function compareText ' +\n      '(expected: string or Array or Matrix, actual: ' + typeOf(y) + ', index: 1)')\n  }\n\n  return (x === y)\n    ? 0\n    : (x > y ? 1 : -1)\n}\n","/**\n * Create a range error with the message:\n *     'Dimension mismatch (<actual size> != <expected size>)'\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 */\nexport function 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\n  this.message = 'Dimension mismatch (' +\n      (Array.isArray(actual) ? ('[' + actual.join(', ') + ']') : actual) +\n      ' ' + (this.relation || '!=') + ' ' +\n      (Array.isArray(expected) ? ('[' + expected.join(', ') + ']') : expected) +\n      ')'\n\n  this.stack = (new Error()).stack\n}\n\nDimensionError.prototype = new RangeError()\nDimensionError.prototype.constructor = RangeError\nDimensionError.prototype.name = 'DimensionError'\nDimensionError.prototype.isDimensionError = true\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 */\nexport function 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  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\n","import { isInteger } from './number.js'\nimport { isNumber, isBigNumber, isArray, isString } from './is.js'\nimport { format } from './string.js'\nimport { DimensionError } from '../error/DimensionError.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { deepStrictEqual } from './object.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 */\nexport function arraySize (x) {\n  const s = []\n\n  while (Array.isArray(x)) {\n    s.push(x.length)\n    x = x[0]\n  }\n\n  return s\n}\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 */\nfunction _validate (array, size, dim) {\n  let i\n  const len = array.length\n\n  if (len !== size[dim]) {\n    throw new DimensionError(len, size[dim])\n  }\n\n  if (dim < size.length - 1) {\n    // recursively validate each child array\n    const dimNext = dim + 1\n    for (i = 0; i < len; i++) {\n      const child = array[i]\n      if (!Array.isArray(child)) {\n        throw new DimensionError(size.length - 1, size.length, '<')\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(size.length + 1, size.length, '>')\n      }\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 */\nexport function validate (array, size) {\n  const isScalar = (size.length === 0)\n  if (isScalar) {\n    // scalar\n    if (Array.isArray(array)) {\n      throw new DimensionError(array.length, 0)\n    }\n  } else {\n    // array\n    _validate(array, size, 0)\n  }\n}\n\n/**\n * Validate whether the source of the index matches the size of the Array\n * @param {Array | Matrix} array    Array to be validated\n * @param {Index} index  Index with the source information to validate\n * @throws DimensionError\n */\nexport function validateIndexSourceSize (value, index) {\n  const valueSize = value.isMatrix ? value._size : arraySize(value)\n  const sourceSize = index._sourceSize\n  // checks if the source size is not null and matches the valueSize\n  sourceSize.forEach((sourceDim, i) => {\n    if (sourceDim !== null && sourceDim !== valueSize[i]) { throw new DimensionError(sourceDim, valueSize[i]) }\n  })\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 */\nexport function validateIndex (index, length) {\n  if (index !== undefined) {\n    if (!isNumber(index) || !isInteger(index)) {\n      throw new TypeError('Index must be an integer (value: ' + index + ')')\n    }\n    if (index < 0 || (typeof length === 'number' && index >= length)) {\n      throw new IndexError(index, length)\n    }\n  }\n}\n\n/**\n * Test if and index has empty values\n * @param {number} index    Zero-based index\n */\nexport function isEmptyIndex (index) {\n  for (let i = 0; i < index._dimensions.length; ++i) {\n    const dimension = index._dimensions[i]\n    if (dimension._data && isArray(dimension._data)) {\n      if (dimension._size[0] === 0) {\n        return true\n      }\n    } else if (dimension.isRange) {\n      if (dimension.start === dimension.end) {\n        return true\n      }\n    } else if (isString(dimension)) {\n      if (dimension.length === 0) {\n        return true\n      }\n    }\n  }\n  return false\n}\n\n/**\n * Resize a multi dimensional array. The resized array is returned.\n * @param {Array | number} array         Array to be resized\n * @param {number[]} 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 */\nexport function resize (array, size, defaultValue) {\n  // check the type of the arguments\n  if (!Array.isArray(size)) {\n    throw new TypeError('Array expected')\n  }\n  if (size.length === 0) {\n    throw new Error('Resizing to scalar is not supported')\n  }\n\n  // check whether size contains positive integers\n  size.forEach(function (value) {\n    if (!isNumber(value) || !isInteger(value) || value < 0) {\n      throw new TypeError('Invalid size, must contain positive integers ' +\n        '(size: ' + format(size) + ')')\n    }\n  })\n\n  // convert number to an array\n  if (isNumber(array) || isBigNumber(array)) {\n    array = [array]\n  }\n\n  // recursively resize the array\n  const _defaultValue = (defaultValue !== undefined) ? defaultValue : 0\n  _resize(array, size, 0, _defaultValue)\n\n  return array\n}\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 */\nfunction _resize (array, size, dim, defaultValue) {\n  let i\n  let elem\n  const oldLen = array.length\n  const newLen = size[dim]\n  const minLen = Math.min(oldLen, newLen)\n\n  // apply new length\n  array.length = newLen\n\n  if (dim < size.length - 1) {\n    // non-last dimension\n    const dimNext = dim + 1\n\n    // resize existing child arrays\n    for (i = 0; i < minLen; i++) {\n      // resize child array\n      elem = array[i]\n      if (!Array.isArray(elem)) {\n        elem = [elem] // add a dimension\n        array[i] = elem\n      }\n      _resize(elem, size, dimNext, defaultValue)\n    }\n\n    // create new child arrays\n    for (i = minLen; i < newLen; i++) {\n      // get child array\n      elem = []\n      array[i] = elem\n\n      // resize new child array\n      _resize(elem, size, dimNext, defaultValue)\n    }\n  } else {\n    // last dimension\n\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    }\n\n    // fill new elements with the default value\n    for (i = minLen; i < newLen; i++) {\n      array[i] = defaultValue\n    }\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 {number[]} 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 */\nexport function reshape (array, sizes) {\n  const flatArray = flatten(array)\n  const 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(0, currentLength, '!=')\n  }\n\n  sizes = processSizesWildcard(sizes, currentLength)\n  const newLength = product(sizes)\n  if (currentLength !== newLength) {\n    throw new DimensionError(\n      newLength,\n      currentLength,\n      '!='\n    )\n  }\n\n  try {\n    return _reshape(flatArray, sizes)\n  } catch (e) {\n    if (e instanceof DimensionError) {\n      throw new DimensionError(\n        newLength,\n        currentLength,\n        '!='\n      )\n    }\n    throw e\n  }\n}\n\n/**\n * Replaces the wildcard -1 in the sizes array.\n * @param {number[]} 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 {number[]}      The sizes array with wildcard replaced.\n */\nexport function processSizesWildcard (sizes, currentLength) {\n  const newLength = product(sizes)\n  const processedSizes = sizes.slice()\n  const WILDCARD = -1\n  const wildCardIndex = sizes.indexOf(WILDCARD)\n\n  const isMoreThanOneWildcard = sizes.indexOf(WILDCARD, wildCardIndex + 1) >= 0\n  if (isMoreThanOneWildcard) {\n    throw new Error('More than one wildcard in sizes')\n  }\n\n  const hasWildcard = wildCardIndex >= 0\n  const 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  return processedSizes\n}\n\n/**\n * Computes the product of all array elements.\n * @param {number[]} array Array of factors\n * @returns {number}            Product of all elements\n */\nfunction product (array) {\n  return array.reduce((prev, curr) => prev * curr, 1)\n}\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 {number[]} sizes  List of sizes for each dimension\n * @returns {Array}               Array whose data has been formatted to fit the\n *                                specified dimensions\n */\n\nfunction _reshape (array, sizes) {\n  // testing if there are enough elements for the requested shape\n  let tmpArray = array\n  let tmpArray2\n  // for each dimensions starting by the last one and ignoring the first one\n  for (let sizeIndex = sizes.length - 1; sizeIndex > 0; sizeIndex--) {\n    const size = sizes[sizeIndex]\n    tmpArray2 = []\n\n    // aggregate the elements of the current tmpArray in elements of the requested size\n    const length = tmpArray.length / size\n    for (let i = 0; i < length; i++) {\n      tmpArray2.push(tmpArray.slice(i * size, (i + 1) * size))\n    }\n    // set it as the new tmpArray for the next loop turn or for return\n    tmpArray = tmpArray2\n  }\n\n  return tmpArray\n}\n\n/**\n * Squeeze a multi dimensional array\n * @param {Array} array\n * @param {Array} [size]\n * @returns {Array} returns the array itself\n */\nexport function squeeze (array, size) {\n  const s = size || arraySize(array)\n\n  // squeeze outer dimensions\n  while (Array.isArray(array) && array.length === 1) {\n    array = array[0]\n    s.shift()\n  }\n\n  // find the first dimension to be squeezed\n  let dims = s.length\n  while (s[dims - 1] === 1) {\n    dims--\n  }\n\n  // squeeze inner dimensions\n  if (dims < s.length) {\n    array = _squeeze(array, dims, 0)\n    s.length = dims\n  }\n\n  return array\n}\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 */\nfunction _squeeze (array, dims, dim) {\n  let i, ii\n\n  if (dim < dims) {\n    const next = dim + 1\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/**\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 */\nexport function unsqueeze (array, dims, outer, size) {\n  const s = size || arraySize(array)\n\n  // unsqueeze outer dimensions\n  if (outer) {\n    for (let i = 0; i < outer; i++) {\n      array = [array]\n      s.unshift(1)\n    }\n  }\n\n  // unsqueeze inner dimensions\n  array = _unsqueeze(array, dims, 0)\n  while (s.length < dims) {\n    s.push(1)\n  }\n\n  return array\n}\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 */\nfunction _unsqueeze (array, dims, dim) {\n  let i, ii\n\n  if (Array.isArray(array)) {\n    const next = dim + 1\n    for (i = 0, ii = array.length; i < ii; i++) {\n      array[i] = _unsqueeze(array[i], dims, next)\n    }\n  } else {\n    for (let 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 */\nexport function flatten (array) {\n  if (!Array.isArray(array)) {\n    // if not an array, return as is\n    return array\n  }\n  const flat = []\n\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\n  return flat\n}\n\n/**\n * A safe map\n * @param {Array} array\n * @param {function} callback\n */\nexport function map (array, callback) {\n  return Array.prototype.map.call(array, callback)\n}\n\n/**\n * A safe forEach\n * @param {Array} array\n * @param {function} callback\n */\nexport function forEach (array, callback) {\n  Array.prototype.forEach.call(array, callback)\n}\n\n/**\n * A safe filter\n * @param {Array} array\n * @param {function} callback\n */\nexport function 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/**\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 */\nexport function 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, (entry) => regexp.test(entry))\n}\n\n/**\n * A safe join\n * @param {Array} array\n * @param {string} separator\n */\nexport function join (array, separator) {\n  return Array.prototype.join.call(array, separator)\n}\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 */\nexport function 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  const b = []\n  let count = 0\n  b[0] = { value: a[0], identifier: 0 }\n  for (let i = 1; i < a.length; i++) {\n    if (a[i] === a[i - 1]) {\n      count++\n    } else {\n      count = 0\n    }\n    b.push({ value: a[i], identifier: count })\n  }\n  return b\n}\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 */\nexport function 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  const b = []\n  for (let i = 0; i < a.length; i++) {\n    b.push(a[i].value)\n  }\n  return b\n}\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 */\nexport function getArrayDataType (array, typeOf) {\n  let type // to hold type info\n  let length = 0 // to hold length value to ensure it has consistent sizes\n\n  for (let i = 0; i < array.length; i++) {\n    const item = array[i]\n    const isArray = Array.isArray(item)\n\n    // Saving the target matrix row size\n    if (i === 0 && isArray) {\n      length = item.length\n    }\n\n    // If the current item is an array but the length does not equal the targetVectorSize\n    if (isArray && item.length !== length) {\n      return undefined\n    }\n\n    const itemType = isArray\n      ? 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 {\n      // we're good, everything has the same type so far\n    }\n  }\n\n  return type\n}\n\n/**\n * Return the last item from an array\n * @param {array}\n * @returns {*}\n */\nexport function last (array) {\n  return array[array.length - 1]\n}\n\n/**\n * Get all but the last element of array.\n * @param {array}\n * @returns {*}\n */\nexport function initial (array) {\n  return array.slice(0, array.length - 1)\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 */\nfunction concatRecursive (a, b, concatDim, dim) {\n  if (dim < concatDim) {\n    // recurse into next dimension\n    if (a.length !== b.length) {\n      throw new DimensionError(a.length, b.length)\n    }\n\n    const c = []\n    for (let i = 0; i < a.length; i++) {\n      c[i] = concatRecursive(a[i], b[i], concatDim, dim + 1)\n    }\n    return c\n  } else {\n    // concatenate this dimension\n    return a.concat(b)\n  }\n}\n\n/**\n * Concatenates many arrays in the specified direction\n * @param {...Array} arrays All the arrays to concatenate\n * @param {number} concatDim The dimension on which to concatenate (zero-based)\n * @returns\n*/\nexport function concat () {\n  const arrays = Array.prototype.slice.call(arguments, 0, -1)\n  const concatDim = Array.prototype.slice.call(arguments, -1)\n\n  if (arrays.length === 1) {\n    return arrays[0]\n  }\n  if (arrays.length > 1) {\n    return arrays.slice(1).reduce(function (A, B) { return concatRecursive(A, B, concatDim, 0) }, arrays[0])\n  } else {\n    throw new Error('Wrong number of arguments in function concat')\n  }\n}\n\n/**\n * Receives two or more sizes and get's the broadcasted size for both.\n * @param  {...number[]} sizes Sizes to broadcast together\n * @returns\n */\nexport function broadcastSizes (...sizes) {\n  const dimensions = sizes.map((s) => s.length)\n  const N = Math.max(...dimensions)\n  const sizeMax = new Array(N).fill(null)\n  // check for every size\n  for (let i = 0; i < sizes.length; i++) {\n    const size = sizes[i]\n    const dim = dimensions[i]\n    for (let j = 0; j < dim; j++) {\n      const n = N - dim + j\n      if (size[j] > sizeMax[n]) {\n        sizeMax[n] = size[j]\n      }\n    }\n  }\n  for (let i = 0; i < sizes.length; i++) {\n    checkBroadcastingRules(sizes[i], sizeMax)\n  }\n  return sizeMax\n}\n\n/**\n * Checks if it's possible to broadcast a size to another size\n * @param {number[]} size The size of the array to check\n * @param {number[]} toSize The size of the array to validate if it can be broadcasted to\n */\nexport function checkBroadcastingRules (size, toSize) {\n  const N = toSize.length\n  const dim = size.length\n  for (let j = 0; j < dim; j++) {\n    const n = N - dim + j\n    if ((size[j] < toSize[n] && size[j] > 1) || (size[j] > toSize[n])) {\n      throw new Error(\n        `shape missmatch: missmatch is found in arg with shape (${size}) not possible to broadcast dimension ${dim} with size ${size[j]} to size ${toSize[n]}`\n      )\n    }\n  }\n}\n\n/**\n * Broadcasts a single array to a certain size\n * @param {array} array Array to be broadcasted\n * @param {number[]} toSize Size to broadcast the array\n * @returns The broadcasted array\n */\nexport function broadcastTo (array, toSize) {\n  let Asize = arraySize(array)\n  if (deepStrictEqual(Asize, toSize)) {\n    return array\n  }\n  checkBroadcastingRules(Asize, toSize)\n  const broadcastedSize = broadcastSizes(Asize, toSize)\n  const N = broadcastedSize.length\n  const paddedSize = [...Array(N - Asize.length).fill(1), ...Asize]\n\n  let A = clone(array)\n  // reshape A if needed to make it ready for concat\n  if (Asize.length < N) {\n    A = reshape(A, paddedSize)\n    Asize = arraySize(A)\n  }\n\n  // stretches the array on each dimension to make it the same size as index\n  for (let dim = 0; dim < N; dim++) {\n    if (Asize[dim] < broadcastedSize[dim]) {\n      A = stretch(A, broadcastedSize[dim], dim)\n      Asize = arraySize(A)\n    }\n  }\n  return A\n}\n\n/**\n * Broadcasts arrays and returns the broadcasted arrays in an array\n * @param  {...Array | any} arrays\n * @returns\n */\nexport function broadcastArrays (...arrays) {\n  if (arrays.length === 0) {\n    throw new Error('Insuficient number of argumnets in function broadcastArrays')\n  }\n  if (arrays.length === 1) {\n    return arrays[0]\n  }\n  const sizes = arrays.map(function (array) { return arraySize(array) })\n  const broadcastedSize = broadcastSizes(...sizes)\n  const broadcastedArrays = []\n  arrays.forEach(function (array) { broadcastedArrays.push(broadcastTo(array, broadcastedSize)) })\n  return broadcastedArrays\n}\n\n/**\n * stretches a matrix up to a certain size in a certain dimension\n * @param {Array} arrayToStretch\n * @param {number[]} sizeToStretch\n * @param {number} dimToStretch\n * @returns\n */\nexport function stretch (arrayToStretch, sizeToStretch, dimToStretch) {\n  return concat(...Array(sizeToStretch).fill(arrayToStretch), dimToStretch)\n}\n\n/**\n * Deep clones a multidimensional array\n * @param {Array} array\n * @returns cloned array\n */\nexport function clone (array) {\n  return Object.assign([], array)\n}\n","// (c) 2018, Mariusz Nowak\n// SPDX-License-Identifier: ISC\n// Derived from https://github.com/medikoo/lru-queue\nexport function lruQueue (limit) {\n  let size = 0\n  let base = 1\n  let queue = Object.create(null)\n  let map = Object.create(null)\n  let index = 0\n  const del = function (id) {\n    const oldIndex = map[id]\n    if (!oldIndex) return\n    delete queue[oldIndex]\n    delete map[id]\n    --size\n    if (base !== oldIndex) return\n    if (!size) {\n      index = 0\n      base = 1\n      return\n    }\n    while (!Object.prototype.hasOwnProperty.call(queue, ++base)) { /* empty */ }\n  }\n  limit = Math.abs(limit)\n  return {\n    hit: function (id) {\n      const oldIndex = map[id]; const nuIndex = ++index\n      queue[nuIndex] = id\n      map[id] = nuIndex\n      if (!oldIndex) {\n        ++size\n        if (size <= limit) return undefined\n        id = queue[base]\n        del(id)\n        return id\n      }\n      delete queue[oldIndex]\n      if (base !== oldIndex) return undefined\n      while (!Object.prototype.hasOwnProperty.call(queue, ++base)) { /* empty */ }\n      return undefined\n    },\n    delete: del,\n    clear: function () {\n      size = index = 0\n      base = 1\n      queue = Object.create(null)\n      map = Object.create(null)\n    }\n  }\n}\n","// function utils\n\nimport { lruQueue } from './lruQueue.js'\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 */\nexport function memoize (fn, { hasher, limit } = {}) {\n  limit = limit == null ? Number.POSITIVE_INFINITY : limit\n  hasher = hasher == null ? JSON.stringify : hasher\n\n  return function memoize () {\n    if (typeof memoize.cache !== 'object') {\n      memoize.cache = {\n        values: new Map(),\n        lru: lruQueue(limit || Number.POSITIVE_INFINITY)\n      }\n    }\n    const args = []\n    for (let i = 0; i < arguments.length; i++) {\n      args[i] = arguments[i]\n    }\n    const 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    const newVal = fn.apply(fn, args)\n    memoize.cache.values.set(hash, newVal)\n    memoize.cache.values.delete(memoize.cache.lru.hit(hash))\n\n    return newVal\n  }\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 */\nexport function memoizeCompare (fn, isEqual) {\n  const memoize = function memoize () {\n    const args = []\n    for (let i = 0; i < arguments.length; i++) {\n      args[i] = arguments[i]\n    }\n\n    for (let c = 0; c < memoize.cache.length; c++) {\n      const 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    const res = fn.apply(fn, args)\n    memoize.cache.unshift({ args, res })\n\n    return res\n  }\n\n  memoize.cache = []\n\n  return memoize\n}\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 */\nexport function maxArgumentCount (fn) {\n  return Object.keys(fn.signatures || {})\n    .reduce(function (args, signature) {\n      const count = (signature.match(/,/g) || []).length + 1\n      return Math.max(args, count)\n    }, -1)\n}\n","import { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'\nimport { arraySize, getArrayDataType, processSizesWildcard, reshape, resize, unsqueeze, validate, validateIndex, broadcastTo } from '../../utils/array.js'\nimport { format } from '../../utils/string.js'\nimport { isInteger } from '../../utils/number.js'\nimport { clone, deepStrictEqual } from '../../utils/object.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\nimport { maxArgumentCount } from '../../utils/function.js'\n\nconst name = 'DenseMatrix'\nconst dependencies = [\n  'Matrix'\n]\n\nexport const createDenseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ Matrix }) => {\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)) { throw new SyntaxError('Constructor must be called with the new operator') }\n    if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n    if (isMatrix(data)) {\n      // check data is a DenseMatrix\n      if (data.type === 'DenseMatrix') {\n        // clone data & size\n        this._data = clone(data._data)\n        this._size = 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 && isArray(data.data) && isArray(data.size)) {\n      // initialize fields from JSON representation\n      this._data = data.data\n      this._size = data.size\n      // verify the dimensions of the array\n      validate(this._data, this._size)\n      this._datatype = datatype || data.datatype\n    } else if (isArray(data)) {\n      // replace nested Matrices with Arrays\n      this._data = preprocess(data)\n      // get the dimensions of the array\n      this._size = arraySize(this._data)\n      // verify the dimensions of the array, TODO: compute size while processing array\n      validate(this._data, this._size)\n      // data type unknown\n      this._datatype = datatype\n    } else if (data) {\n      // unsupported type\n      throw new TypeError('Unsupported type of data (' + 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  /**\n   * Create a new DenseMatrix\n   */\n  DenseMatrix.prototype.createDenseMatrix = function (data, datatype) {\n    return new DenseMatrix(data, datatype)\n  }\n\n  /**\n   * Attach type information\n   */\n  Object.defineProperty(DenseMatrix, 'name', { value: 'DenseMatrix' })\n  DenseMatrix.prototype.constructor = DenseMatrix\n  DenseMatrix.prototype.type = 'DenseMatrix'\n  DenseMatrix.prototype.isDenseMatrix = true\n\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  DenseMatrix.prototype.getDataType = function () {\n    return getArrayDataType(this._data, typeOf)\n  }\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  DenseMatrix.prototype.storage = function () {\n    return 'dense'\n  }\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  DenseMatrix.prototype.datatype = function () {\n    return this._datatype\n  }\n\n  /**\n   * Create a new DenseMatrix\n   * @memberof DenseMatrix\n   * @param {Array} data\n   * @param {string} [datatype]\n   */\n  DenseMatrix.prototype.create = function (data, datatype) {\n    return new DenseMatrix(data, datatype)\n  }\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  DenseMatrix.prototype.subset = function (index, replacement, defaultValue) {\n    switch (arguments.length) {\n      case 1:\n        return _get(this, index)\n\n      // intentional fall through\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  /**\n   * Get a single element from the matrix.\n   * @memberof DenseMatrix\n   * @param {number[]} index   Zero-based index\n   * @return {*} value\n   */\n  DenseMatrix.prototype.get = function (index) {\n    if (!isArray(index)) { throw new TypeError('Array expected') }\n    if (index.length !== this._size.length) { throw new DimensionError(index.length, this._size.length) }\n\n    // check index\n    for (let x = 0; x < index.length; x++) { validateIndex(index[x], this._size[x]) }\n\n    let data = this._data\n    for (let i = 0, ii = index.length; i < ii; i++) {\n      const indexI = index[i]\n      validateIndex(indexI, data.length)\n      data = data[indexI]\n    }\n\n    return data\n  }\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  DenseMatrix.prototype.set = function (index, value, defaultValue) {\n    if (!isArray(index)) { throw new TypeError('Array expected') }\n    if (index.length < this._size.length) { throw new DimensionError(index.length, this._size.length, '<') }\n\n    let i, ii, indexI\n\n    // enlarge matrix when needed\n    const size = index.map(function (i) {\n      return i + 1\n    })\n    _fit(this, size, defaultValue)\n\n    // traverse over the dimensions\n    let data = this._data\n    for (i = 0, ii = index.length - 1; i < ii; i++) {\n      indexI = index[i]\n      validateIndex(indexI, data.length)\n      data = data[indexI]\n    }\n\n    // set new value\n    indexI = index[index.length - 1]\n    validateIndex(indexI, data.length)\n    data[indexI] = value\n\n    return this\n  }\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  function _get (matrix, index) {\n    if (!isIndex(index)) {\n      throw new TypeError('Invalid index')\n    }\n\n    const isScalar = index.isScalar()\n    if (isScalar) {\n      // return a scalar\n      return matrix.get(index.min())\n    } else {\n      // validate dimensions\n      const size = index.size()\n      if (size.length !== matrix._size.length) {\n        throw new DimensionError(size.length, matrix._size.length)\n      }\n\n      // validate if any of the ranges in the index is out of range\n      const min = index.min()\n      const max = index.max()\n      for (let i = 0, ii = matrix._size.length; i < ii; i++) {\n        validateIndex(min[i], matrix._size[i])\n        validateIndex(max[i], matrix._size[i])\n      }\n\n      // retrieve submatrix\n      // TODO: more efficient when creating an empty matrix and setting _data and _size manually\n      return new DenseMatrix(_getSubmatrix(matrix._data, index, size.length, 0), matrix._datatype)\n    }\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  function _getSubmatrix (data, index, dims, dim) {\n    const last = (dim === dims - 1)\n    const range = index.dimension(dim)\n\n    if (last) {\n      return range.map(function (i) {\n        validateIndex(i, data.length)\n        return data[i]\n      }).valueOf()\n    } else {\n      return range.map(function (i) {\n        validateIndex(i, data.length)\n        const child = data[i]\n        return _getSubmatrix(child, index, dims, dim + 1)\n      }).valueOf()\n    }\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  function _set (matrix, index, submatrix, defaultValue) {\n    if (!index || index.isIndex !== true) {\n      throw new TypeError('Invalid index')\n    }\n\n    // get index size and check whether the index contains a single value\n    const iSize = index.size()\n    const isScalar = index.isScalar()\n\n    // calculate the size of the submatrix, and convert it into an Array if needed\n    let sSize\n    if (isMatrix(submatrix)) {\n      sSize = submatrix.size()\n      submatrix = submatrix.valueOf()\n    } else {\n      sSize = arraySize(submatrix)\n    }\n\n    if (isScalar) {\n      // set a scalar\n\n      // check whether submatrix is a scalar\n      if (sSize.length !== 0) {\n        throw new TypeError('Scalar expected')\n      }\n      matrix.set(index.min(), submatrix, defaultValue)\n    } else {\n      // set a submatrix\n\n      // broadcast submatrix\n      if (!deepStrictEqual(sSize, iSize)) {\n        try {\n          if (sSize.length === 0) {\n            submatrix = broadcastTo([submatrix], iSize)\n          } else {\n            submatrix = broadcastTo(submatrix, iSize)\n          }\n          sSize = arraySize(submatrix)\n        } catch {\n        }\n      }\n\n      // validate dimensions\n      if (iSize.length < matrix._size.length) {\n        throw new DimensionError(iSize.length, matrix._size.length, '<')\n      }\n\n      if (sSize.length < iSize.length) {\n        // calculate number of missing outer dimensions\n        let i = 0\n        let outer = 0\n        while (iSize[i] === 1 && sSize[i] === 1) {\n          i++\n        }\n        while (iSize[i] === 1) {\n          outer++\n          i++\n        }\n\n        // unsqueeze both outer and inner dimensions\n        submatrix = unsqueeze(submatrix, iSize.length, outer, sSize)\n      }\n\n      // check whether the size of the submatrix matches the index size\n      if (!deepStrictEqual(iSize, sSize)) {\n        throw new DimensionError(iSize, sSize, '>')\n      }\n\n      // enlarge matrix when needed\n      const size = index.max().map(function (i) {\n        return i + 1\n      })\n      _fit(matrix, size, defaultValue)\n\n      // insert the sub matrix\n      const dims = iSize.length\n      const dim = 0\n      _setSubmatrix(matrix._data, index, submatrix, dims, dim)\n    }\n\n    return matrix\n  }\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  function _setSubmatrix (data, index, submatrix, dims, dim) {\n    const last = (dim === dims - 1)\n    const range = index.dimension(dim)\n\n    if (last) {\n      range.forEach(function (dataIndex, subIndex) {\n        validateIndex(dataIndex)\n        data[dataIndex] = submatrix[subIndex[0]]\n      })\n    } else {\n      range.forEach(function (dataIndex, subIndex) {\n        validateIndex(dataIndex)\n        _setSubmatrix(data[dataIndex], index, submatrix[subIndex[0]], dims, dim + 1)\n      })\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  DenseMatrix.prototype.resize = function (size, defaultValue, copy) {\n    // validate arguments\n    if (!isCollection(size)) {\n      throw new TypeError('Array or Matrix expected')\n    }\n\n    // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n    const sizeArray = size.valueOf().map(value => {\n      return Array.isArray(value) && value.length === 1\n        ? value[0]\n        : value\n    })\n\n    // matrix to resize\n    const m = copy ? this.clone() : this\n    // resize matrix\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      let v = matrix._data\n      // go deep\n      while (isArray(v)) {\n        v = v[0]\n      }\n      return v\n    }\n    // resize matrix\n    matrix._size = size.slice(0) // copy the array\n    matrix._data = resize(matrix._data, matrix._size, defaultValue)\n    // return matrix\n    return matrix\n  }\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  DenseMatrix.prototype.reshape = function (size, copy) {\n    const m = copy ? this.clone() : this\n\n    m._data = reshape(m._data, size)\n    const currentLength = m._size.reduce((length, size) => length * size)\n    m._size = processSizesWildcard(size, currentLength)\n    return m\n  }\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  function _fit (matrix, size, defaultValue) {\n    const // copy the array\n      newSize = matrix._size.slice(0)\n\n    let changed = false\n\n    // add dimensions when needed\n    while (newSize.length < size.length) {\n      newSize.push(0)\n      changed = true\n    }\n\n    // enlarge size when needed\n    for (let 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  /**\n   * Create a clone of the matrix\n   * @memberof DenseMatrix\n   * @return {DenseMatrix} clone\n   */\n  DenseMatrix.prototype.clone = function () {\n    const m = new DenseMatrix({\n      data: clone(this._data),\n      size: clone(this._size),\n      datatype: this._datatype\n    })\n    return m\n  }\n\n  /**\n   * Retrieve the size of the matrix.\n   * @memberof DenseMatrix\n   * @returns {number[]} size\n   */\n  DenseMatrix.prototype.size = function () {\n    return this._size.slice(0) // return a clone of _size\n  }\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  DenseMatrix.prototype.map = function (callback) {\n    // matrix instance\n    const me = this\n    const args = maxArgumentCount(callback)\n    const recurse = function (value, index) {\n      if (isArray(value)) {\n        return value.map(function (child, i) {\n          return recurse(child, index.concat(i))\n        })\n      } else {\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 { // 3 or -1\n          return callback(value, index, me)\n        }\n      }\n    }\n\n    // determine the new datatype when the original matrix has datatype defined\n    // TODO: should be done in matrix constructor instead\n    const data = recurse(this._data, [])\n    const datatype = this._datatype !== undefined\n      ? getArrayDataType(data, typeOf)\n      : undefined\n    return new DenseMatrix(data, datatype)\n  }\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  DenseMatrix.prototype.forEach = function (callback) {\n    // matrix instance\n    const me = this\n    const recurse = function (value, index) {\n      if (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    recurse(this._data, [])\n  }\n\n  /**\n   * Iterate over the matrix elements\n   * @return {Iterable<{ value, index: number[] }>}\n   */\n  DenseMatrix.prototype[Symbol.iterator] = function * () {\n    const recurse = function * (value, index) {\n      if (isArray(value)) {\n        for (let i = 0; i < value.length; i++) {\n          yield * recurse(value[i], index.concat(i))\n        }\n      } else {\n        yield ({ value, index })\n      }\n    }\n    yield * recurse(this._data, [])\n  }\n\n  /**\n   * Returns an array containing the rows of a 2D matrix\n   * @returns {Array<Matrix>}\n   */\n  DenseMatrix.prototype.rows = function () {\n    const result = []\n\n    const s = this.size()\n    if (s.length !== 2) {\n      throw new TypeError('Rows can only be returned for a 2D matrix.')\n    }\n\n    const data = this._data\n    for (const row of data) {\n      result.push(new DenseMatrix([row], this._datatype))\n    }\n\n    return result\n  }\n\n  /**\n   * Returns an array containing the columns of a 2D matrix\n   * @returns {Array<Matrix>}\n   */\n  DenseMatrix.prototype.columns = function () {\n    const result = []\n\n    const s = this.size()\n    if (s.length !== 2) {\n      throw new TypeError('Rows can only be returned for a 2D matrix.')\n    }\n\n    const data = this._data\n    for (let i = 0; i < s[1]; i++) {\n      const col = data.map(row => [row[i]])\n      result.push(new DenseMatrix(col, this._datatype))\n    }\n\n    return result\n  }\n\n  /**\n   * Create an Array with a copy of the data of the DenseMatrix\n   * @memberof DenseMatrix\n   * @returns {Array} array\n   */\n  DenseMatrix.prototype.toArray = function () {\n    return clone(this._data)\n  }\n\n  /**\n   * Get the primitive value of the DenseMatrix: a multidimensional array\n   * @memberof DenseMatrix\n   * @returns {Array} array\n   */\n  DenseMatrix.prototype.valueOf = function () {\n    return this._data\n  }\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  DenseMatrix.prototype.format = function (options) {\n    return format(this._data, options)\n  }\n\n  /**\n   * Get a string representation of the matrix\n   * @memberof DenseMatrix\n   * @returns {string} str\n   */\n  DenseMatrix.prototype.toString = function () {\n    return format(this._data)\n  }\n\n  /**\n   * Get a JSON representation of the matrix\n   * @memberof DenseMatrix\n   * @returns {Object}\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  /**\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  DenseMatrix.prototype.diagonal = function (k) {\n    // validate k if any\n    if (k) {\n      // convert BigNumber to a number\n      if (isBigNumber(k)) { k = k.toNumber() }\n      // is must be an integer\n      if (!isNumber(k) || !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    const kSuper = k > 0 ? k : 0\n    const kSub = k < 0 ? -k : 0\n\n    // rows & columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n\n    // number diagonal values\n    const n = Math.min(rows - kSub, columns - kSuper)\n\n    // x is a matrix get diagonal from matrix\n    const data = []\n\n    // loop rows\n    for (let i = 0; i < n; i++) {\n      data[i] = this._data[i + kSub][i + kSuper]\n    }\n\n    // create DenseMatrix\n    return new DenseMatrix({\n      data,\n      size: [n],\n      datatype: this._datatype\n    })\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  DenseMatrix.diagonal = function (size, value, k, defaultValue) {\n    if (!isArray(size)) { throw new TypeError('Array expected, size parameter') }\n    if (size.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n    // map size & validate\n    size = size.map(function (s) {\n      // check it is a big number\n      if (isBigNumber(s)) {\n        // convert it\n        s = s.toNumber()\n      }\n      // validate arguments\n      if (!isNumber(s) || !isInteger(s) || s < 1) {\n        throw new Error('Size values must be positive integers')\n      }\n      return s\n    })\n\n    // validate k if any\n    if (k) {\n      // convert BigNumber to a number\n      if (isBigNumber(k)) { k = k.toNumber() }\n      // is must be an integer\n      if (!isNumber(k) || !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    const kSuper = k > 0 ? k : 0\n    const kSub = k < 0 ? -k : 0\n\n    // rows and columns\n    const rows = size[0]\n    const columns = size[1]\n\n    // number of non-zero items\n    const n = Math.min(rows - kSub, columns - kSuper)\n\n    // value extraction function\n    let _value\n\n    // check value\n    if (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      }\n      // define function\n      _value = function (i) {\n        // return value @ i\n        return value[i]\n      }\n    } else if (isMatrix(value)) {\n      // matrix size\n      const ms = value.size()\n      // validate matrix\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      }\n      // define function\n      _value = function (i) {\n        // return value @ i\n        return value.get([i])\n      }\n    } else {\n      // define function\n      _value = function () {\n        // return value\n        return value\n      }\n    }\n\n    // discover default value if needed\n    if (!defaultValue) {\n      // check first value in array\n      defaultValue = isBigNumber(_value(0))\n        ? _value(0).mul(0) // trick to create a BigNumber with value zero\n        : 0\n    }\n\n    // empty array\n    let data = []\n\n    // check we need to resize array\n    if (size.length > 0) {\n      // resize array\n      data = resize(data, size, defaultValue)\n      // fill diagonal\n      for (let d = 0; d < n; d++) {\n        data[d + kSub][d + kSuper] = _value(d)\n      }\n    }\n\n    // create DenseMatrix\n    return new DenseMatrix({\n      data,\n      size: [rows, columns]\n    })\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  DenseMatrix.fromJSON = function (json) {\n    return new DenseMatrix(json)\n  }\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  DenseMatrix.prototype.swapRows = function (i, j) {\n    // check index\n    if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) {\n      throw new Error('Row index must be positive integers')\n    }\n    // check dimensions\n    if (this._size.length !== 2) {\n      throw new Error('Only two dimensional matrix is supported')\n    }\n    // validate index\n    validateIndex(i, this._size[0])\n    validateIndex(j, this._size[0])\n\n    // swap rows\n    DenseMatrix._swapRows(i, j, this._data)\n    // return current instance\n    return this\n  }\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  DenseMatrix._swapRows = function (i, j, data) {\n    // swap values i <-> j\n    const vi = data[i]\n    data[i] = data[j]\n    data[j] = vi\n  }\n\n  /**\n   * Preprocess data, which can be an Array or DenseMatrix with nested Arrays and\n   * Matrices. Clones all (nested) Arrays, and replaces all nested Matrices with Arrays\n   * @memberof DenseMatrix\n   * @param {Array | Matrix} data\n   * @return {Array} data\n   */\n  function preprocess (data) {\n    if (isMatrix(data)) {\n      return preprocess(data.valueOf())\n    }\n\n    if (isArray(data)) {\n      return data.map(preprocess)\n    }\n\n    return data\n  }\n\n  return DenseMatrix\n}, { isClass: true })\n","import { clone as objectClone } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'clone'\nconst dependencies = ['typed']\n\nexport const createClone = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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: objectClone\n  })\n})\n","/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\nexport function _switch (mat) {\n  const I = mat.length\n  const J = mat[0].length\n  let i, j\n  const ret = []\n  for (j = 0; j < J; j++) {\n    const tmp = []\n    for (i = 0; i < I; i++) {\n      tmp.push(mat[i][j])\n    }\n    ret.push(tmp)\n  }\n  return ret\n}\n","import { isCollection, isMatrix } from './is.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { arraySize } from './array.js'\nimport { _switch } from './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 */\nexport function containsCollections (array) {\n  for (let i = 0; i < array.length; i++) {\n    if (isCollection(array[i])) {\n      return true\n    }\n  }\n  return false\n}\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 */\nexport function deepForEach (array, callback) {\n  if (isMatrix(array)) {\n    array = array.valueOf()\n  }\n\n  for (let i = 0, ii = array.length; i < ii; i++) {\n    const value = array[i]\n\n    if (Array.isArray(value)) {\n      deepForEach(value, callback)\n    } else {\n      callback(value)\n    }\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 */\nexport function 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/**\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 */\nexport function reduce (mat, dim, callback) {\n  const size = Array.isArray(mat) ? arraySize(mat) : mat.size()\n  if (dim < 0 || (dim >= size.length)) {\n    // TODO: would be more clear when throwing a DimensionError here\n    throw new IndexError(dim, size.length)\n  }\n\n  if (isMatrix(mat)) {\n    return mat.create(_reduce(mat.valueOf(), dim, callback))\n  } else {\n    return _reduce(mat, dim, callback)\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 */\nfunction _reduce (mat, dim, callback) {\n  let i, ret, val, tran\n\n  if (dim <= 0) {\n    if (!Array.isArray(mat[0])) {\n      val = mat[0]\n      for (i = 1; i < mat.length; i++) {\n        val = callback(val, mat[i])\n      }\n      return val\n    } else {\n      tran = _switch(mat)\n      ret = []\n      for (i = 0; i < tran.length; i++) {\n        ret[i] = _reduce(tran[i], dim - 1, callback)\n      }\n      return ret\n    }\n  } else {\n    ret = []\n    for (i = 0; i < mat.length; i++) {\n      ret[i] = _reduce(mat[i], dim - 1, callback)\n    }\n    return ret\n  }\n}\n\n// TODO: document function scatter\nexport function scatter (a, j, w, x, u, mark, cindex, f, inverse, update, value) {\n  // a arrays\n  const avalues = a._values\n  const aindex = a._index\n  const aptr = a._ptr\n\n  // vars\n  let k, k0, k1, i\n\n  // check we need to process values (pattern matrix)\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]\n      // check value exists in current j\n      if (w[i] !== mark) {\n        // i is new entry in j\n        w[i] = mark\n        // add i to pattern of C\n        cindex.push(i)\n        // x(i) = A, check we need to call function this time\n        if (update) {\n          // copy value to workspace calling callback function\n          x[i] = inverse ? f(avalues[k], value) : f(value, avalues[k])\n          // function was called on current row\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])\n        // function was called on current row\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]\n      // check value exists in current j\n      if (w[i] !== mark) {\n        // i is new entry in j\n        w[i] = mark\n        // add i to pattern of C\n        cindex.push(i)\n      } else {\n        // indicate function was called on current row\n        u[i] = mark\n      }\n    }\n  }\n}\n","import { deepMap } from '../../utils/collection.js'\nimport { isInteger as isIntegerNumber } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isInteger'\nconst dependencies = ['typed']\n\nexport const createIsInteger = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | 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: isIntegerNumber, // TODO: what to do with isInteger(add(0.1, 0.2))  ?\n\n    BigNumber: function (x) {\n      return x.isInt()\n    },\n\n    bigint: function (x) {\n      return true\n    },\n\n    Fraction: function (x) {\n      return x.d === 1 && isFinite(x.n)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { isInteger } from '../../utils/number.js'\n\nconst n1 = 'number'\n\nexport function isIntegerNumber (x) {\n  return isInteger(x)\n}\nisIntegerNumber.signature = n1\n\nexport function isNegativeNumber (x) {\n  return x < 0\n}\nisNegativeNumber.signature = n1\n\nexport function isPositiveNumber (x) {\n  return x > 0\n}\nisPositiveNumber.signature = n1\n\nexport function isZeroNumber (x) {\n  return x === 0\n}\nisZeroNumber.signature = n1\n\nexport function isNaNNumber (x) {\n  return Number.isNaN(x)\n}\nisNaNNumber.signature = n1\n","/**\n * Compares two BigNumbers.\n * @param {BigNumber} a - First value to compare\n * @param {BigNumber} b - Second value to compare\n * @param {number} [relTol=1e-09] - The relative tolerance, indicating the maximum allowed difference relative to the larger absolute value. Must be greater than 0.\n * @param {number} [absTol=0] - The minimum absolute tolerance, useful for comparisons near zero. Must be at least 0.\n * @returns {boolean} whether the two numbers are nearly equal\n * @throws {Error} If `relTol` is less than or equal to 0.\n * @throws {Error} If `absTol` is less than 0.\n *\n * @example\n * nearlyEqual(1.000000001, 1.0, 1e-9);            // true\n * nearlyEqual(1.000000002, 1.0, 0);            // false\n * nearlyEqual(1.0, 1.009, undefined, 0.02);       // true\n * nearlyEqual(0.000000001, 0.0, undefined, 1e-8); // true\n */\nexport function nearlyEqual (a, b, relTol = 1e-9, absTol = 0) {\n  if (relTol <= 0) {\n    throw new Error('Relative tolerance must be greater than 0')\n  }\n\n  if (absTol < 0) {\n    throw new Error('Absolute tolerance must be at least 0')\n  }\n  // NaN\n  if (a.isNaN() || b.isNaN()) {\n    return false\n  }\n\n  if (!a.isFinite() || !b.isFinite()) {\n    return a.eq(b)\n  }\n  // use \"==\" operator, handles infinities\n  if (a.eq(b)) {\n    return true\n  }\n  // abs(a-b) <= max(relTol * max(abs(a), abs(b)), absTol)\n  return a.minus(b).abs().lte(a.constructor.max(a.constructor.max(a.abs(), b.abs()).mul(relTol), absTol))\n}\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNegativeNumber } from '../../plain/number/index.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\n\nconst name = 'isNegative'\nconst dependencies = ['typed', 'config']\n\nexport const createIsNegative = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\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 | bigint | 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: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isNegativeNumber(x),\n\n    BigNumber: x => bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol)\n      ? false\n      : x.isNeg() && !x.isZero() && !x.isNaN(),\n\n    bigint: x => x < 0n,\n\n    Fraction: x => x.s < 0, // It's enough to decide on the sign\n\n    Unit: typed.referToSelf(self =>\n      x => typed.find(self, x.valueType())(x.value)),\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isNumeric'\nconst dependencies = ['typed']\n\nexport const createIsNumeric = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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('42'))  // returns true\n   *    math.isNumeric(math.bigint('42'))     // 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 | bigint | Fraction | boolean': () => true,\n    'Complex | Unit | string | null | undefined | Node': () => false,\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'hasNumericValue'\nconst dependencies = ['typed', 'isNumeric']\n\nexport const createHasNumericValue = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNumeric }) => {\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.bigint('42'))     // returns true\n   *    math.hasNumericValue(42n)                   // returns true\n   *    math.hasNumericValue(math.fraction(4))      // returns true\n   *    math.hasNumericValue(math.complex('2-4i'))  // returns false\n   *    math.hasNumericValue(false)                 // returns true\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    boolean: () => true,\n    string: function (x) {\n      return x.trim().length > 0 && !isNaN(Number(x))\n    },\n    any: function (x) {\n      return isNumeric(x)\n    }\n  })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isPositiveNumber } from '../../plain/number/index.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\n\nconst name = 'isPositive'\nconst dependencies = ['typed', 'config']\n\nexport const createIsPositive = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\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 true\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 | bigint | 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: x => nearlyEqual(x, 0, config.relTol, config.absTol) ? false : isPositiveNumber(x),\n\n    BigNumber: x =>\n      bigNearlyEqual(x, new x.constructor(0), config.relTol, config.absTol)\n        ? false\n        : !x.isNeg() && !x.isZero() && !x.isNaN(),\n\n    bigint: x => x > 0n,\n\n    Fraction: x => x.s > 0 && x.n > 0,\n\n    Unit: typed.referToSelf(self =>\n      x => typed.find(self, x.valueType())(x.value)),\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isZero'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createIsZero = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 | bigint | 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 | BigNumber | Complex | Fraction': x => equalScalar(x, 0),\n\n    bigint: x => x === 0n,\n\n    Unit: typed.referToSelf(self =>\n      x => typed.find(self, x.valueType())(x.value)),\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNaNNumber } from '../../plain/number/index.js'\n\nconst name = 'isNaN'\nconst dependencies = ['typed']\n\nexport const createIsNaN = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | 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: isNaNNumber,\n\n    BigNumber: function (x) {\n      return x.isNaN()\n    },\n\n    bigint: function (x) {\n      return false\n    },\n\n    Fraction: function (x) {\n      return false\n    },\n\n    Complex: function (x) {\n      return x.isNaN()\n    },\n\n    Unit: function (x) {\n      return Number.isNaN(x.value)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { typeOf as _typeOf } from '../../utils/is.js'\n\nconst name = 'typeOf'\nconst dependencies = ['typed']\n\nexport const createTypeOf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Determine the type of an entity.\n   *\n   * Syntax:\n   *\n   *    math.typeOf(x)\n   *\n   * Examples:\n   *\n   *    // This list is intended to include all relevant types, for testing\n   *    // purposes:\n   *    math.typeOf(3.5)                      // returns 'number'\n   *    math.typeOf(42n)                      // returns 'bigint'\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   *    math.typeOf(null)                     // returns 'null'\n   *    math.typeOf(true)                     // returns 'boolean'\n   *    math.typeOf([1, 2, 3])                // returns 'Array'\n   *    math.typeOf(new Date())               // returns 'Date'\n   *    math.typeOf(function () {})           // returns 'function'\n   *    math.typeOf({a: 2, b: 3})             // returns 'Object'\n   *    math.typeOf(/a regexp/)               // returns 'RegExp'\n   *    math.typeOf(undefined)                // returns 'undefined'\n   *    math.typeOf(math.bignumber('23e99'))  // returns 'BigNumber'\n   *    math.typeOf(math.chain(2))            // returns 'Chain'\n   *    math.typeOf(math.fraction(1, 3))      // returns 'Fraction'\n   *    math.typeOf(math.help('sqrt'))        // returns 'Help'\n   *    math.typeOf(math.index(1, 3))         // returns 'Index'\n   *    math.typeOf(math.matrix([[1],[3]]))   // returns 'DenseMatrix'\n   *    math.typeOf(math.matrix([],'sparse')) // returns 'SparseMatrix'\n   *    math.typeOf(new math.Range(0, 10))    // returns 'Range'\n   *    math.typeOf(math.evaluate('a=2\\na'))  // returns 'ResultSet'\n   *    math.typeOf(math.parse('A[2]'))       // returns 'AccessorNode'\n   *    math.typeOf(math.parse('[1,2,3]'))    // returns 'ArrayNode'\n   *    math.typeOf(math.parse('x=2'))        // returns 'AssignmentNode'\n   *    math.typeOf(math.parse('a=2; b=3'))   // returns 'BlockNode'\n   *    math.typeOf(math.parse('x<0?-1:1'))   // returns 'ConditionalNode'\n   *    math.typeOf(math.parse('2.3'))        // returns 'ConstantNode'\n   *    math.typeOf(math.parse('f(x)=x^2'))   // returns 'FunctionAssignmentNode'\n   *    math.typeOf(math.parse('sqrt(4)'))    // returns 'FunctionNode'\n   *    math.typeOf(math.parse('A[2]').index) // returns 'IndexNode'\n   *    math.typeOf(math.parse('{a:2}'))      // returns 'ObjectNode'\n   *    math.typeOf(math.parse('(2+3)'))      // returns 'ParenthesisNode'\n   *    math.typeOf(math.parse('1:10'))       // returns 'RangeNode'\n   *    math.typeOf(math.parse('a<b<c'))      // returns 'RelationalNode'\n   *    math.typeOf(math.parse('x'))          // returns 'SymbolNode'\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: _typeOf\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nexport const createCompareUnits = /* #__PURE__ */ factory(\n  'compareUnits', ['typed'], ({ typed }) => ({\n    'Unit, Unit': typed.referToSelf(self => (x, y) => {\n      if (!x.equalBase(y)) {\n        throw new Error('Cannot compare units with different base')\n      }\n      return typed.find(self, [x.valueType(), y.valueType()])(x.value, y.value)\n    })\n  })\n)\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { complexEquals } from '../../utils/complex.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'equalScalar'\nconst dependencies = ['typed', 'config']\n\nexport const createEqualScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed, config }) => {\n  const compareUnits = createCompareUnits({ typed })\n\n  /**\n   * Test whether two scalar values are nearly equal.\n   *\n   * @param  {number | BigNumber | bigint | Fraction | boolean | Complex | Unit} x   First value to compare\n   * @param  {number | BigNumber | bigint | 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\n    'boolean, boolean': function (x, y) {\n      return x === y\n    },\n\n    'number, number': function (x, y) {\n      return nearlyEqual(x, y, config.relTol, config.absTol)\n    },\n\n    'BigNumber, BigNumber': function (x, y) {\n      return x.eq(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n    },\n\n    'bigint, bigint': function (x, y) {\n      return x === y\n    },\n\n    'Fraction, Fraction': function (x, y) {\n      return x.equals(y)\n    },\n\n    'Complex, Complex': function (x, y) {\n      return complexEquals(x, y, config.relTol, config.absTol)\n    }\n  }, compareUnits)\n})\n\nexport const createEqualScalarNumber = factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return nearlyEqual(x, y, config.relTol, config.absTol)\n    }\n  })\n})\n","import { nearlyEqual } from './number.js'\n\n/**\n * Test whether two complex values are equal provided a given relTol and absTol.\n * Does not use or change the global Complex.EPSILON setting\n * @param {Complex} x - The first complex number for comparison.\n * @param {Complex} y - The second complex number for comparison.\n * @param {number} relTol - The relative tolerance for comparison.\n * @param {number} absTol - The absolute tolerance for comparison.\n * @returns {boolean} - Returns true if the two complex numbers are equal within the given tolerances, otherwise returns false.\n */\nexport function complexEquals (x, y, relTol, absTol) {\n  return nearlyEqual(x.re, y.re, relTol, absTol) && nearlyEqual(x.im, y.im, relTol, absTol)\n}\n","import { isArray, isBigNumber, isCollection, isIndex, isMatrix, isNumber, isString, typeOf } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { format } from '../../utils/string.js'\nimport { clone, deepStrictEqual } from '../../utils/object.js'\nimport { arraySize, getArrayDataType, processSizesWildcard, unsqueeze, validateIndex } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { maxArgumentCount } from '../../utils/function.js'\n\nconst name = 'SparseMatrix'\nconst dependencies = [\n  'typed',\n  'equalScalar',\n  'Matrix'\n]\n\nexport const createSparseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar, Matrix }) => {\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)) { throw new SyntaxError('Constructor must be called with the new operator') }\n    if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n    if (isMatrix(data)) {\n      // create from matrix\n      _createFromMatrix(this, data, datatype)\n    } else if (data && isArray(data.index) && isArray(data.ptr) && 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 (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 (' + 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 ? clone(source._values) : undefined\n      matrix._index = clone(source._index)\n      matrix._ptr = clone(source._ptr)\n      matrix._size = 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\n    // discover rows & columns, do not use math.size() to avoid looping array twice\n    const rows = data.length\n    let columns = 0\n\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    if (isString(datatype)) {\n      // find signature that matches (datatype, datatype)\n      eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar\n      // convert 0 to the same datatype\n      zero = typed.convert(0, datatype)\n    }\n\n    // check we have rows (empty array)\n    if (rows > 0) {\n      // column index\n      let j = 0\n      do {\n        // store pointer to values index\n        matrix._ptr.push(matrix._index.length)\n        // loop rows\n        for (let i = 0; i < rows; i++) {\n          // current row\n          const row = data[i]\n          // check row is an array\n          if (isArray(row)) {\n            // update columns if needed (only on first column)\n            if (j === 0 && columns < row.length) { columns = row.length }\n            // check row has column\n            if (j < row.length) {\n              // value\n              const v = row[j]\n              // check value != 0\n              if (!eq(v, zero)) {\n                // store value\n                matrix._values.push(v)\n                // index\n                matrix._index.push(i)\n              }\n            }\n          } else {\n            // update columns if needed (only on first column)\n            if (j === 0 && columns < 1) { columns = 1 }\n            // check value != 0 (row is a scalar)\n            if (!eq(row, zero)) {\n              // store value\n              matrix._values.push(row)\n              // index\n              matrix._index.push(i)\n            }\n          }\n        }\n        // increment index\n        j++\n      }\n      while (j < columns)\n    }\n    // store number of values in ptr\n    matrix._ptr.push(matrix._index.length)\n    // size\n    matrix._size = [rows, columns]\n  }\n\n  SparseMatrix.prototype = new Matrix()\n\n  /**\n   * Create a new SparseMatrix\n   */\n  SparseMatrix.prototype.createSparseMatrix = function (data, datatype) {\n    return new SparseMatrix(data, datatype)\n  }\n\n  /**\n   * Attach type information\n   */\n  Object.defineProperty(SparseMatrix, 'name', { value: 'SparseMatrix' })\n  SparseMatrix.prototype.constructor = SparseMatrix\n  SparseMatrix.prototype.type = 'SparseMatrix'\n  SparseMatrix.prototype.isSparseMatrix = true\n\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  SparseMatrix.prototype.getDataType = function () {\n    return getArrayDataType(this._values, typeOf)\n  }\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  SparseMatrix.prototype.storage = function () {\n    return 'sparse'\n  }\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  SparseMatrix.prototype.datatype = function () {\n    return this._datatype\n  }\n\n  /**\n   * Create a new SparseMatrix\n   * @memberof SparseMatrix\n   * @param {Array} data\n   * @param {string} [datatype]\n   */\n  SparseMatrix.prototype.create = function (data, datatype) {\n    return new SparseMatrix(data, datatype)\n  }\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  SparseMatrix.prototype.density = function () {\n    // rows & columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n    // calculate density\n    return rows !== 0 && columns !== 0 ? (this._index.length / (rows * columns)) : 0\n  }\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  SparseMatrix.prototype.subset = function (index, replacement, defaultValue) { // check it is a pattern matrix\n    if (!this._values) { throw new Error('Cannot invoke subset on a Pattern only matrix') }\n\n    // check arguments\n    switch (arguments.length) {\n      case 1:\n        return _getsubset(this, index)\n\n      // intentional fall through\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 (!isIndex(idx)) {\n      throw new TypeError('Invalid index')\n    }\n\n    const isScalar = idx.isScalar()\n    if (isScalar) {\n      // return a scalar\n      return matrix.get(idx.min())\n    }\n    // validate dimensions\n    const size = idx.size()\n    if (size.length !== matrix._size.length) {\n      throw new DimensionError(size.length, matrix._size.length)\n    }\n\n    // vars\n    let i, ii, k, kk\n\n    // validate if any of the ranges in the index is out of range\n    const min = idx.min()\n    const max = idx.max()\n    for (i = 0, ii = matrix._size.length; i < ii; i++) {\n      validateIndex(min[i], matrix._size[i])\n      validateIndex(max[i], matrix._size[i])\n    }\n\n    // matrix arrays\n    const mvalues = matrix._values\n    const mindex = matrix._index\n    const mptr = matrix._ptr\n\n    // rows & columns dimensions for result matrix\n    const rows = idx.dimension(0)\n    const columns = idx.dimension(1)\n\n    // workspace & permutation vector\n    const w = []\n    const pv = []\n\n    // loop rows in resulting matrix\n    rows.forEach(function (i, r) {\n      // update permutation vector\n      pv[i] = r[0]\n      // mark i in workspace\n      w[i] = true\n    })\n\n    // result matrix arrays\n    const values = mvalues ? [] : undefined\n    const index = []\n    const ptr = []\n\n    // loop columns in result matrix\n    columns.forEach(function (j) {\n      // update ptr\n      ptr.push(index.length)\n      // loop values in column j\n      for (k = mptr[j], kk = mptr[j + 1]; k < kk; k++) {\n        // row\n        i = mindex[k]\n        // check row is in result matrix\n        if (w[i] === true) {\n          // push index\n          index.push(pv[i])\n          // check we need to process values\n          if (values) { values.push(mvalues[k]) }\n        }\n      }\n    })\n    // update ptr\n    ptr.push(index.length)\n\n    // return matrix\n    return new SparseMatrix({\n      values,\n      index,\n      ptr,\n      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    }\n\n    // get index size and check whether the index contains a single value\n    const iSize = index.size()\n    const isScalar = index.isScalar()\n\n    // calculate the size of the submatrix, and convert it into an Array if needed\n    let sSize\n    if (isMatrix(submatrix)) {\n      // submatrix size\n      sSize = submatrix.size()\n      // use array representation\n      submatrix = submatrix.toArray()\n    } else {\n      // get submatrix size (array, scalar)\n      sSize = arraySize(submatrix)\n    }\n\n    // check index is a scalar\n    if (isScalar) {\n      // verify submatrix is a scalar\n      if (sSize.length !== 0) {\n        throw new TypeError('Scalar expected')\n      }\n      // set value\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(iSize.length, matrix._size.length, '<')\n      }\n\n      // check submatrix and index have the same dimensions\n      if (sSize.length < iSize.length) {\n        // calculate number of missing outer dimensions\n        let i = 0\n        let outer = 0\n        while (iSize[i] === 1 && sSize[i] === 1) {\n          i++\n        }\n        while (iSize[i] === 1) {\n          outer++\n          i++\n        }\n        // unsqueeze both outer and inner dimensions\n        submatrix = unsqueeze(submatrix, iSize.length, outer, sSize)\n      }\n\n      // check whether the size of the submatrix matches the index size\n      if (!deepStrictEqual(iSize, sSize)) {\n        throw new DimensionError(iSize, sSize, '>')\n      }\n\n      // insert the sub matrix\n      if (iSize.length === 1) {\n        // if the replacement index only has 1 dimension, go trough each one and set its value\n        const range = index.dimension(0)\n        range.forEach(function (dataIndex, subIndex) {\n          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        const firstDimensionRange = index.dimension(0)\n        const secondDimensionRange = index.dimension(1)\n        firstDimensionRange.forEach(function (firstDataIndex, firstSubIndex) {\n          validateIndex(firstDataIndex)\n          secondDimensionRange.forEach(function (secondDataIndex, secondSubIndex) {\n            validateIndex(secondDataIndex)\n            matrix.set([firstDataIndex, secondDataIndex], submatrix[firstSubIndex[0]][secondSubIndex[0]], defaultValue)\n          })\n        })\n      }\n    }\n    return matrix\n  }\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  SparseMatrix.prototype.get = function (index) {\n    if (!isArray(index)) { throw new TypeError('Array expected') }\n    if (index.length !== this._size.length) { throw new DimensionError(index.length, this._size.length) }\n\n    // check it is a pattern matrix\n    if (!this._values) { throw new Error('Cannot invoke get on a Pattern only matrix') }\n\n    // row and column\n    const i = index[0]\n    const j = index[1]\n\n    // check i, j are valid\n    validateIndex(i, this._size[0])\n    validateIndex(j, this._size[1])\n\n    // find value index\n    const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index)\n    // check k is prior to next column k and it is in the correct row\n    if (k < this._ptr[j + 1] && this._index[k] === i) { return this._values[k] }\n\n    return 0\n  }\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  SparseMatrix.prototype.set = function (index, v, defaultValue) {\n    if (!isArray(index)) { throw new TypeError('Array expected') }\n    if (index.length !== this._size.length) { throw new DimensionError(index.length, this._size.length) }\n\n    // check it is a pattern matrix\n    if (!this._values) { throw new Error('Cannot invoke set on a Pattern only matrix') }\n\n    // row and column\n    const i = index[0]\n    const j = index[1]\n\n    // rows & columns\n    let rows = this._size[0]\n    let columns = this._size[1]\n\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    if (isString(this._datatype)) {\n      // find signature that matches (datatype, datatype)\n      eq = typed.find(equalScalar, [this._datatype, this._datatype]) || equalScalar\n      // convert 0 to the same datatype\n      zero = typed.convert(0, this._datatype)\n    }\n\n    // check we need to resize matrix\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)\n      // update rows & columns\n      rows = this._size[0]\n      columns = this._size[1]\n    }\n\n    // check i, j are valid\n    validateIndex(i, rows)\n    validateIndex(j, columns)\n\n    // find value index\n    const k = _getValueIndex(i, this._ptr[j], this._ptr[j + 1], this._index)\n    // check k is prior to next column k and it is in the correct row\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      if (!eq(v, zero)) {\n        // insert value @ (i, j)\n        _insert(k, i, j, v, this._values, this._index, this._ptr)\n      }\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) { return bottom }\n    // loop rows [top, bottom[\n    for (let r = top; r < bottom; r++) {\n      // check we found value index\n      if (index[r] === i) { return r }\n    }\n    // we did not find row\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)\n    // update pointers\n    for (let x = j + 1; x < ptr.length; x++) { ptr[x]-- }\n  }\n\n  function _insert (k, i, j, v, values, index, ptr) {\n    // insert value\n    values.splice(k, 0, v)\n    // update row for k\n    index.splice(k, 0, i)\n    // update column pointers\n    for (let x = j + 1; x < ptr.length; x++) { 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  SparseMatrix.prototype.resize = function (size, defaultValue, copy) {\n    // validate arguments\n    if (!isCollection(size)) {\n      throw new TypeError('Array or Matrix expected')\n    }\n\n    // SparseMatrix input is always 2d, flatten this into 1d if it's indeed a vector\n    const sizeArray = size.valueOf().map(value => {\n      return Array.isArray(value) && value.length === 1\n        ? value[0]\n        : value\n    })\n\n    if (sizeArray.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n    // check sizes\n    sizeArray.forEach(function (value) {\n      if (!isNumber(value) || !isInteger(value) || value < 0) {\n        throw new TypeError('Invalid size, must contain positive integers ' +\n          '(size: ' + format(sizeArray) + ')')\n      }\n    })\n\n    // matrix to resize\n    const m = copy ? this.clone() : this\n    // resize matrix\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    let value = defaultValue || 0\n\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    if (isString(matrix._datatype)) {\n      // find signature that matches (datatype, datatype)\n      eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar\n      // convert 0 to the same datatype\n      zero = typed.convert(0, matrix._datatype)\n      // convert value to the same datatype\n      value = typed.convert(value, matrix._datatype)\n    }\n\n    // should we insert the value?\n    const ins = !eq(value, zero)\n\n    // old columns and rows\n    const r = matrix._size[0]\n    let c = matrix._size[1]\n\n    let i, j, k\n\n    // check we need to increase columns\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\n        // check we need to insert matrix._values\n        if (ins) {\n          // loop rows\n          for (i = 0; i < r; i++) {\n            // add new matrix._values\n            matrix._values.push(value)\n            // update matrix._index\n            matrix._index.push(i)\n          }\n        }\n      }\n      // store number of matrix._values in matrix._ptr\n      matrix._ptr[columns] = matrix._values.length\n    } else if (columns < c) {\n      // truncate matrix._ptr\n      matrix._ptr.splice(columns + 1, c - columns)\n      // truncate matrix._values and matrix._index\n      matrix._values.splice(matrix._ptr[columns], matrix._values.length)\n      matrix._index.splice(matrix._ptr[columns], matrix._index.length)\n    }\n    // update columns\n    c = columns\n\n    // check we need to increase rows\n    if (rows > r) {\n      // check we have to insert values\n      if (ins) {\n        // inserts\n        let n = 0\n        // loop columns\n        for (j = 0; j < c; j++) {\n          // update matrix._ptr for current column\n          matrix._ptr[j] = matrix._ptr[j] + n\n          // where to insert matrix._values\n          k = matrix._ptr[j + 1] + n\n          // pointer\n          let p = 0\n          // loop new rows, initialize pointer\n          for (i = r; i < rows; i++, p++) {\n            // add value\n            matrix._values.splice(k + p, 0, value)\n            // update matrix._index\n            matrix._index.splice(k + p, 0, i)\n            // increment inserts\n            n++\n          }\n        }\n        // store number of matrix._values in matrix._ptr\n        matrix._ptr[c] = matrix._values.length\n      }\n    } else if (rows < r) {\n      // deletes\n      let d = 0\n      // loop columns\n      for (j = 0; j < c; j++) {\n        // update matrix._ptr for current column\n        matrix._ptr[j] = matrix._ptr[j] - d\n        // where matrix._values start for next column\n        const k0 = matrix._ptr[j]\n        const k1 = matrix._ptr[j + 1] - d\n        // loop matrix._index\n        for (k = k0; k < k1; k++) {\n          // row\n          i = matrix._index[k]\n          // check we need to delete value and matrix._index\n          if (i > rows - 1) {\n            // remove value\n            matrix._values.splice(k, 1)\n            // remove item from matrix._index\n            matrix._index.splice(k, 1)\n            // increase deletes\n            d++\n          }\n        }\n      }\n      // update matrix._ptr for current column\n      matrix._ptr[j] = matrix._values.length\n    }\n    // update matrix._size\n    matrix._size[0] = rows\n    matrix._size[1] = columns\n    // return matrix\n    return matrix\n  }\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  SparseMatrix.prototype.reshape = function (sizes, copy) {\n    // validate arguments\n    if (!isArray(sizes)) { throw new TypeError('Array expected') }\n    if (sizes.length !== 2) { throw new Error('Sparse matrices can only be reshaped in two dimensions') }\n\n    // check sizes\n    sizes.forEach(function (value) {\n      if (!isNumber(value) || !isInteger(value) || value <= -2 || value === 0) {\n        throw new TypeError('Invalid size, must contain positive integers or -1 ' +\n          '(size: ' + format(sizes) + ')')\n      }\n    })\n\n    const currentLength = this._size[0] * this._size[1]\n    sizes = processSizesWildcard(sizes, currentLength)\n    const newLength = sizes[0] * sizes[1]\n\n    // m * n must not change\n    if (currentLength !== newLength) {\n      throw new Error('Reshaping sparse matrix will result in the wrong number of elements')\n    }\n\n    // matrix to reshape\n    const m = copy ? this.clone() : this\n\n    // return unchanged if the same shape\n    if (this._size[0] === sizes[0] && this._size[1] === sizes[1]) {\n      return m\n    }\n\n    // Convert to COO format (generate a column index)\n    const colIndex = []\n    for (let i = 0; i < m._ptr.length; i++) {\n      for (let j = 0; j < m._ptr[i + 1] - m._ptr[i]; j++) {\n        colIndex.push(i)\n      }\n    }\n\n    // Clone the values array\n    const values = m._values.slice()\n\n    // Clone the row index array\n    const rowIndex = m._index.slice()\n\n    // Transform the (row, column) indices\n    for (let i = 0; i < m._index.length; i++) {\n      const r1 = rowIndex[i]\n      const c1 = colIndex[i]\n      const flat = r1 * m._size[1] + c1\n      colIndex[i] = flat % sizes[1]\n      rowIndex[i] = Math.floor(flat / sizes[1])\n    }\n\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\n    // OR, we could easily just:\n\n    // 1. Remove all values from the matrix\n    m._values.length = 0\n    m._index.length = 0\n    m._ptr.length = sizes[1] + 1\n    m._size = sizes.slice()\n    for (let i = 0; i < m._ptr.length; i++) {\n      m._ptr[i] = 0\n    }\n\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    for (let h = 0; h < values.length; h++) {\n      const i = rowIndex[h]\n      const j = colIndex[h]\n      const v = values[h]\n      const k = _getValueIndex(i, m._ptr[j], m._ptr[j + 1], m._index)\n      _insert(k, i, j, v, m._values, m._index, m._ptr)\n    }\n\n    // The value indices are inserted out of order, but apparently that's... still OK?\n\n    return m\n  }\n\n  /**\n   * Create a clone of the matrix\n   * @memberof SparseMatrix\n   * @return {SparseMatrix} clone\n   */\n  SparseMatrix.prototype.clone = function () {\n    const m = new SparseMatrix({\n      values: this._values ? clone(this._values) : undefined,\n      index: clone(this._index),\n      ptr: clone(this._ptr),\n      size: clone(this._size),\n      datatype: this._datatype\n    })\n    return m\n  }\n\n  /**\n   * Retrieve the size of the matrix.\n   * @memberof SparseMatrix\n   * @returns {number[]} size\n   */\n  SparseMatrix.prototype.size = function () {\n    return this._size.slice(0) // copy the Array\n  }\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  SparseMatrix.prototype.map = function (callback, skipZeros) {\n    // check it is a pattern matrix\n    if (!this._values) { throw new Error('Cannot invoke map on a Pattern only matrix') }\n    // matrix instance\n    const me = this\n    // rows and columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n    // invoke callback\n    const args = maxArgumentCount(callback)\n    const invoke = function (v, i, j) {\n      // invoke callback\n      if (args === 1) return callback(v)\n      if (args === 2) return callback(v, [i, j])\n      return callback(v, [i, j], me)\n    }\n    // invoke _map\n    return _map(this, 0, rows - 1, 0, columns - 1, invoke, skipZeros)\n  }\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  function _map (matrix, minRow, maxRow, minColumn, maxColumn, callback, skipZeros) {\n    // result arrays\n    const values = []\n    const index = []\n    const ptr = []\n\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    if (isString(matrix._datatype)) {\n      // find signature that matches (datatype, datatype)\n      eq = typed.find(equalScalar, [matrix._datatype, matrix._datatype]) || equalScalar\n      // convert 0 to the same datatype\n      zero = typed.convert(0, matrix._datatype)\n    }\n\n    // invoke callback\n    const invoke = function (v, x, y) {\n      // invoke callback\n      v = callback(v, x, y)\n      // check value != 0\n      if (!eq(v, zero)) {\n        // store value\n        values.push(v)\n        // index\n        index.push(x)\n      }\n    }\n    // loop columns\n    for (let j = minColumn; j <= maxColumn; j++) {\n      // store pointer to values index\n      ptr.push(values.length)\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = matrix._ptr[j]\n      const k1 = matrix._ptr[j + 1]\n\n      if (skipZeros) {\n        // loop k within [k0, k1[\n        for (let k = k0; k < k1; k++) {\n          // row index\n          const i = matrix._index[k]\n          // check i is in range\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        const values = {}\n        for (let k = k0; k < k1; k++) {\n          const i = matrix._index[k]\n          values[i] = matrix._values[k]\n        }\n\n        // loop over all rows (indexes can be unordered so we can't use that),\n        // and either read the value or zero\n        for (let i = minRow; i <= maxRow; i++) {\n          const value = (i in values) ? values[i] : 0\n          invoke(value, i - minRow, j - minColumn)\n        }\n      }\n    }\n\n    // store number of values in ptr\n    ptr.push(values.length)\n    // return sparse matrix\n    return new SparseMatrix({\n      values,\n      index,\n      ptr,\n      size: [maxRow - minRow + 1, maxColumn - minColumn + 1]\n    })\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  SparseMatrix.prototype.forEach = function (callback, skipZeros) {\n    // check it is a pattern matrix\n    if (!this._values) { throw new Error('Cannot invoke forEach on a Pattern only matrix') }\n    // matrix instance\n    const me = this\n    // rows and columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = this._ptr[j]\n      const k1 = this._ptr[j + 1]\n\n      if (skipZeros) {\n        // loop k within [k0, k1[\n        for (let k = k0; k < k1; k++) {\n          // row index\n          const i = this._index[k]\n\n          // value @ k\n          callback(this._values[k], [i, j], me)\n        }\n      } else {\n        // create a cache holding all defined values\n        const values = {}\n        for (let k = k0; k < k1; k++) {\n          const i = this._index[k]\n          values[i] = this._values[k]\n        }\n\n        // loop over all rows (indexes can be unordered so we can't use that),\n        // and either read the value or zero\n        for (let i = 0; i < rows; i++) {\n          const value = (i in values) ? values[i] : 0\n          callback(value, [i, j], me)\n        }\n      }\n    }\n  }\n\n  /**\n   * Iterate over the matrix elements, skipping zeros\n   * @return {Iterable<{ value, index: number[] }>}\n   */\n  SparseMatrix.prototype[Symbol.iterator] = function * () {\n    if (!this._values) { throw new Error('Cannot iterate a Pattern only matrix') }\n\n    const columns = this._size[1]\n\n    for (let j = 0; j < columns; j++) {\n      const k0 = this._ptr[j]\n      const k1 = this._ptr[j + 1]\n\n      for (let k = k0; k < k1; k++) {\n        // row index\n        const i = this._index[k]\n\n        yield ({ value: this._values[k], index: [i, j] })\n      }\n    }\n  }\n\n  /**\n   * Create an Array with a copy of the data of the SparseMatrix\n   * @memberof SparseMatrix\n   * @returns {Array} array\n   */\n  SparseMatrix.prototype.toArray = function () {\n    return _toArray(this._values, this._index, this._ptr, this._size, true)\n  }\n\n  /**\n   * Get the primitive value of the SparseMatrix: a two dimensions array\n   * @memberof SparseMatrix\n   * @returns {Array} array\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    const rows = size[0]\n    const columns = size[1]\n    // result\n    const a = []\n    // vars\n    let i, j\n    // initialize array\n    for (i = 0; i < rows; i++) {\n      a[i] = []\n      for (j = 0; j < columns; j++) { a[i][j] = 0 }\n    }\n\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = ptr[j]\n      const k1 = ptr[j + 1]\n      // loop k within [k0, k1[\n      for (let k = k0; k < k1; k++) {\n        // row index\n        i = index[k]\n        // set value (use one for pattern matrix)\n        a[i][j] = values ? (copy ? clone(values[k]) : values[k]) : 1\n      }\n    }\n    return a\n  }\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  SparseMatrix.prototype.format = function (options) {\n    // rows and columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n    // density\n    const density = this.density()\n    // rows & columns\n    let str = 'Sparse Matrix [' + format(rows, options) + ' x ' + format(columns, options) + '] density: ' + format(density, options) + '\\n'\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = this._ptr[j]\n      const k1 = this._ptr[j + 1]\n      // loop k within [k0, k1[\n      for (let k = k0; k < k1; k++) {\n        // row index\n        const i = this._index[k]\n        // append value\n        str += '\\n    (' + format(i, options) + ', ' + format(j, options) + ') ==> ' + (this._values ? format(this._values[k], options) : 'X')\n      }\n    }\n    return str\n  }\n\n  /**\n   * Get a string representation of the matrix\n   * @memberof SparseMatrix\n   * @returns {string} str\n   */\n  SparseMatrix.prototype.toString = function () {\n    return format(this.toArray())\n  }\n\n  /**\n   * Get a JSON representation of the matrix\n   * @memberof SparseMatrix\n   * @returns {Object}\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  /**\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  SparseMatrix.prototype.diagonal = function (k) {\n    // validate k if any\n    if (k) {\n      // convert BigNumber to a number\n      if (isBigNumber(k)) { k = k.toNumber() }\n      // is must be an integer\n      if (!isNumber(k) || !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    const kSuper = k > 0 ? k : 0\n    const kSub = k < 0 ? -k : 0\n\n    // rows & columns\n    const rows = this._size[0]\n    const columns = this._size[1]\n\n    // number diagonal values\n    const n = Math.min(rows - kSub, columns - kSuper)\n\n    // diagonal arrays\n    const values = []\n    const index = []\n    const ptr = []\n    // initial ptr value\n    ptr[0] = 0\n    // loop columns\n    for (let j = kSuper; j < columns && values.length < n; j++) {\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = this._ptr[j]\n      const k1 = this._ptr[j + 1]\n      // loop x within [k0, k1[\n      for (let x = k0; x < k1; x++) {\n        // row index\n        const i = this._index[x]\n        // check row\n        if (i === j - kSuper + kSub) {\n          // value on this column\n          values.push(this._values[x])\n          // store row\n          index[values.length - 1] = i - kSub\n          // exit loop\n          break\n        }\n      }\n    }\n    // close ptr\n    ptr.push(values.length)\n    // return matrix\n    return new SparseMatrix({\n      values,\n      index,\n      ptr,\n      size: [n, 1]\n    })\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  SparseMatrix.fromJSON = function (json) {\n    return new SparseMatrix(json)\n  }\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  SparseMatrix.diagonal = function (size, value, k, defaultValue, datatype) {\n    if (!isArray(size)) { throw new TypeError('Array expected, size parameter') }\n    if (size.length !== 2) { throw new Error('Only two dimensions matrix are supported') }\n\n    // map size & validate\n    size = size.map(function (s) {\n      // check it is a big number\n      if (isBigNumber(s)) {\n        // convert it\n        s = s.toNumber()\n      }\n      // validate arguments\n      if (!isNumber(s) || !isInteger(s) || s < 1) {\n        throw new Error('Size values must be positive integers')\n      }\n      return s\n    })\n\n    // validate k if any\n    if (k) {\n      // convert BigNumber to a number\n      if (isBigNumber(k)) { k = k.toNumber() }\n      // is must be an integer\n      if (!isNumber(k) || !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    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    if (isString(datatype)) {\n      // find signature that matches (datatype, datatype)\n      eq = typed.find(equalScalar, [datatype, datatype]) || equalScalar\n      // convert 0 to the same datatype\n      zero = typed.convert(0, datatype)\n    }\n\n    const kSuper = k > 0 ? k : 0\n    const kSub = k < 0 ? -k : 0\n\n    // rows and columns\n    const rows = size[0]\n    const columns = size[1]\n\n    // number of non-zero items\n    const n = Math.min(rows - kSub, columns - kSuper)\n\n    // value extraction function\n    let _value\n\n    // check value\n    if (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      }\n      // define function\n      _value = function (i) {\n        // return value @ i\n        return value[i]\n      }\n    } else if (isMatrix(value)) {\n      // matrix size\n      const ms = value.size()\n      // validate matrix\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      }\n      // define function\n      _value = function (i) {\n        // return value @ i\n        return value.get([i])\n      }\n    } else {\n      // define function\n      _value = function () {\n        // return value\n        return value\n      }\n    }\n\n    // create arrays\n    const values = []\n    const index = []\n    const ptr = []\n\n    // loop items\n    for (let j = 0; j < columns; j++) {\n      // number of rows with value\n      ptr.push(values.length)\n      // diagonal index\n      const i = j - kSuper\n      // check we need to set diagonal value\n      if (i >= 0 && i < n) {\n        // get value @ i\n        const v = _value(i)\n        // check for zero\n        if (!eq(v, zero)) {\n          // column\n          index.push(i + kSub)\n          // add value\n          values.push(v)\n        }\n      }\n    }\n    // last value should be number of values\n    ptr.push(values.length)\n    // create SparseMatrix\n    return new SparseMatrix({\n      values,\n      index,\n      ptr,\n      size: [rows, columns]\n    })\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  SparseMatrix.prototype.swapRows = function (i, j) {\n    // check index\n    if (!isNumber(i) || !isInteger(i) || !isNumber(j) || !isInteger(j)) {\n      throw new Error('Row index must be positive integers')\n    }\n    // check dimensions\n    if (this._size.length !== 2) {\n      throw new Error('Only two dimensional matrix is supported')\n    }\n    // validate index\n    validateIndex(i, this._size[0])\n    validateIndex(j, this._size[0])\n\n    // swap rows\n    SparseMatrix._swapRows(i, j, this._size[1], this._values, this._index, this._ptr)\n    // return current instance\n    return this\n  }\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  SparseMatrix._forEachRow = function (j, values, index, ptr, callback) {\n    // indeces for column j\n    const k0 = ptr[j]\n    const k1 = ptr[j + 1]\n    // loop\n    for (let k = k0; k < k1; k++) {\n      // invoke callback\n      callback(index[k], values[k])\n    }\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  SparseMatrix._swapRows = function (x, y, columns, values, index, ptr) {\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = ptr[j]\n      const k1 = ptr[j + 1]\n      // find value index @ x\n      const kx = _getValueIndex(x, k0, k1, index)\n      // find value index @ x\n      const ky = _getValueIndex(y, k0, k1, index)\n      // check both rows exist in matrix\n      if (kx < k1 && ky < k1 && index[kx] === x && index[ky] === y) {\n        // swap values (check for pattern matrix)\n        if (values) {\n          const v = values[kx]\n          values[kx] = values[ky]\n          values[ky] = v\n        }\n        // next column\n        continue\n      }\n      // check x row exist & no y row\n      if (kx < k1 && index[kx] === x && (ky >= k1 || index[ky] !== y)) {\n        // value @ x (check for pattern matrix)\n        const vx = values ? values[kx] : undefined\n        // insert value @ y\n        index.splice(ky, 0, y)\n        if (values) { values.splice(ky, 0, vx) }\n        // remove value @ x (adjust array index if needed)\n        index.splice(ky <= kx ? kx + 1 : kx, 1)\n        if (values) { values.splice(ky <= kx ? kx + 1 : kx, 1) }\n        // next column\n        continue\n      }\n      // check y row exist & no x row\n      if (ky < k1 && index[ky] === y && (kx >= k1 || index[kx] !== x)) {\n        // value @ y (check for pattern matrix)\n        const vy = values ? values[ky] : undefined\n        // insert value @ x\n        index.splice(kx, 0, x)\n        if (values) { values.splice(kx, 0, vy) }\n        // remove value @ y (adjust array index if needed)\n        index.splice(kx <= ky ? ky + 1 : ky, 1)\n        if (values) { values.splice(kx <= ky ? ky + 1 : ky, 1) }\n      }\n    }\n  }\n\n  return SparseMatrix\n}, { isClass: true })\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'number'\nconst dependencies = ['typed']\n\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 */\nfunction getNonDecimalNumberParts (input) {\n  const nonDecimalWithRadixMatch = input.match(/(0[box])([0-9a-fA-F]*)\\.([0-9a-fA-F]*)/)\n  if (nonDecimalWithRadixMatch) {\n    const radix = ({ '0b': 2, '0o': 8, '0x': 16 })[nonDecimalWithRadixMatch[1]]\n    const integerPart = nonDecimalWithRadixMatch[2]\n    const fractionalPart = nonDecimalWithRadixMatch[3]\n    return { input, radix, integerPart, fractionalPart }\n  } else {\n    return null\n  }\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 */\nfunction makeNumberFromNonDecimalParts (parts) {\n  const n = parseInt(parts.integerPart, parts.radix)\n  let f = 0\n  for (let i = 0; i < parts.fractionalPart.length; i++) {\n    const digitValue = parseInt(parts.fractionalPart[i], parts.radix)\n    f += digitValue / Math.pow(parts.radix, i + 1)\n  }\n  const result = n + f\n  if (isNaN(result)) {\n    throw new SyntaxError('String \"' + parts.input + '\" is not a valid number')\n  }\n  return result\n}\n\nexport const createNumber = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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, bigint, boolean, numeric, 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  const number = typed('number', {\n    '': function () {\n      return 0\n    },\n\n    number: function (x) {\n      return x\n    },\n\n    string: function (x) {\n      if (x === 'NaN') return NaN\n      const nonDecimalNumberParts = getNonDecimalNumberParts(x)\n      if (nonDecimalNumberParts) {\n        return makeNumberFromNonDecimalParts(nonDecimalNumberParts)\n      }\n      let size = 0\n      const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/)\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      let num = Number(x)\n      if (isNaN(num)) {\n        throw new SyntaxError('String \"' + x + '\" is not a valid number')\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 > 2 ** size - 1) {\n          // literal is too large for size suffix\n          throw new SyntaxError(`String \"${x}\" is out of range`)\n        }\n        // check if the bit at index size - 1 is set and if so do the twos complement\n        if (num >= 2 ** (size - 1)) {\n          num = num - 2 ** size\n        }\n      }\n      return num\n    },\n\n    BigNumber: function (x) {\n      return x.toNumber()\n    },\n\n    bigint: function (x) {\n      return Number(x)\n    },\n\n    Fraction: function (x) {\n      return x.valueOf()\n    },\n\n    Unit: typed.referToSelf(self => (x) => {\n      const clone = x.clone()\n      clone.value = self(x.value)\n      return clone\n    }),\n\n    null: function (x) {\n      return 0\n    },\n\n    'Unit, string | Unit': function (unit, valuelessUnit) {\n      return unit.toNumber(valuelessUnit)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\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  number.fromJSON = function (json) {\n    return parseFloat(json.value)\n  }\n\n  return number\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'bigint'\nconst dependencies = ['typed']\n\nexport const createBigint = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Create a bigint or convert a string, boolean, or unit to a bigint.\n   * When value is a matrix, all elements will be converted to bigint.\n   *\n   * Syntax:\n   *\n   *    math.bigint(value)\n   *\n   * Examples:\n   *\n   *    math.bigint(2)                         // returns 2n\n   *    math.bigint('123')                     // returns 123n\n   *    math.bigint(true)                      // returns 1n\n   *    math.bigint([true, false, true, true]) // returns [1n, 0n, 1n, 1n]\n   *\n   * See also:\n   *\n   *    number, bignumber, boolean, complex, index, matrix, string, unit\n   *\n   * @param {string | number | BigNumber | bigint | Fraction | boolean | Array | Matrix | null} [value]  Value to be converted\n   * @return {bigint | Array | Matrix} The created bigint\n   */\n  const bigint = typed('bigint', {\n    '': function () {\n      return 0n\n    },\n\n    bigint: function (x) {\n      return x\n    },\n\n    number: function (x) {\n      return BigInt(x.toFixed())\n    },\n\n    BigNumber: function (x) {\n      return BigInt(x.round().toString())\n    },\n\n    Fraction: function (x) {\n      return BigInt(x.valueOf().toFixed())\n    },\n\n    'string | boolean': function (x) {\n      return BigInt(x)\n    },\n\n    null: function (x) {\n      return 0n\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n\n  // reviver function to parse a JSON object like:\n  //\n  //     {\"mathjs\":\"bigint\",\"value\":\"123\"}\n  //\n  // into a bigint 123n\n  bigint.fromJSON = function (json) {\n    return BigInt(json.value)\n  }\n\n  return bigint\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\nimport { format } from '../utils/number.js'\n\nconst name = 'string'\nconst dependencies = ['typed']\n\nexport const createString = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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\n    number: format,\n\n    null: function (x) {\n      return 'null'\n    },\n\n    boolean: function (x) {\n      return x + ''\n    },\n\n    string: function (x) {\n      return x\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)),\n\n    any: function (x) {\n      return String(x)\n    }\n  })\n})\n","import { factory } from '../utils/factory.js'\nimport { deepMap } from '../utils/collection.js'\n\nconst name = 'boolean'\nconst dependencies = ['typed']\n\nexport const createBoolean = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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\n    boolean: function (x) {\n      return x\n    },\n\n    number: function (x) {\n      return !!x\n    },\n\n    null: function (x) {\n      return false\n    },\n\n    BigNumber: function (x) {\n      return !x.isZero()\n    },\n\n    string: function (x) {\n      // try case insensitive\n      const lcase = x.toLowerCase()\n      if (lcase === 'true') {\n        return true\n      } else if (lcase === 'false') {\n        return false\n      }\n\n      // test whether value is a valid number\n      const num = Number(x)\n      if (x !== '' && !isNaN(num)) {\n        return !!num\n      }\n\n      throw new Error('Cannot convert \"' + x + '\" to a boolean')\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'bignumber'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createBignumber = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\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   *    number, bigint, boolean, complex, index, matrix, string, unit\n   *\n   * @param {number | string | Fraction | BigNumber | bigint | 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\n    number: function (x) {\n      // convert to string to prevent errors in case of >15 digits\n      return new BigNumber(x + '')\n    },\n\n    string: function (x) {\n      const wordSizeSuffixMatch = x.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/)\n      if (wordSizeSuffixMatch) {\n        // x has a word size suffix\n        const size = wordSizeSuffixMatch[2]\n        const n = BigNumber(wordSizeSuffixMatch[1])\n        const twoPowSize = new BigNumber(2).pow(Number(size))\n        if (n.gt(twoPowSize.sub(1))) {\n          throw new SyntaxError(`String \"${x}\" is out of range`)\n        }\n        const twoPowSizeSubOne = new BigNumber(2).pow(Number(size) - 1)\n        if (n.gte(twoPowSizeSubOne)) {\n          return n.sub(twoPowSize)\n        } else {\n          return n\n        }\n      }\n      return new BigNumber(x)\n    },\n\n    BigNumber: function (x) {\n      // we assume a BigNumber is immutable\n      return x\n    },\n\n    bigint: function (x) {\n      return new BigNumber(x.toString())\n    },\n\n    Unit: typed.referToSelf(self => (x) => {\n      const clone = x.clone()\n      clone.value = self(x.value)\n      return clone\n    }),\n\n    Fraction: function (x) {\n      return new BigNumber(x.n).div(x.d).times(x.s)\n    },\n\n    null: function (x) {\n      return new BigNumber(0)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'complex'\nconst dependencies = ['typed', 'Complex']\n\nexport const createComplex = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex }) => {\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\n    number: function (x) {\n      return new Complex(x, 0)\n    },\n\n    'number, number': function (re, im) {\n      return new Complex(re, im)\n    },\n\n    // TODO: this signature should be redundant\n    'BigNumber, BigNumber': function (re, im) {\n      return new Complex(re.toNumber(), im.toNumber())\n    },\n\n    Fraction: function (x) {\n      return new Complex(x.valueOf(), 0)\n    },\n\n    Complex: function (x) {\n      return x.clone()\n    },\n\n    string: function (x) {\n      return Complex(x) // for example '2 + 3i'\n    },\n\n    null: function (x) {\n      return Complex(0)\n    },\n\n    Object: function (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\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'fraction'\nconst dependencies = ['typed', 'Fraction']\n\nexport const createFraction = /* #__PURE__ */ factory(name, dependencies, ({ typed, Fraction }) => {\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 | bigint | Unit | 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 (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\n    string: function (x) {\n      return new Fraction(x)\n    },\n\n    'number, number': function (numerator, denominator) {\n      return new Fraction(numerator, denominator)\n    },\n\n    null: function (x) {\n      return new Fraction(0)\n    },\n\n    BigNumber: function (x) {\n      return new Fraction(x.toString())\n    },\n\n    bigint: function (x) {\n      return new Fraction(x.toString())\n    },\n\n    Fraction: function (x) {\n      return x // fractions are immutable\n    },\n\n    Unit: typed.referToSelf(self => (x) => {\n      const clone = x.clone()\n      clone.value = self(x.value)\n      return clone\n    }),\n\n    Object: function (x) {\n      return new Fraction(x)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matrix'\nconst dependencies = ['typed', 'Matrix', 'DenseMatrix', 'SparseMatrix']\n\nexport const createMatrix = /* #__PURE__ */ factory(name, dependencies, ({ typed, Matrix, DenseMatrix, SparseMatrix }) => {\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\n    string: function (format) {\n      return _create([], format)\n    },\n\n    'string, string': function (format, datatype) {\n      return _create([], format, datatype)\n    },\n\n    Array: function (data) {\n      return _create(data)\n    },\n\n    Matrix: function (data) {\n      return _create(data, data.storage())\n    },\n\n    'Array | Matrix, string': _create,\n\n    'Array | Matrix, string, string': _create\n  })\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  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})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromFunction'\nconst dependencies = ['typed', 'matrix', 'isZero']\n\nexport const createMatrixFromFunction = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isZero }) => {\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 (size, fn, format, datatype) {\n      return _create(size, fn, format, datatype)\n    },\n    'Array | Matrix, function, string': function (size, fn, format) {\n      return _create(size, fn, format)\n    },\n    'Matrix, function': function (size, fn) {\n      return _create(size, fn, 'dense')\n    },\n    'Array, function': function (size, fn) {\n      return _create(size, fn, 'dense').toArray()\n    },\n    'Array | Matrix, string, function': function (size, format, fn) {\n      return _create(size, fn, format)\n    },\n    'Array | Matrix, string, string, function': function (size, format, datatype, fn) {\n      return _create(size, fn, format, datatype)\n    }\n  })\n\n  function _create (size, fn, format, datatype) {\n    let m\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      const val = fn(index)\n      if (isZero(val)) return\n      m.set(index, val)\n    })\n\n    return m\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromRows'\nconst dependencies = ['typed', 'matrix', 'flatten', 'size']\n\nexport const createMatrixFromRows = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, flatten, size }) => {\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 (arr) {\n      return _createArray(arr)\n    },\n    '...Matrix': function (arr) {\n      return matrix(_createArray(arr.map(m => m.toArray())))\n    }\n\n    // TODO implement this properly for SparseMatrix\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    const N = checkVectorTypeAndReturnLength(arr[0])\n\n    const result = []\n    for (const row of arr) {\n      const 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\n    return result\n  }\n\n  function checkVectorTypeAndReturnLength (vec) {\n    const s = size(vec)\n\n    if (s.length === 1) { // 1D vector\n      return s[0]\n    } else if (s.length === 2) { // 2D vector\n      if (s[0] === 1) { // row vector\n        return s[1]\n      } else if (s[1] === 1) { // 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})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'matrixFromColumns'\nconst dependencies = ['typed', 'matrix', 'flatten', 'size']\n\nexport const createMatrixFromColumns = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, flatten, size }) => {\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 (arr) {\n      return _createArray(arr)\n    },\n    '...Matrix': function (arr) {\n      return matrix(_createArray(arr.map(m => m.toArray())))\n    }\n\n    // TODO implement this properly for SparseMatrix\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    const N = checkVectorTypeAndReturnLength(arr[0])\n\n    // create an array with empty rows\n    const result = []\n    for (let i = 0; i < N; i++) {\n      result[i] = []\n    }\n\n    // loop columns\n    for (const col of arr) {\n      const colLength = checkVectorTypeAndReturnLength(col)\n\n      if (colLength !== N) {\n        throw new TypeError('The vectors had different length: ' + (N | 0) + ' ≠ ' + (colLength | 0))\n      }\n\n      const f = flatten(col)\n\n      // push a value to each row\n      for (let i = 0; i < N; i++) {\n        result[i].push(f[i])\n      }\n    }\n\n    return result\n  }\n\n  function checkVectorTypeAndReturnLength (vec) {\n    const s = size(vec)\n\n    if (s.length === 1) { // 1D vector\n      return s[0]\n    } else if (s.length === 2) { // 2D vector\n      if (s[0] === 1) { // row vector\n        return s[1]\n      } else if (s[1] === 1) { // 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})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'splitUnit'\nconst dependencies = ['typed']\n\nexport const createSplitUnit = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Split a unit in an array of units whose sum is equal to the original unit.\n   *\n   * Syntax:\n   *\n   *     math.splitUnit(unit: Unit, parts: Array.<Unit>)\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 (unit, parts) {\n      return unit.splitUnit(parts)\n    }\n  })\n})\n","import { cbrt, expm1, isInteger, log10, log1p, log2, sign, toFixed } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function absNumber (a) {\n  return Math.abs(a)\n}\nabsNumber.signature = n1\n\nexport function addNumber (a, b) {\n  return a + b\n}\naddNumber.signature = n2\n\nexport function subtractNumber (a, b) {\n  return a - b\n}\nsubtractNumber.signature = n2\n\nexport function multiplyNumber (a, b) {\n  return a * b\n}\nmultiplyNumber.signature = n2\n\nexport function divideNumber (a, b) {\n  return a / b\n}\ndivideNumber.signature = n2\n\nexport function unaryMinusNumber (x) {\n  return -x\n}\nunaryMinusNumber.signature = n1\n\nexport function unaryPlusNumber (x) {\n  return x\n}\nunaryPlusNumber.signature = n1\n\nexport function cbrtNumber (x) {\n  return cbrt(x)\n}\ncbrtNumber.signature = n1\n\nexport function cubeNumber (x) {\n  return x * x * x\n}\ncubeNumber.signature = n1\n\nexport function expNumber (x) {\n  return Math.exp(x)\n}\nexpNumber.signature = n1\n\nexport function expm1Number (x) {\n  return expm1(x)\n}\nexpm1Number.signature = n1\n\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 */\nexport function gcdNumber (a, b) {\n  if (!isInteger(a) || !isInteger(b)) {\n    throw new Error('Parameters in function gcd must be integer numbers')\n  }\n\n  // https://en.wikipedia.org/wiki/Euclidean_algorithm\n  let r\n  while (b !== 0) {\n    r = a % b\n    a = b\n    b = r\n  }\n  return (a < 0) ? -a : a\n}\ngcdNumber.signature = n2\n\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 */\nexport function lcmNumber (a, b) {\n  if (!isInteger(a) || !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  }\n\n  // https://en.wikipedia.org/wiki/Euclidean_algorithm\n  // evaluate lcm here inline to reduce overhead\n  let t\n  const prod = a * b\n  while (b !== 0) {\n    t = b\n    b = a % t\n    a = t\n  }\n  return Math.abs(prod / a)\n}\nlcmNumber.signature = n2\n\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 */\nexport function logNumber (x, y) {\n  if (y) { return Math.log(x) / Math.log(y) }\n  return Math.log(x)\n}\n\n/**\n * Calculate the 10-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\nexport function log10Number (x) {\n  return log10(x)\n}\nlog10Number.signature = n1\n\n/**\n * Calculate the 2-base logarithm of a number\n * @param {number} x\n * @return {number}\n */\nexport function log2Number (x) {\n  return log2(x)\n}\nlog2Number.signature = n1\n\n/**\n * Calculate the natural logarithm of a `number+1`\n * @param {number} x\n * @returns {number}\n */\nexport function log1pNumber (x) {\n  return log1p(x)\n}\nlog1pNumber.signature = n1\n\n/**\n * Calculate the modulus of two numbers\n * @param {number} x\n * @param {number} y\n * @returns {number} res\n * @private\n */\nexport function modNumber (x, y) {\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 (y === 0) ? x : x - y * Math.floor(x / y)\n}\nmodNumber.signature = n2\n\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 */\nexport function nthRootNumber (a, root = 2) {\n  const inv = root < 0\n  if (inv) {\n    root = -root\n  }\n\n  if (root === 0) {\n    throw new Error('Root must be non-zero')\n  }\n  if (a < 0 && (Math.abs(root) % 2 !== 1)) {\n    throw new Error('Root must be odd when a is negative.')\n  }\n\n  // edge cases zero and infinity\n  if (a === 0) {\n    return inv ? Infinity : 0\n  }\n  if (!isFinite(a)) {\n    return inv ? 0 : a\n  }\n\n  let x = Math.pow(Math.abs(a), 1 / root)\n  // If a < 0, we require that root is an odd integer,\n  // so (-1) ^ (1/root) = -1\n  x = a < 0 ? -x : x\n  return inv ? 1 / x : x\n\n  // 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  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\n  if (xPrev !== x) {\n    throw new Error('Function nthRoot failed to converge')\n  }\n\n  return inv ? 1 / x : x\n  */\n}\n\nexport function signNumber (x) {\n  return sign(x)\n}\nsignNumber.signature = n1\n\nexport function sqrtNumber (x) {\n  return Math.sqrt(x)\n}\nsqrtNumber.signature = n1\n\nexport function squareNumber (x) {\n  return x * x\n}\nsquareNumber.signature = n1\n\n/**\n * Calculate xgcd for two numbers\n * @param {number} a\n * @param {number} b\n * @return {number} result\n * @private\n */\nexport function xgcdNumber (a, b) {\n  // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n  let t // used to swap two variables\n  let q // quotient\n  let r // remainder\n  let x = 0\n  let lastx = 1\n  let y = 1\n  let lasty = 0\n\n  if (!isInteger(a) || !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\n    t = x\n    x = lastx - q * x\n    lastx = t\n\n    t = y\n    y = lasty - q * y\n    lasty = t\n\n    a = b\n    b = r\n  }\n\n  let res\n  if (a < 0) {\n    res = [-a, -lastx, -lasty]\n  } else {\n    res = [a, a ? lastx : 0, lasty]\n  }\n  return res\n}\nxgcdNumber.signature = n2\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} res\n */\nexport function 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) ||\n    (x * x > 1 && y === -Infinity)) {\n    return 0\n  }\n\n  return Math.pow(x, y)\n}\npowNumber.signature = n2\n\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 */\nexport function roundNumber (value, decimals = 0) {\n  if (!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  return parseFloat(toFixed(value, decimals))\n}\n\n/**\n * Calculate the norm of a number, the absolute value.\n * @param {number} x\n * @return {number}\n */\nexport function normNumber (x) {\n  return Math.abs(x)\n}\nnormNumber.signature = n1\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { unaryMinusNumber } from '../../plain/number/index.js'\n\nconst name = 'unaryMinus'\nconst dependencies = ['typed']\n\nexport const createUnaryMinus = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | Fraction | Complex | Unit | Array | Matrix} x Number to be inverted.\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Returns the value with inverted sign.\n   */\n  return typed(name, {\n    number: unaryMinusNumber,\n\n    'Complex | BigNumber | Fraction': x => x.neg(),\n\n    bigint: x => -x,\n\n    Unit: typed.referToSelf(self => x => {\n      const res = x.clone()\n      res.value = typed.find(self, res.valueType())(x.value)\n      return res\n    }),\n\n    // deep map collection, skip zeros since unaryMinus(0) = 0\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true))\n\n    // TODO: add support for string\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { unaryPlusNumber } from '../../plain/number/index.js'\nimport { safeNumberType } from '../../utils/number.js'\n\nconst name = 'unaryPlus'\nconst dependencies = ['typed', 'config', 'numeric']\n\nexport const createUnaryPlus = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric }) => {\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 | bigint | Fraction | string | Complex | Unit | Array | Matrix} x\n   *            Input value\n   * @return {number | BigNumber | bigint | 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: unaryPlusNumber,\n\n    Complex: function (x) {\n      return x // complex numbers are immutable\n    },\n\n    BigNumber: function (x) {\n      return x // bignumbers are immutable\n    },\n\n    bigint: function (x) {\n      return x\n    },\n\n    Fraction: function (x) {\n      return x // fractions are immutable\n    },\n\n    Unit: function (x) {\n      return x.clone()\n    },\n\n    // deep map collection, skip zeros since unaryPlus(0) = 0\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)),\n\n    boolean: function (x) {\n      return numeric(x ? 1 : 0, config.number)\n    },\n\n    string: function (x) {\n      return numeric(x, safeNumberType(x, config))\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { absNumber } from '../../plain/number/index.js'\n\nconst name = 'abs'\nconst dependencies = ['typed']\n\nexport const createAbs = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | Fraction | Complex | Array | Matrix | Unit} x\n   *            A number or matrix for which to get the absolute value\n   * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit}\n   *            Absolute value of `x`\n   */\n  return typed(name, {\n    number: absNumber,\n\n    'Complex | BigNumber | Fraction | Unit': x => x.abs(),\n\n    bigint: x => x < 0n ? -x : x,\n\n    // deep map collection, skip zeros since abs(0) = 0\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { arraySize } from '../../utils/array.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { IndexError } from '../../error/IndexError.js'\n\nconst name = 'apply'\nconst dependencies = ['typed', 'isInteger']\n\nexport const createApply = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\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 (mat, dim, callback) {\n      if (!isInteger(dim)) {\n        throw new TypeError('Integer number expected for dimension')\n      }\n\n      const size = Array.isArray(mat) ? arraySize(mat) : mat.size()\n      if (dim < 0 || (dim >= size.length)) {\n        throw new IndexError(dim, size.length)\n      }\n\n      if (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/**\n * Recursively reduce a matrix\n * @param {Array} mat\n * @param {number} dim\n * @param {Function} callback\n * @returns {Array} ret\n * @private\n */\nfunction _apply (mat, dim, callback) {\n  let 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      for (i = 0; i < tran.length; i++) {\n        ret[i] = _apply(tran[i], dim - 1, callback)\n      }\n      return ret\n    }\n  } else {\n    ret = []\n    for (i = 0; i < mat.length; i++) {\n      ret[i] = _apply(mat[i], dim - 1, callback)\n    }\n    return ret\n  }\n}\n\n/**\n * Transpose a matrix\n * @param {Array} mat\n * @returns {Array} ret\n * @private\n */\nfunction _switch (mat) {\n  const I = mat.length\n  const J = mat[0].length\n  let i, j\n  const ret = []\n  for (j = 0; j < J; j++) {\n    const tmp = []\n    for (i = 0; i < I; i++) {\n      tmp.push(mat[i][j])\n    }\n    ret.push(tmp)\n  }\n  return ret\n}\n","import { factory } from '../../utils/factory.js'\nimport { addNumber } from '../../plain/number/index.js'\n\nconst name = 'addScalar'\nconst dependencies = ['typed']\n\nexport const createAddScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | Fraction | Complex | Unit} x   First value to add\n   * @param  {number | BigNumber | bigint | Fraction | Complex} y          Second value to add\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit}     Sum of `x` and `y`\n   * @private\n   */\n  return typed(name, {\n\n    'number, number': addNumber,\n\n    'Complex, Complex': function (x, y) {\n      return x.add(y)\n    },\n\n    'BigNumber, BigNumber': function (x, y) {\n      return x.plus(y)\n    },\n\n    'bigint, bigint': function (x, y) {\n      return x + y\n    },\n\n    'Fraction, Fraction': function (x, y) {\n      return x.add(y)\n    },\n\n    'Unit, Unit': typed.referToSelf(self => (x, y) => {\n      if (x.value === null || x.value === undefined) {\n        throw new Error('Parameter x contains a unit with undefined value')\n      }\n      if (y.value === null || y.value === undefined) {\n        throw new Error('Parameter y contains a unit with undefined value')\n      }\n      if (!x.equalBase(y)) throw new Error('Units do not match')\n\n      const res = x.clone()\n      res.value =\n        typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value)\n      res.fixPrefix = false\n      return res\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { subtractNumber } from '../../plain/number/index.js'\n\nconst name = 'subtractScalar'\nconst dependencies = ['typed']\n\nexport const createSubtractScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Subtract two scalar values, `x - y`.\n   * This function is meant for internal use: it is used by the public function\n   * `subtract`\n   *\n   * This function does not support collections (Array or Matrix).\n   *\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit} x   First value\n   * @param  {number | BigNumber | bigint | Fraction | Complex} y          Second value to be subtracted from `x`\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit}     Difference of `x` and `y`\n   * @private\n   */\n  return typed(name, {\n\n    'number, number': subtractNumber,\n\n    'Complex, Complex': function (x, y) {\n      return x.sub(y)\n    },\n\n    'BigNumber, BigNumber': function (x, y) {\n      return x.minus(y)\n    },\n\n    'bigint, bigint': function (x, y) {\n      return x - y\n    },\n\n    'Fraction, Fraction': function (x, y) {\n      return x.sub(y)\n    },\n\n    'Unit, Unit': typed.referToSelf(self => (x, y) => {\n      if (x.value === null || x.value === undefined) {\n        throw new Error('Parameter x contains a unit with undefined value')\n      }\n      if (y.value === null || y.value === undefined) {\n        throw new Error('Parameter y contains a unit with undefined value')\n      }\n      if (!x.equalBase(y)) throw new Error('Units do not match')\n\n      const res = x.clone()\n      res.value =\n        typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value)\n      res.fixPrefix = false\n      return res\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isBigNumber, isComplex, isFraction } from '../../utils/is.js'\nimport { cbrtNumber } from '../../plain/number/index.js'\n\nconst name = 'cbrt'\nconst dependencies = [\n  'config',\n  'typed',\n  'isNegative',\n  'unaryMinus',\n  'matrix',\n  'Complex',\n  'BigNumber',\n  'Fraction'\n]\n\nexport const createCbrt = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, isNegative, unaryMinus, matrix, Complex, BigNumber, Fraction }) => {\n  /**\n   * Calculate the cubic root of a value.\n   *\n   * To avoid confusion with the matrix cube root, this function does not\n   * apply to matrices. For a matrix, to take the cube root elementwise,\n   * see the examples.\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.map([27, 64, 125], x => math.cbrt(x))       // 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} 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}\n   *            Returns the cubic root of `x`\n   */\n  return typed(name, {\n    number: cbrtNumber,\n    // note: signature 'number, boolean' is also supported,\n    //       created by typed as it knows how to convert number to Complex\n\n    Complex: _cbrtComplex,\n\n    'Complex, boolean': _cbrtComplex,\n\n    BigNumber: function (x) {\n      return x.cbrt()\n    },\n\n    Unit: _cbrtUnit\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.<Complex> | Matrix.<Complex>} Returns the cubic root(s) of x\n   * @private\n   */\n  function _cbrtComplex (x, allRoots) {\n    // https://www.wikiwand.com/en/Cube_root#/Complex_numbers\n\n    const arg3 = x.arg() / 3\n    const abs = x.abs()\n\n    // principal root:\n    const principal = new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3).exp())\n\n    if (allRoots) {\n      const all = [\n        principal,\n        new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 + Math.PI * 2 / 3).exp()),\n        new Complex(cbrtNumber(abs), 0).mul(new Complex(0, arg3 - Math.PI * 2 / 3).exp())\n      ]\n\n      return (config.matrix === 'Array') ? all : matrix(all)\n    } else {\n      return principal\n    }\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  function _cbrtUnit (x) {\n    if (x.value && isComplex(x.value)) {\n      let result = x.clone()\n      result.value = 1.0\n      result = result.pow(1.0 / 3) // Compute the units\n      result.value = _cbrtComplex(x.value) // Compute the value\n      return result\n    } else {\n      const negate = isNegative(x.value)\n      if (negate) {\n        x.value = unaryMinus(x.value)\n      }\n\n      // TODO: create a helper function for this\n      let third\n      if (isBigNumber(x.value)) {\n        third = new BigNumber(1).div(3)\n      } else if (isFraction(x.value)) {\n        third = new Fraction(1, 3)\n      } else {\n        third = 1 / 3\n      }\n\n      const result = x.pow(third)\n\n      if (negate) {\n        result.value = unaryMinus(result.value)\n      }\n\n      return result\n    }\n  }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo11xS0s'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo11xS0s = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 matAlgo11xS0s (s, b, callback, inverse) {\n    // sparse matrix arrays\n    const avalues = s._values\n    const aindex = s._index\n    const aptr = s._ptr\n    const asize = s._size\n    const adt = s._datatype\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // convert b to the same datatype\n      b = typed.convert(b, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // initialize ptr\n      cptr[j] = cindex.length\n      // values in j\n      for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        const i = aindex[k]\n        // invoke callback\n        const v = inverse ? cf(b, avalues[k]) : cf(avalues[k], b)\n        // check value is zero\n        if (!eq(v, zero)) {\n          // push index & value\n          cindex.push(i)\n          cvalues.push(v)\n        }\n      }\n    }\n    // update ptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return s.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: dt\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo12xSfs'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo12xSfs = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\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 matAlgo12xSfs (s, b, callback, inverse) {\n    // sparse matrix arrays\n    const avalues = s._values\n    const aindex = s._index\n    const aptr = s._ptr\n    const asize = s._size\n    const adt = s._datatype\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string') {\n      // datatype\n      dt = adt\n      // convert b to the same datatype\n      b = typed.convert(b, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cdata = []\n\n    // workspaces\n    const x = []\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // columns mark\n      const mark = j + 1\n      // values in j\n      for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        const r = aindex[k]\n        // update workspace\n        x[r] = avalues[k]\n        w[r] = mark\n      }\n      // loop rows\n      for (let i = 0; i < rows; i++) {\n        // initialize C on first column\n        if (j === 0) {\n          // create row array\n          cdata[i] = []\n        }\n        // check sparse matrix has a value @ i,j\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    }\n\n    // return dense matrix\n    return new DenseMatrix({\n      data: cdata,\n      size: [rows, columns],\n      datatype: dt\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { clone } from '../../../utils/object.js'\n\nconst name = 'matAlgo14xDs'\nconst dependencies = ['typed']\n\nexport const createMatAlgo14xDs = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 matAlgo14xDs (a, b, callback, inverse) {\n    // a arrays\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype\n\n    // datatype\n    let dt\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string') {\n      // datatype\n      dt = adt\n      // convert b to the same datatype\n      b = typed.convert(b, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // populate cdata, iterate through dimensions\n    const cdata = asize.length > 0 ? _iterate(cf, 0, asize, asize[0], adata, b, inverse) : []\n\n    // c matrix\n    return a.createDenseMatrix({\n      data: cdata,\n      size: clone(asize),\n      datatype: dt\n    })\n  }\n\n  // recursive function\n  function _iterate (f, level, s, n, av, bv, inverse) {\n    // initialize array for this level\n    const cv = []\n    // check we reach the last level\n    if (level === s.length - 1) {\n      // loop arrays in last level\n      for (let 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 (let 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    return cv\n  }\n})\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'ceil'\nconst dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createCeilNumber = /* #__PURE__ */ factory(\n  name, ['typed', 'config', 'round'], ({ typed, config, round }) => {\n    return typed(name, {\n      number: function (x) {\n        if (nearlyEqual(x, round(x), config.relTol, config.absTol)) {\n          return round(x)\n        } else {\n          return Math.ceil(x)\n        }\n      },\n\n      'number, number': function (x, n) {\n        if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n          return round(x, n)\n        } else {\n          let [number, exponent] = `${x}e`.split('e')\n          const result = Math.ceil(Number(`${number}e${Number(exponent) + n}`));\n          [number, exponent] = `${result}e`.split('e')\n          return Number(`${number}e${Number(exponent) - n}`)\n        }\n      }\n    })\n  }\n)\n\nexport const createCeil = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix }) => {\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n  const ceilNumber = createCeilNumber({ typed, config, round })\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  return typed('ceil', {\n    number: ceilNumber.signatures.number,\n    'number,number': ceilNumber.signatures['number,number'],\n\n    Complex: function (x) {\n      return x.ceil()\n    },\n\n    'Complex, number': function (x, n) {\n      return x.ceil(n)\n    },\n\n    'Complex, BigNumber': function (x, n) {\n      return x.ceil(n.toNumber())\n    },\n\n    BigNumber: function (x) {\n      if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) {\n        return round(x)\n      } else {\n        return x.ceil()\n      }\n    },\n\n    'BigNumber, BigNumber': function (x, n) {\n      if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n        return round(x, n)\n      } else {\n        return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_CEIL)\n      }\n    },\n\n    Fraction: function (x) {\n      return x.ceil()\n    },\n\n    'Fraction, number': function (x, n) {\n      return x.ceil(n)\n    },\n\n    'Fraction, BigNumber': function (x, n) {\n      return x.ceil(n.toNumber())\n    },\n\n    'Array | Matrix': typed.referToSelf(self => (x) => {\n      // deep map collection, skip zeros since ceil(0) = 0\n      return deepMap(x, self, true)\n    }),\n\n    'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      // deep map collection, skip zeros since ceil(0) = 0\n      return deepMap(x, i => self(i, n), true)\n    }),\n\n    'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n      return matAlgo11xS0s(x, y, self, false)\n    }),\n\n    'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n      return matAlgo14xDs(x, y, self, false)\n    }),\n\n    'number | Complex | Fraction | BigNumber, Array':\n      typed.referToSelf(self => (x, y) => {\n        // use matrix implementation\n        return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n      }),\n\n    'number | Complex | Fraction | BigNumber, Matrix':\n      typed.referToSelf(self => (x, y) => {\n        if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n        if (y.storage() === 'dense') {\n          return matAlgo14xDs(y, x, self, true)\n        }\n        return matAlgo12xSfs(y, x, self, true)\n      })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cubeNumber } from '../../plain/number/index.js'\n\nconst name = 'cube'\nconst dependencies = ['typed']\n\nexport const createCube = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Compute the cube of a value, `x * x * x`.\n   * To avoid confusion with `pow(M,3)`, this function does not apply to matrices.\n   * If you wish to cube every entry of a matrix, see the examples.\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.map([1, 2, 3, 4], math.cube) // returns Array [1, 8, 27, 64]\n   *\n   * See also:\n   *\n   *    multiply, square, pow, cbrt\n   *\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit} x  Number for which to calculate the cube\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit} Cube of x\n   */\n  return typed(name, {\n    number: cubeNumber,\n\n    Complex: function (x) {\n      return x.mul(x).mul(x) // Is faster than pow(x, 3)\n    },\n\n    BigNumber: function (x) {\n      return x.times(x).times(x)\n    },\n\n    bigint: function (x) {\n      return x * x * x\n    },\n\n    Fraction: function (x) {\n      return x.pow(3) // Is faster than mul()mul()mul()\n    },\n\n    Unit: function (x) {\n      return x.pow(3)\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { expNumber } from '../../plain/number/index.js'\n\nconst name = 'exp'\nconst dependencies = ['typed']\n\nexport const createExp = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the exponential of a value.\n   * For matrices, if you want the matrix exponential of square matrix, use\n   * the `expm` function; if you want to take the exponential of each element,\n   * see the examples.\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.map([1, 2, 3], math.exp)\n   *    // returns Array [\n   *    //   2.718281828459045,\n   *    //   7.3890560989306495,\n   *    //   20.085536923187668\n   *    // ]\n   *\n   * See also:\n   *\n   *    expm1, expm, log, pow\n   *\n   * @param {number | BigNumber | Complex} x  A number to exponentiate\n   * @return {number | BigNumber | Complex} Exponential of `x`\n   */\n  return typed(name, {\n    number: expNumber,\n\n    Complex: function (x) {\n      return x.exp()\n    },\n\n    BigNumber: function (x) {\n      return x.exp()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { expm1Number } from '../../plain/number/index.js'\n\nconst name = 'expm1'\nconst dependencies = ['typed', 'Complex']\n\nexport const createExpm1 = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex }) => {\n  /**\n   * Calculate the value of subtracting 1 from the exponential value.\n   * This function is more accurate than `math.exp(x)-1` when `x` is near 0\n   * To avoid ambiguity with the matrix exponential `expm`, this function\n   * does not operate on matrices; if you wish to apply it elementwise, see\n   * the examples.\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.expm1(1e-8)                   // returns number 1.0000000050000001e-8\n   *    math.exp(1e-8) - 1                 // returns number 9.9999999392253e-9\n   *    math.log(math.expm1(2) + 1)        // returns number 2\n   *\n   *    math.map([1, 2, 3], math.expm1)\n   *    // returns Array [\n   *    //   1.718281828459045,\n   *    //   6.3890560989306495,\n   *    //   19.085536923187668\n   *    // ]\n   *\n   * See also:\n   *\n   *    exp, expm, log, pow\n   *\n   * @param {number | BigNumber | Complex} x  The number to exponentiate\n   * @return {number | BigNumber | Complex} Exponential of `x`, minus one\n   */\n  return typed(name, {\n    number: expm1Number,\n\n    Complex: function (x) {\n      const r = Math.exp(x.re)\n      return new Complex(\n        r * Math.cos(x.im) - 1,\n        r * Math.sin(x.im)\n      )\n    },\n\n    BigNumber: function (x) {\n      return x.exp().minus(1)\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'fix'\nconst dependencies = ['typed', 'Complex', 'matrix', 'ceil', 'floor', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createFixNumber = /* #__PURE__ */ factory(\n  name, ['typed', 'ceil', 'floor'], ({ typed, ceil, floor }) => {\n    return typed(name, {\n      number: function (x) {\n        return (x > 0) ? floor(x) : ceil(x)\n      },\n\n      'number, number': function (x, n) {\n        return (x > 0) ? floor(x, n) : ceil(x, n)\n      }\n    })\n  }\n)\n\nexport const createFix = /* #__PURE__ */ factory(name, dependencies, ({ typed, Complex, matrix, ceil, floor, equalScalar, zeros, DenseMatrix }) => {\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n  const fixNumber = createFixNumber({ typed, ceil, floor })\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  return typed('fix', {\n    number: fixNumber.signatures.number,\n    'number, number | BigNumber': fixNumber.signatures['number,number'],\n\n    Complex: function (x) {\n      return new Complex(\n        (x.re > 0) ? Math.floor(x.re) : Math.ceil(x.re),\n        (x.im > 0) ? Math.floor(x.im) : Math.ceil(x.im)\n      )\n    },\n\n    'Complex, number': function (x, n) {\n      return new Complex(\n        (x.re > 0) ? floor(x.re, n) : ceil(x.re, n),\n        (x.im > 0) ? floor(x.im, n) : ceil(x.im, n)\n      )\n    },\n\n    'Complex, BigNumber': function (x, bn) {\n      const n = bn.toNumber()\n      return new Complex(\n        (x.re > 0) ? floor(x.re, n) : ceil(x.re, n),\n        (x.im > 0) ? floor(x.im, n) : ceil(x.im, n)\n      )\n    },\n\n    BigNumber: function (x) {\n      return x.isNegative() ? ceil(x) : floor(x)\n    },\n\n    'BigNumber, number | BigNumber': function (x, n) {\n      return x.isNegative() ? ceil(x, n) : floor(x, n)\n    },\n\n    Fraction: function (x) {\n      return x.s < 0 ? x.ceil() : x.floor()\n    },\n\n    'Fraction, number | BigNumber': function (x, n) {\n      return x.s < 0 ? ceil(x, n) : floor(x, n)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => (x) => {\n      // deep map collection, skip zeros since fix(0) = 0\n      return deepMap(x, self, true)\n    }),\n\n    'Array | Matrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      // deep map collection, skip zeros since fix(0) = 0\n      return deepMap(x, i => self(i, n), true)\n    }),\n\n    'number | Complex | Fraction | BigNumber, Array':\n      typed.referToSelf(self => (x, y) => {\n        // use matrix implementation\n        return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n      }),\n\n    'number | Complex | Fraction | BigNumber, Matrix':\n      typed.referToSelf(self => (x, y) => {\n        if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n        if (y.storage() === 'dense') {\n          return matAlgo14xDs(y, x, self, true)\n        }\n        return matAlgo12xSfs(y, x, self, true)\n      })\n  })\n})\n","import Decimal from 'decimal.js'\nimport { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'floor'\nconst dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix']\n\nexport const createFloorNumber = /* #__PURE__ */ factory(\n  name, ['typed', 'config', 'round'], ({ typed, config, round }) => {\n    return typed(name, {\n      number: function (x) {\n        if (nearlyEqual(x, round(x), config.relTol, config.absTol)) {\n          return round(x)\n        } else {\n          return Math.floor(x)\n        }\n      },\n\n      'number, number': function (x, n) {\n        if (nearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n          return round(x, n)\n        } else {\n          let [number, exponent] = `${x}e`.split('e')\n          const result = Math.floor(Number(`${number}e${Number(exponent) + n}`));\n          [number, exponent] = `${result}e`.split('e')\n          return Number(`${number}e${Number(exponent) - n}`)\n        }\n      }\n    })\n  }\n)\n\nexport const createFloor = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix }) => {\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n  const floorNumber = createFloorNumber({ typed, config, round })\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  return typed('floor', {\n    number: floorNumber.signatures.number,\n    'number,number': floorNumber.signatures['number,number'],\n\n    Complex: function (x) {\n      return x.floor()\n    },\n\n    'Complex, number': function (x, n) {\n      return x.floor(n)\n    },\n\n    'Complex, BigNumber': function (x, n) {\n      return x.floor(n.toNumber())\n    },\n\n    BigNumber: function (x) {\n      if (bigNearlyEqual(x, round(x), config.relTol, config.absTol)) {\n        return round(x)\n      } else {\n        return x.floor()\n      }\n    },\n\n    'BigNumber, BigNumber': function (x, n) {\n      if (bigNearlyEqual(x, round(x, n), config.relTol, config.absTol)) {\n        return round(x, n)\n      } else {\n        return x.toDecimalPlaces(n.toNumber(), Decimal.ROUND_FLOOR)\n      }\n    },\n\n    Fraction: function (x) {\n      return x.floor()\n    },\n\n    'Fraction, number': function (x, n) {\n      return x.floor(n)\n    },\n\n    'Fraction, BigNumber': function (x, n) {\n      return x.floor(n.toNumber())\n    },\n\n    'Array | Matrix': typed.referToSelf(self => (x) => {\n      // deep map collection, skip zeros since floor(0) = 0\n      return deepMap(x, self, true)\n    }),\n\n    'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      // deep map collection, skip zeros since ceil(0) = 0\n      return deepMap(x, i => self(i, n), true)\n    }),\n\n    'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n      return matAlgo11xS0s(x, y, self, false)\n    }),\n\n    'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n      return matAlgo14xDs(x, y, self, false)\n    }),\n\n    'number | Complex | Fraction | BigNumber, Array':\n      typed.referToSelf(self => (x, y) => {\n        // use matrix implementation\n        return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n      }),\n\n    'number | Complex | Fraction | BigNumber, Matrix':\n      typed.referToSelf(self => (x, y) => {\n        if (equalScalar(x, 0)) return zeros(y.size(), y.storage())\n        if (y.storage() === 'dense') {\n          return matAlgo14xDs(y, x, self, true)\n        }\n        return matAlgo12xSfs(y, x, self, true)\n      })\n  })\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo02xDS0'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo02xDS0 = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 matAlgo02xDS0 (denseMatrix, sparseMatrix, callback, inverse) {\n    // dense matrix arrays\n    const adata = denseMatrix._data\n    const asize = denseMatrix._size\n    const adt = denseMatrix._datatype || denseMatrix.getDataType()\n    // sparse matrix arrays\n    const bvalues = sparseMatrix._values\n    const bindex = sparseMatrix._index\n    const bptr = sparseMatrix._ptr\n    const bsize = sparseMatrix._size\n    const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result (SparseMatrix)\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n\n    // loop columns in b\n    for (let j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // values in column j\n      for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        const i = bindex[k]\n        // update C(i,j)\n        const cij = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n        // check for nonzero\n        if (!eq(cij, zero)) {\n          // push i & v\n          cindex.push(i)\n          cvalues.push(cij)\n        }\n      }\n    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return sparseMatrix.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo03xDSf'\nconst dependencies = ['typed']\n\nexport const createMatAlgo03xDSf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 matAlgo03xDSf (denseMatrix, sparseMatrix, callback, inverse) {\n    // dense matrix arrays\n    const adata = denseMatrix._data\n    const asize = denseMatrix._size\n    const adt = denseMatrix._datatype || denseMatrix.getDataType()\n    // sparse matrix arrays\n    const bvalues = sparseMatrix._values\n    const bindex = sparseMatrix._index\n    const bptr = sparseMatrix._ptr\n    const bsize = sparseMatrix._size\n    const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result (DenseMatrix)\n    const cdata = []\n\n    // initialize dense matrix\n    for (let z = 0; z < rows; z++) {\n      // initialize row\n      cdata[z] = []\n    }\n\n    // workspace\n    const x = []\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // loop columns in b\n    for (let j = 0; j < columns; j++) {\n      // column mark\n      const mark = j + 1\n      // values in column j\n      for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        const i = bindex[k]\n        // update workspace\n        x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n        w[i] = mark\n      }\n      // process workspace\n      for (let 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    }\n\n    // return dense matrix\n    return denseMatrix.createDenseMatrix({\n      data: cdata,\n      size: [rows, columns],\n      datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo05xSfSf'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo05xSfSf = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 matAlgo05xSfSf (a, b, callback) {\n    // sparse matrix arrays\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = avalues && bvalues ? [] : undefined\n    const cindex = []\n    const cptr = []\n\n    // workspaces\n    const xa = cvalues ? [] : undefined\n    const xb = cvalues ? [] : undefined\n    // marks indicating we have a value in x for a given column\n    const wa = []\n    const wb = []\n\n    // vars\n    let i, j, k, k1\n\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // columns mark\n      const mark = j + 1\n      // loop values A(:,j)\n      for (k = aptr[j], k1 = aptr[j + 1]; k < k1; k++) {\n        // row\n        i = aindex[k]\n        // push index\n        cindex.push(i)\n        // update workspace\n        wa[i] = mark\n        // check we need to process values\n        if (xa) { xa[i] = avalues[k] }\n      }\n      // loop values B(:,j)\n      for (k = bptr[j], k1 = bptr[j + 1]; k < k1; k++) {\n        // row\n        i = bindex[k]\n        // check row existed in A\n        if (wa[i] !== mark) {\n          // push index\n          cindex.push(i)\n        }\n        // update workspace\n        wb[i] = mark\n        // check we need to process values\n        if (xb) { xb[i] = bvalues[k] }\n      }\n      // check we need to process values (non pattern matrix)\n      if (cvalues) {\n        // initialize first index in j\n        k = cptr[j]\n        // loop index in j\n        while (k < cindex.length) {\n          // row\n          i = cindex[k]\n          // marks\n          const wai = wa[i]\n          const wbi = wb[i]\n          // check Aij or Bij are nonzero\n          if (wai === mark || wbi === mark) {\n            // matrix values @ i,j\n            const va = wai === mark ? xa[i] : zero\n            const vb = wbi === mark ? xb[i] : zero\n            // Cij\n            const vc = cf(va, vb)\n            // check for zero\n            if (!eq(vc, zero)) {\n              // push value\n              cvalues.push(vc)\n              // increment pointer\n              k++\n            } else {\n              // remove value @ i, do not increment pointer\n              cindex.splice(k, 1)\n            }\n          }\n        }\n      }\n    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo13xDD'\nconst dependencies = ['typed']\n\nexport const createMatAlgo13xDD = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 matAlgo13xDD (a, b, callback) {\n    // a arrays\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype\n    // b arrays\n    const bdata = b._data\n    const bsize = b._size\n    const bdt = b._datatype\n    // c arrays\n    const csize = []\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // validate each one of the dimension sizes\n    for (let s = 0; s < asize.length; s++) {\n      // must match\n      if (asize[s] !== bsize[s]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n      // update dimension in c\n      csize[s] = asize[s]\n    }\n\n    // datatype\n    let dt\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt) {\n      // datatype\n      dt = adt\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // populate cdata, iterate through dimensions\n    const cdata = csize.length > 0 ? _iterate(cf, 0, csize, csize[0], adata, bdata) : []\n\n    // c matrix\n    return a.createDenseMatrix({\n      data: cdata,\n      size: csize,\n      datatype: dt\n    })\n  }\n\n  // recursive function\n  function _iterate (f, level, s, n, av, bv) {\n    // initialize array for this level\n    const cv = []\n    // check we reach the last level\n    if (level === s.length - 1) {\n      // loop arrays in last level\n      for (let 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 (let 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    return cv\n  }\n})\n","import { broadcastSizes, broadcastTo } from '../../../utils/array.js'\nimport { deepStrictEqual } from '../../../utils/object.js'\n\n/**\n* Broadcasts two matrices, and return both in an array\n* It checks if it's possible with broadcasting rules\n*\n* @param {Matrix}   A      First Matrix\n* @param {Matrix}   B      Second Matrix\n*\n* @return {Matrix[]}      [ broadcastedA, broadcastedB ]\n*/\n\nexport function broadcast (A, B) {\n  if (deepStrictEqual(A.size(), B.size())) {\n    // If matrices have the same size return them\n    return [A, B]\n  }\n\n  // calculate the broadcasted sizes\n  const newSize = broadcastSizes(A.size(), B.size())\n\n  // return the array with the two broadcasted matrices\n  return [A, B].map(M => _broadcastTo(M, newSize))\n}\n\n/**\n * Broadcasts a matrix to the given size.\n *\n * @param {Matrix} M - The matrix to be broadcasted.\n * @param {number[]} size - The desired size of the broadcasted matrix.\n * @returns {Matrix} The broadcasted matrix.\n * @throws {Error} If the size parameter is not an array of numbers.\n */\nfunction _broadcastTo (M, size) {\n  if (deepStrictEqual(M.size(), size)) {\n    return M\n  }\n  return M.create(broadcastTo(M.valueOf(), size), M.datatype())\n}\n","import { factory } from '../../../utils/factory.js'\nimport { extend } from '../../../utils/object.js'\nimport { createMatAlgo13xDD } from './matAlgo13xDD.js'\nimport { createMatAlgo14xDs } from './matAlgo14xDs.js'\nimport { broadcast } from './broadcast.js'\n\nconst name = 'matrixAlgorithmSuite'\nconst dependencies = ['typed', 'matrix']\n\nexport const createMatrixAlgorithmSuite = /* #__PURE__ */ factory(\n  name, dependencies, ({ typed, matrix }) => {\n    const matAlgo13xDD = createMatAlgo13xDD({ typed })\n    const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n    /**\n     * Return a signatures object with the usual boilerplate of\n     * matrix algorithms, based on a plain options object with the\n     * following properties:\n     *   elop: function -- the elementwise operation to use, defaults to self\n     *   SS: function -- the algorithm to apply for two sparse matrices\n     *   DS: function -- the algorithm to apply for a dense and a sparse matrix\n     *   SD: function -- algo for a sparse and a dense; defaults to SD flipped\n     *   Ss: function -- the algorithm to apply for a sparse matrix and scalar\n     *   sS: function -- algo for scalar and sparse; defaults to Ss flipped\n     *   scalar: string -- typed-function type for scalars, defaults to 'any'\n     *\n     * If Ss is not specified, no matrix-scalar signatures are generated.\n     *\n     * @param {object} options\n     * @return {Object<string, function>} signatures\n     */\n    return function matrixAlgorithmSuite (options) {\n      const elop = options.elop\n      const SD = options.SD || options.DS\n      let matrixSignatures\n      if (elop) {\n        // First the dense ones\n        matrixSignatures = {\n          'DenseMatrix, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(x, y), elop),\n          'Array, Array': (x, y) =>\n            matAlgo13xDD(...broadcast(matrix(x), matrix(y)), elop).valueOf(),\n          'Array, DenseMatrix': (x, y) => matAlgo13xDD(...broadcast(matrix(x), y), elop),\n          'DenseMatrix, Array': (x, y) => matAlgo13xDD(...broadcast(x, matrix(y)), elop)\n        }\n        // Now incorporate sparse matrices\n        if (options.SS) {\n          matrixSignatures['SparseMatrix, SparseMatrix'] =\n            (x, y) => options.SS(...broadcast(x, y), elop, false)\n        }\n        if (options.DS) {\n          matrixSignatures['DenseMatrix, SparseMatrix'] =\n            (x, y) => options.DS(...broadcast(x, y), elop, false)\n          matrixSignatures['Array, SparseMatrix'] =\n            (x, y) => options.DS(...broadcast(matrix(x), y), elop, false)\n        }\n        if (SD) {\n          matrixSignatures['SparseMatrix, DenseMatrix'] =\n            (x, y) => SD(...broadcast(y, x), elop, true)\n          matrixSignatures['SparseMatrix, Array'] =\n            (x, y) => SD(...broadcast(matrix(y), x), elop, true)\n        }\n      } else {\n        // No elop, use this\n        // First the dense ones\n        matrixSignatures = {\n          'DenseMatrix, DenseMatrix': typed.referToSelf(self => (x, y) => {\n            return matAlgo13xDD(...broadcast(x, y), self)\n          }),\n          'Array, Array': typed.referToSelf(self => (x, y) => {\n            return matAlgo13xDD(...broadcast(matrix(x), matrix(y)), self).valueOf()\n          }),\n          'Array, DenseMatrix': typed.referToSelf(self => (x, y) => {\n            return matAlgo13xDD(...broadcast(matrix(x), y), self)\n          }),\n          'DenseMatrix, Array': typed.referToSelf(self => (x, y) => {\n            return matAlgo13xDD(...broadcast(x, matrix(y)), self)\n          })\n        }\n        // Now incorporate sparse matrices\n        if (options.SS) {\n          matrixSignatures['SparseMatrix, SparseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return options.SS(...broadcast(x, y), self, false)\n            })\n        }\n        if (options.DS) {\n          matrixSignatures['DenseMatrix, SparseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return options.DS(...broadcast(x, y), self, false)\n            })\n          matrixSignatures['Array, SparseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return options.DS(...broadcast(matrix(x), y), self, false)\n            })\n        }\n        if (SD) {\n          matrixSignatures['SparseMatrix, DenseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return SD(...broadcast(y, x), self, true)\n            })\n          matrixSignatures['SparseMatrix, Array'] =\n            typed.referToSelf(self => (x, y) => {\n              return SD(...broadcast(matrix(y), x), self, true)\n            })\n        }\n      }\n\n      // Now add the scalars\n      const scalar = options.scalar || 'any'\n      const Ds = options.Ds || options.Ss\n      if (Ds) {\n        if (elop) {\n          matrixSignatures['DenseMatrix,' + scalar] =\n            (x, y) => matAlgo14xDs(x, y, elop, false)\n          matrixSignatures[scalar + ', DenseMatrix'] =\n            (x, y) => matAlgo14xDs(y, x, elop, true)\n          matrixSignatures['Array,' + scalar] =\n            (x, y) => matAlgo14xDs(matrix(x), y, elop, false).valueOf()\n          matrixSignatures[scalar + ', Array'] =\n            (x, y) => matAlgo14xDs(matrix(y), x, elop, true).valueOf()\n        } else {\n          matrixSignatures['DenseMatrix,' + scalar] =\n            typed.referToSelf(self => (x, y) => {\n              return matAlgo14xDs(x, y, self, false)\n            })\n          matrixSignatures[scalar + ', DenseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return matAlgo14xDs(y, x, self, true)\n            })\n          matrixSignatures['Array,' + scalar] =\n            typed.referToSelf(self => (x, y) => {\n              return matAlgo14xDs(matrix(x), y, self, false).valueOf()\n            })\n          matrixSignatures[scalar + ', Array'] =\n            typed.referToSelf(self => (x, y) => {\n              return matAlgo14xDs(matrix(y), x, self, true).valueOf()\n            })\n        }\n      }\n      const sS = (options.sS !== undefined) ? options.sS : options.Ss\n      if (elop) {\n        if (options.Ss) {\n          matrixSignatures['SparseMatrix,' + scalar] =\n            (x, y) => options.Ss(x, y, elop, false)\n        }\n        if (sS) {\n          matrixSignatures[scalar + ', SparseMatrix'] =\n            (x, y) => sS(y, x, elop, true)\n        }\n      } else {\n        if (options.Ss) {\n          matrixSignatures['SparseMatrix,' + scalar] =\n            typed.referToSelf(self => (x, y) => {\n              return options.Ss(x, y, self, false)\n            })\n        }\n        if (sS) {\n          matrixSignatures[scalar + ', SparseMatrix'] =\n            typed.referToSelf(self => (x, y) => {\n              return sS(y, x, self, true)\n            })\n        }\n      }\n      // Also pull in the scalar signatures if the operator is a typed function\n      if (elop && elop.signatures) {\n        extend(matrixSignatures, elop.signatures)\n      }\n      return matrixSignatures\n    }\n  })\n","import { factory } from '../../utils/factory.js'\nimport { createFloor } from './floor.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'mod'\nconst dependencies = [\n  'typed',\n  'config',\n  'round',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createMod = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n  const floor = createFloor({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix })\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Fraction | Array | Matrix} x Dividend\n   * @param  {number | BigNumber | bigint | Fraction | Array | Matrix} y Divisor\n   * @return {number | BigNumber | bigint | Fraction | Array | Matrix} Returns the remainder of `x` divided by `y`.\n   */\n  return typed(\n    name,\n    {\n      'number, number': _modNumber,\n\n      'BigNumber, BigNumber': function (x, y) {\n        return y.isZero() ? x : x.sub(y.mul(floor(x.div(y))))\n      },\n\n      'bigint, bigint': function (x, y) {\n        if (y === 0n) {\n          return x\n        }\n\n        if (x < 0) {\n          const m = x % y\n          return m === 0n ? m : m + y\n        }\n\n        return x % y\n      },\n\n      'Fraction, Fraction': function (x, y) {\n        return y.equals(0) ? x : x.sub(y.mul(floor(x.div(y))))\n      }\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo05xSfSf,\n      DS: matAlgo03xDSf,\n      SD: matAlgo02xDS0,\n      Ss: matAlgo11xS0s,\n      sS: matAlgo12xSfs\n    })\n  )\n\n  /**\n * Calculate the modulus of two numbers\n * @param {number} x\n * @param {number} y\n * @returns {number} res\n * @private\n */\n  function _modNumber (x, y) {\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\n    // We use mathjs floor to handle errors associated with\n    // precision float approximation\n    return (y === 0) ? x : x - y * floor(x / y)\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo01xDSid'\nconst dependencies = ['typed']\n\nexport const createMatAlgo01xDSid = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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    const adata = denseMatrix._data\n    const asize = denseMatrix._size\n    const adt = denseMatrix._datatype || denseMatrix.getDataType()\n    // sparse matrix arrays\n    const bvalues = sparseMatrix._values\n    const bindex = sparseMatrix._index\n    const bptr = sparseMatrix._ptr\n    const bsize = sparseMatrix._size\n    const bdt = sparseMatrix._datatype || sparseMatrix._data === undefined ? sparseMatrix._datatype : sparseMatrix.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!bvalues) { throw new Error('Cannot perform operation on Dense Matrix and Pattern Sparse Matrix') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // process data types\n    const dt = typeof adt === 'string' && adt !== 'mixed' && adt === bdt ? adt : undefined\n    // callback function\n    const cf = dt ? typed.find(callback, [dt, dt]) : callback\n\n    // vars\n    let i, j\n\n    // result (DenseMatrix)\n    const cdata = []\n    // initialize c\n    for (i = 0; i < rows; i++) { cdata[i] = [] }\n\n    // workspace\n    const x = []\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // loop columns in b\n    for (j = 0; j < columns; j++) {\n      // column mark\n      const mark = j + 1\n      // values in column j\n      for (let k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = bindex[k]\n        // update workspace\n        x[i] = inverse ? cf(bvalues[k], adata[i][j]) : cf(adata[i][j], bvalues[k])\n        // mark i as updated\n        w[i] = mark\n      }\n      // loop rows\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    }\n\n    // return dense matrix\n    return denseMatrix.createDenseMatrix({\n      data: cdata,\n      size: [rows, columns],\n      datatype: adt === denseMatrix._datatype && bdt === sparseMatrix._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo04xSidSid'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo04xSidSid = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 && B(i,j) === 0\n   *          └  B(i,j)       ; A(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 matAlgo04xSidSid (a, b, callback) {\n    // sparse matrix arrays\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = avalues && bvalues ? [] : undefined\n    const cindex = []\n    const cptr = []\n\n    // workspace\n    const xa = avalues && bvalues ? [] : undefined\n    const xb = avalues && bvalues ? [] : undefined\n    // marks indicating we have a value in x for a given column\n    const wa = []\n    const wb = []\n\n    // vars\n    let i, j, k, k0, k1\n\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // columns mark\n      const mark = j + 1\n      // loop A(:,j)\n      for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = aindex[k]\n        // update c\n        cindex.push(i)\n        // update workspace\n        wa[i] = mark\n        // check we need to process values\n        if (xa) { xa[i] = avalues[k] }\n      }\n      // loop B(:,j)\n      for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = bindex[k]\n        // check row exists in A\n        if (wa[i] === mark) {\n          // update record in xa @ i\n          if (xa) {\n            // invoke callback\n            const v = cf(xa[i], bvalues[k])\n            // check for zero\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)\n          // update workspace\n          wb[i] = mark\n          // check we need to process values\n          if (xb) { xb[i] = bvalues[k] }\n        }\n      }\n      // check we need to process values (non pattern matrix)\n      if (xa && xb) {\n        // initialize first index in j\n        k = cptr[j]\n        // loop index in j\n        while (k < cindex.length) {\n          // row\n          i = cindex[k]\n          // check workspace has value @ i\n          if (wa[i] === mark) {\n            // push value (Aij != 0 || (Aij != 0 && Bij != 0))\n            cvalues[k] = xa[i]\n            // increment pointer\n            k++\n          } else if (wb[i] === mark) {\n            // push value (bij != 0)\n            cvalues[k] = xb[i]\n            // increment pointer\n            k++\n          } else {\n            // remove index @ k\n            cindex.splice(k, 1)\n          }\n        }\n      }\n    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'matAlgo10xSids'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo10xSids = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\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 matAlgo10xSids (s, b, callback, inverse) {\n    // sparse matrix arrays\n    const avalues = s._values\n    const aindex = s._index\n    const aptr = s._ptr\n    const asize = s._size\n    const adt = s._datatype\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!avalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrix and Scalar value') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string') {\n      // datatype\n      dt = adt\n      // convert b to the same datatype\n      b = typed.convert(b, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cdata = []\n\n    // workspaces\n    const x = []\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // columns mark\n      const mark = j + 1\n      // values in j\n      for (let k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        const r = aindex[k]\n        // update workspace\n        x[r] = avalues[k]\n        w[r] = mark\n      }\n      // loop rows\n      for (let i = 0; i < rows; i++) {\n        // initialize C on first column\n        if (j === 0) {\n          // create row array\n          cdata[i] = []\n        }\n        // check sparse matrix has a value @ i,j\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    }\n\n    // return dense matrix\n    return new DenseMatrix({\n      data: cdata,\n      size: [rows, columns],\n      datatype: dt\n    })\n  }\n})\n","/**\n * Create a syntax error with the message:\n *     'Wrong number of arguments in function <fn> (<count> provided, <min>-<max> 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 */\nexport function 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\n  this.message = 'Wrong number of arguments in function ' + fn +\n      ' (' + count + ' provided, ' +\n      min + ((max !== undefined && max !== null) ? ('-' + max) : '') + ' expected)'\n\n  this.stack = (new Error()).stack\n}\n\nArgumentsError.prototype = new Error()\nArgumentsError.prototype.constructor = Error\nArgumentsError.prototype.name = 'ArgumentsError'\nArgumentsError.prototype.isArgumentsError = true\n","import { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMod } from './mod.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\n\nconst name = 'gcd'\nconst dependencies = [\n  'typed',\n  'config',\n  'round',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'BigNumber',\n  'DenseMatrix',\n  'concat'\n]\n\nconst gcdTypes = 'number | BigNumber | Fraction | Matrix | Array'\nconst gcdManyTypesSignature = `${gcdTypes}, ${gcdTypes}, ...${gcdTypes}`\n\nfunction is1d (array) {\n  return !array.some(element => Array.isArray(element))\n}\n\nexport const createGcd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, config, round, equalScalar, zeros, BigNumber, DenseMatrix, concat }) => {\n  const mod = createMod({ typed, config, round, matrix, equalScalar, zeros, DenseMatrix, concat })\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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  return typed(\n    name,\n    {\n      'number, number': _gcdNumber,\n      'BigNumber, BigNumber': _gcdBigNumber,\n      'Fraction, Fraction': (x, y) => x.gcd(y)\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo04xSidSid,\n      DS: matAlgo01xDSid,\n      Ss: matAlgo10xSids\n    }),\n    {\n      [gcdManyTypesSignature]: typed.referToSelf(self => (a, b, args) => {\n        let res = self(a, b)\n        for (let i = 0; i < args.length; i++) {\n          res = self(res, args[i])\n        }\n        return res\n      }),\n      Array: typed.referToSelf(self => (array) => {\n        if (array.length === 1 && Array.isArray(array[0]) && is1d(array[0])) {\n          return self(...array[0])\n        }\n        if (is1d(array)) {\n          return self(...array)\n        }\n        throw new ArgumentsError('gcd() supports only 1d matrices!')\n      }),\n      Matrix: typed.referToSelf(self => (matrix) => {\n        return self(matrix.toArray())\n      })\n    }\n  )\n\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 * @private\n */\n  function _gcdNumber (a, b) {\n    if (!isInteger(a) || !isInteger(b)) {\n      throw new Error('Parameters in function gcd must be integer numbers')\n    }\n\n    // https://en.wikipedia.org/wiki/Euclidean_algorithm\n    let r\n    while (b !== 0) {\n      r = mod(a, b)\n      a = b\n      b = r\n    }\n    return (a < 0) ? -a : a\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  function _gcdBigNumber (a, b) {\n    if (!a.isInt() || !b.isInt()) {\n      throw new Error('Parameters in function gcd must be integer numbers')\n    }\n\n    // https://en.wikipedia.org/wiki/Euclidean_algorithm\n    const zero = new BigNumber(0)\n    while (!b.isZero()) {\n      const r = mod(a, b)\n      a = b\n      b = r\n    }\n    return a.lt(zero) ? a.neg() : a\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\nimport { scatter } from '../../../utils/collection.js'\n\nconst name = 'matAlgo06xS0S0'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo06xS0S0 = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 matAlgo06xS0S0 (a, b, callback) {\n    // sparse matrix arrays\n    const avalues = a._values\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bvalues = b._values\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = avalues && bvalues ? [] : undefined\n    const cindex = []\n    const cptr = []\n\n    // workspaces\n    const x = cvalues ? [] : undefined\n    // marks indicating we have a value in x for a given column\n    const w = []\n    // marks indicating value in a given row has been updated\n    const u = []\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // columns mark\n      const mark = j + 1\n      // scatter the values of A(:,j) into workspace\n      scatter(a, j, w, x, u, mark, cindex, cf)\n      // scatter the values of B(:,j) into workspace\n      scatter(b, j, w, x, u, mark, cindex, cf)\n      // check we need to process values (non pattern matrix)\n      if (x) {\n        // initialize first index in j\n        let k = cptr[j]\n        // loop index in j\n        while (k < cindex.length) {\n          // row\n          const i = cindex[k]\n          // check function was invoked on current row (Aij !=0 && Bij != 0)\n          if (u[i] === mark) {\n            // value @ i\n            const v = x[i]\n            // check for zero value\n            if (!eq(v, zero)) {\n              // push value\n              cvalues.push(v)\n              // increment pointer\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        let p = cptr[j]\n        // loop index in j\n        while (p < cindex.length) {\n          // row\n          const r = cindex[p]\n          // check function was invoked on current row (Aij !=0 && Bij != 0)\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    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { lcmNumber } from '../../plain/number/index.js'\n\nconst name = 'lcm'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'concat'\n]\n\nexport const createLcm = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n  const lcmTypes = 'number | BigNumber | Fraction | Matrix | Array'\n  const lcmManySignature = {}\n  lcmManySignature[`${lcmTypes}, ${lcmTypes}, ...${lcmTypes}`] =\n    typed.referToSelf(self => (a, b, args) => {\n      let res = self(a, b)\n      for (let i = 0; i < args.length; i++) {\n        res = self(res, args[i])\n      }\n      return res\n    })\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  return typed(\n    name, {\n      'number, number': lcmNumber,\n      'BigNumber, BigNumber': _lcmBigNumber,\n      'Fraction, Fraction': (x, y) => x.lcm(y)\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo06xS0S0,\n      DS: matAlgo02xDS0,\n      Ss: matAlgo11xS0s\n    }),\n    lcmManySignature\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  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    if (b.isZero()) {\n      return b\n    }\n\n    // https://en.wikipedia.org/wiki/Euclidean_algorithm\n    // evaluate lcm here inline to reduce overhead\n    const prod = a.times(b)\n    while (!b.isZero()) {\n      const t = b\n      b = a.mod(t)\n      a = t\n    }\n    return prod.div(a).abs()\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log10Number } from '../../plain/number/index.js'\n\nconst name = 'log10'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createLog10 = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\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 (x) {\n      if (x >= 0 || config.predictable) {\n        return log10Number(x)\n      } else {\n        // negative value -> complex value computation\n        return new Complex(x, 0).log().div(Math.LN10)\n      }\n    },\n\n    Complex: function (x) {\n      return new Complex(x).log().div(Math.LN10)\n    },\n\n    BigNumber: function (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\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log2Number } from '../../plain/number/index.js'\n\nconst name = 'log2'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createLog2 = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\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 (x) {\n      if (x >= 0 || config.predictable) {\n        return log2Number(x)\n      } else {\n        // negative value -> complex value computation\n        return _log2Complex(new Complex(x, 0))\n      }\n    },\n\n    Complex: _log2Complex,\n\n    BigNumber: function (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\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n\n  /**\n   * Calculate log2 for a complex value\n   * @param {Complex} x\n   * @returns {Complex}\n   * @private\n   */\n  function _log2Complex (x) {\n    const newX = Math.sqrt(x.re * x.re + x.im * x.im)\n    return new Complex(\n      (Math.log2) ? Math.log2(newX) : Math.log(newX) / Math.LN2,\n      Math.atan2(x.im, x.re) / Math.LN2\n    )\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { multiplyNumber } from '../../plain/number/index.js'\n\nconst name = 'multiplyScalar'\nconst dependencies = ['typed']\n\nexport const createMultiplyScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | Fraction | Complex | Unit} x   First value to multiply\n   * @param  {number | BigNumber | bigint | Fraction | Complex} y          Second value to multiply\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit}     Multiplication of `x` and `y`\n   * @private\n   */\n  return typed('multiplyScalar', {\n\n    'number, number': multiplyNumber,\n\n    'Complex, Complex': function (x, y) {\n      return x.mul(y)\n    },\n\n    'BigNumber, BigNumber': function (x, y) {\n      return x.times(y)\n    },\n\n    'bigint, bigint': function (x, y) {\n      return x * y\n    },\n\n    'Fraction, Fraction': function (x, y) {\n      return x.mul(y)\n    },\n\n    'number | Fraction | BigNumber | Complex, Unit': (x, y) => y.multiply(x),\n\n    'Unit, number | Fraction | BigNumber | Complex | Unit': (x, y) => x.multiply(y)\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'multiply'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'addScalar',\n  'multiplyScalar',\n  'equalScalar',\n  'dot'\n]\n\nexport const createMultiply = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, addScalar, multiplyScalar, equalScalar, dot }) => {\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\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            break\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            break\n          default:\n            throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)')\n        }\n        break\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            break\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            break\n          default:\n            throw new Error('Can only multiply a 1 or 2 dimensional matrix (Matrix B has ' + size2.length + ' dimensions)')\n        }\n        break\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  /**\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  function _multiplyVectorVector (a, b, n) {\n    // check empty vector\n    if (n === 0) { throw new Error('Cannot multiply two empty vectors') }\n    return dot(a, b)\n  }\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  function _multiplyVectorMatrix (a, b) {\n    // process storage\n    if (b.storage() !== 'dense') {\n      throw new Error('Support for SparseMatrix not implemented')\n    }\n    return _multiplyVectorDenseMatrix(a, b)\n  }\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  function _multiplyVectorDenseMatrix (a, b) {\n    // a dense\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype || a.getDataType()\n    // b dense\n    const bdata = b._data\n    const bsize = b._size\n    const bdt = b._datatype || b.getDataType()\n    // rows & columns\n    const alength = asize[0]\n    const bcolumns = bsize[1]\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n    }\n\n    // result\n    const c = []\n\n    // loop matrix columns\n    for (let j = 0; j < bcolumns; j++) {\n      // sum (do not initialize it with zero)\n      let sum = mf(adata[0], bdata[0][j])\n      // loop vector\n      for (let i = 1; i < alength; i++) {\n        // multiply & accumulate\n        sum = af(sum, mf(adata[i], bdata[i][j]))\n      }\n      c[j] = sum\n    }\n\n    // return matrix\n    return a.createDenseMatrix({\n      data: c,\n      size: [bcolumns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\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  const _multiplyMatrixVector = typed('_multiplyMatrixVector', {\n    'DenseMatrix, any': _multiplyDenseMatrixVector,\n    'SparseMatrix, any': _multiplySparseMatrixVector\n  })\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  const _multiplyMatrixMatrix = typed('_multiplyMatrixMatrix', {\n    'DenseMatrix, DenseMatrix': _multiplyDenseMatrixDenseMatrix,\n    'DenseMatrix, SparseMatrix': _multiplyDenseMatrixSparseMatrix,\n    'SparseMatrix, DenseMatrix': _multiplySparseMatrixDenseMatrix,\n    'SparseMatrix, SparseMatrix': _multiplySparseMatrixSparseMatrix\n  })\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  function _multiplyDenseMatrixVector (a, b) {\n    // a dense\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype || a.getDataType()\n    // b dense\n    const bdata = b._data\n    const bdt = b._datatype || b.getDataType()\n    // rows & columns\n    const arows = asize[0]\n    const acolumns = asize[1]\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n    }\n\n    // result\n    const c = []\n\n    // loop matrix a rows\n    for (let i = 0; i < arows; i++) {\n      // current row\n      const row = adata[i]\n      // sum (do not initialize it with zero)\n      let sum = mf(row[0], bdata[0])\n      // loop matrix a columns\n      for (let j = 1; j < acolumns; j++) {\n        // multiply & accumulate\n        sum = af(sum, mf(row[j], bdata[j]))\n      }\n      c[i] = sum\n    }\n\n    // return matrix\n    return a.createDenseMatrix({\n      data: c,\n      size: [arows],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\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  function _multiplyDenseMatrixDenseMatrix (a, b) { // getDataType()\n    // a dense\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype || a.getDataType()\n    // b dense\n    const bdata = b._data\n    const bsize = b._size\n    const bdt = b._datatype || b.getDataType()\n    // rows & columns\n    const arows = asize[0]\n    const acolumns = asize[1]\n    const bcolumns = bsize[1]\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n    }\n\n    // result\n    const c = []\n\n    // loop matrix a rows\n    for (let i = 0; i < arows; i++) {\n      // current row\n      const row = adata[i]\n      // initialize row array\n      c[i] = []\n      // loop matrix b columns\n      for (let j = 0; j < bcolumns; j++) {\n        // sum (avoid initializing sum to zero)\n        let sum = mf(row[0], bdata[0][j])\n        // loop matrix a columns\n        for (let x = 1; x < acolumns; x++) {\n          // multiply & accumulate\n          sum = af(sum, mf(row[x], bdata[x][j]))\n        }\n        c[i][j] = sum\n      }\n    }\n\n    // return matrix\n    return a.createDenseMatrix({\n      data: c,\n      size: [arows, bcolumns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\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  function _multiplyDenseMatrixSparseMatrix (a, b) {\n    // a dense\n    const adata = a._data\n    const asize = a._size\n    const adt = a._datatype || a.getDataType()\n    // b sparse\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n    // validate b matrix\n    if (!bvalues) { throw new Error('Cannot multiply Dense Matrix times Pattern only Matrix') }\n    // rows & columns\n    const arows = asize[0]\n    const bcolumns = bsize[1]\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n    // equalScalar signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n    }\n\n    // result\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n    // c matrix\n    const c = b.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [arows, bcolumns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n\n    // loop b columns\n    for (let jb = 0; jb < bcolumns; jb++) {\n      // update ptr\n      cptr[jb] = cindex.length\n      // indeces in column jb\n      const kb0 = bptr[jb]\n      const kb1 = bptr[jb + 1]\n      // do not process column jb if no data exists\n      if (kb1 > kb0) {\n        // last row mark processed\n        let last = 0\n        // loop a rows\n        for (let i = 0; i < arows; i++) {\n          // column mark\n          const mark = i + 1\n          // C[i, jb]\n          let cij\n          // values in b column j\n          for (let kb = kb0; kb < kb1; kb++) {\n            // row\n            const ib = bindex[kb]\n            // check value has been initialized\n            if (last !== mark) {\n              // first value in column jb\n              cij = mf(adata[i][ib], bvalues[kb])\n              // update mark\n              last = mark\n            } else {\n              // accumulate value\n              cij = af(cij, mf(adata[i][ib], bvalues[kb]))\n            }\n          }\n          // check column has been processed and value != 0\n          if (last === mark && !eq(cij, zero)) {\n            // push row & value\n            cindex.push(i)\n            cvalues.push(cij)\n          }\n        }\n      }\n    }\n    // update ptr\n    cptr[bcolumns] = cindex.length\n\n    // return sparse matrix\n    return c\n  }\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  function _multiplySparseMatrixVector (a, b) {\n    // a sparse\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // validate a matrix\n    if (!avalues) { throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix') }\n    // b dense\n    const bdata = b._data\n    const bdt = b._datatype || b.getDataType()\n    // rows & columns\n    const arows = a._size[0]\n    const brows = b._size[0]\n    // result\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n    // equalScalar signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n    }\n\n    // workspace\n    const x = []\n    // vector with marks indicating a value x[i] exists in a given column\n    const w = []\n\n    // update ptr\n    cptr[0] = 0\n    // rows in b\n    for (let ib = 0; ib < brows; ib++) {\n      // b[ib]\n      const vbi = bdata[ib]\n      // check b[ib] != 0, avoid loops\n      if (!eq(vbi, zero)) {\n        // A values & index in ib column\n        for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n          // a row\n          const ia = aindex[ka]\n          // check value exists in current j\n          if (!w[ia]) {\n            // ia is new entry in j\n            w[ia] = true\n            // add i to pattern of C\n            cindex.push(ia)\n            // x(ia) = A\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    }\n    // copy values from x to column jb of c\n    for (let p1 = cindex.length, p = 0; p < p1; p++) {\n      // row\n      const ic = cindex[p]\n      // copy value\n      cvalues[p] = x[ic]\n    }\n    // update ptr\n    cptr[1] = cindex.length\n\n    // matrix to return\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [arows, 1],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\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  function _multiplySparseMatrixDenseMatrix (a, b) {\n    // a sparse\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // validate a matrix\n    if (!avalues) { throw new Error('Cannot multiply Pattern only Matrix times Dense Matrix') }\n    // b dense\n    const bdata = b._data\n    const bdt = b._datatype || b.getDataType()\n    // rows & columns\n    const arows = a._size[0]\n    const brows = b._size[0]\n    const bcolumns = b._size[1]\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n    // equalScalar signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n    }\n\n    // result\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n    // c matrix\n    const c = a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [arows, bcolumns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n\n    // workspace\n    const x = []\n    // vector with marks indicating a value x[i] exists in a given column\n    const w = []\n\n    // loop b columns\n    for (let jb = 0; jb < bcolumns; jb++) {\n      // update ptr\n      cptr[jb] = cindex.length\n      // mark in workspace for current column\n      const mark = jb + 1\n      // rows in jb\n      for (let ib = 0; ib < brows; ib++) {\n        // b[ib, jb]\n        const vbij = bdata[ib][jb]\n        // check b[ib, jb] != 0, avoid loops\n        if (!eq(vbij, zero)) {\n          // A values & index in ib column\n          for (let ka0 = aptr[ib], ka1 = aptr[ib + 1], ka = ka0; ka < ka1; ka++) {\n            // a row\n            const ia = aindex[ka]\n            // check value exists in current j\n            if (w[ia] !== mark) {\n              // ia is new entry in j\n              w[ia] = mark\n              // add i to pattern of C\n              cindex.push(ia)\n              // x(ia) = A\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      }\n      // copy values from x to column jb of c\n      for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n        // row\n        const ic = cindex[p]\n        // copy value\n        cvalues[p] = x[ic]\n      }\n    }\n    // update ptr\n    cptr[bcolumns] = cindex.length\n\n    // return sparse matrix\n    return c\n  }\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  function _multiplySparseMatrixSparseMatrix (a, b) {\n    // a sparse\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // b sparse\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // rows & columns\n    const arows = a._size[0]\n    const bcolumns = b._size[1]\n    // flag indicating both matrices (a & b) contain data\n    const values = avalues && bvalues\n\n    // datatype\n    let dt\n    // addScalar signature to use\n    let af = addScalar\n    // multiplyScalar signature to use\n    let mf = multiplyScalar\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signatures that matches (dt, dt)\n      af = typed.find(addScalar, [dt, dt])\n      mf = typed.find(multiplyScalar, [dt, dt])\n    }\n\n    // result\n    const cvalues = values ? [] : undefined\n    const cindex = []\n    const cptr = []\n    // c matrix\n    const c = a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [arows, bcolumns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n\n    // workspace\n    const x = values ? [] : undefined\n    // vector with marks indicating a value x[i] exists in a given column\n    const w = []\n    // variables\n    let ka, ka0, ka1, kb, kb0, kb1, ia, ib\n    // loop b columns\n    for (let jb = 0; jb < bcolumns; jb++) {\n      // update ptr\n      cptr[jb] = cindex.length\n      // mark in workspace for current column\n      const mark = jb + 1\n      // B values & index in j\n      for (kb0 = bptr[jb], kb1 = bptr[jb + 1], kb = kb0; kb < kb1; kb++) {\n        // b row\n        ib = bindex[kb]\n        // check we need to process values\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]\n            // check value exists in current j\n            if (w[ia] !== mark) {\n              // ia is new entry in j\n              w[ia] = mark\n              // add i to pattern of C\n              cindex.push(ia)\n              // x(ia) = A\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]\n            // check value exists in current j\n            if (w[ia] !== mark) {\n              // ia is new entry in j\n              w[ia] = mark\n              // add i to pattern of C\n              cindex.push(ia)\n            }\n          }\n        }\n      }\n      // check we need to process matrix values (pattern matrix)\n      if (values) {\n        // copy values from x to column jb of c\n        for (let p0 = cptr[jb], p1 = cindex.length, p = p0; p < p1; p++) {\n          // row\n          const ic = cindex[p]\n          // copy value\n          cvalues[p] = x[ic]\n        }\n      }\n    }\n    // update ptr\n    cptr[bcolumns] = cindex.length\n\n    // return sparse matrix\n    return c\n  }\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 | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to multiply\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to multiply\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Multiplication of `x` and `y`\n   */\n  return typed(name, multiplyScalar, {\n    // we extend the signatures of multiplyScalar with signatures dealing with matrices\n\n    'Array, Array': typed.referTo('Matrix, Matrix', selfMM => (x, y) => {\n      // check dimensions\n      _validateMatrixDimensions(arraySize(x), arraySize(y))\n\n      // use dense matrix implementation\n      const m = selfMM(matrix(x), matrix(y))\n      // return array or scalar\n      return isMatrix(m) ? m.valueOf() : m\n    }),\n\n    'Matrix, Matrix': function (x, y) {\n      // dimensions\n      const xsize = x.size()\n      const ysize = y.size()\n\n      // check dimensions\n      _validateMatrixDimensions(xsize, ysize)\n\n      // process dimensions\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        }\n        // Vector * Matrix\n        return _multiplyVectorMatrix(x, y)\n      }\n      // process y dimensions\n      if (ysize.length === 1) {\n        // Matrix * Vector\n        return _multiplyMatrixVector(x, y)\n      }\n      // Matrix * Matrix\n      return _multiplyMatrixMatrix(x, y)\n    },\n\n    'Matrix, Array': typed.referTo('Matrix,Matrix', selfMM =>\n      (x, y) => selfMM(x, matrix(y))),\n\n    'Array, Matrix': typed.referToSelf(self => (x, y) => {\n      // use Matrix * Matrix implementation\n      return self(matrix(x, y.storage()), y)\n    }),\n\n    'SparseMatrix, any': function (x, y) {\n      return matAlgo11xS0s(x, y, multiplyScalar, false)\n    },\n\n    'DenseMatrix, any': function (x, y) {\n      return matAlgo14xDs(x, y, multiplyScalar, false)\n    },\n\n    'any, SparseMatrix': function (x, y) {\n      return matAlgo11xS0s(y, x, multiplyScalar, true)\n    },\n\n    'any, DenseMatrix': function (x, y) {\n      return matAlgo14xDs(y, x, multiplyScalar, true)\n    },\n\n    'Array, any': function (x, y) {\n      // use matrix implementation\n      return matAlgo14xDs(matrix(x), y, multiplyScalar, false).valueOf()\n    },\n\n    'any, Array': function (x, y) {\n      // use matrix implementation\n      return matAlgo14xDs(matrix(y), x, multiplyScalar, true).valueOf()\n    },\n\n    'any, any': multiplyScalar,\n\n    'any, any, ...any': typed.referToSelf(self => (x, y, rest) => {\n      let result = self(x, y)\n\n      for (let i = 0; i < rest.length; i++) {\n        result = self(result, rest[i])\n      }\n\n      return result\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { nthRootNumber } from '../../plain/number/index.js'\n\nconst name = 'nthRoot'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'BigNumber',\n  'concat'\n]\n\nexport const createNthRoot = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, BigNumber, concat }) => {\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 (since 3^2 == 9)\n   *     math.sqrt(9)          // returns 3 (since 3^2 == 9)\n   *     math.nthRoot(64, 3)   // returns 4 (since 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  function complexErr () {\n    throw new Error(\n      'Complex number not supported in function nthRoot. Use nthRoots instead.')\n  }\n\n  return typed(\n    name,\n    {\n      number: nthRootNumber,\n      'number, number': nthRootNumber,\n\n      BigNumber: x => _bigNthRoot(x, new BigNumber(2)),\n      'BigNumber, BigNumber': _bigNthRoot,\n\n      Complex: complexErr,\n      'Complex, number': complexErr,\n\n      Array: typed.referTo('DenseMatrix,number', selfDn =>\n        x => selfDn(matrix(x), 2).valueOf()),\n      DenseMatrix: typed.referTo('DenseMatrix,number', selfDn =>\n        x => selfDn(x, 2)),\n      SparseMatrix: typed.referTo('SparseMatrix,number', selfSn =>\n        x => selfSn(x, 2)),\n\n      'SparseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // density must be one (no zeros in matrix)\n        if (y.density() === 1) {\n          // sparse + sparse\n          return matAlgo06xS0S0(x, y, self)\n        } else {\n          // throw exception\n          throw new Error('Root must be non-zero')\n        }\n      }),\n\n      'DenseMatrix, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // density must be one (no zeros in matrix)\n        if (y.density() === 1) {\n          // dense + sparse\n          return matAlgo01xDSid(x, y, self, false)\n        } else {\n          // throw exception\n          throw new Error('Root must be non-zero')\n        }\n      }),\n\n      'Array, SparseMatrix': typed.referTo('DenseMatrix,SparseMatrix', selfDS =>\n        (x, y) => selfDS(matrix(x), y)),\n\n      'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // density must be one (no zeros in matrix)\n        if (y.density() === 1) {\n          // sparse - scalar\n          return matAlgo11xS0s(y, x, self, true)\n        } else {\n          // throw exception\n          throw new Error('Root must be non-zero')\n        }\n      })\n    },\n    matrixAlgorithmSuite({\n      scalar: 'number | BigNumber',\n      SD: matAlgo02xDS0,\n      Ss: matAlgo11xS0s,\n      sS: false\n    })\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  function _bigNthRoot (a, root) {\n    const precision = BigNumber.precision\n    const Big = BigNumber.clone({ precision: precision + 2 })\n    const zero = new BigNumber(0)\n\n    const one = new Big(1)\n    const inv = root.isNegative()\n    if (inv) {\n      root = root.neg()\n    }\n\n    if (root.isZero()) {\n      throw new Error('Root must be non-zero')\n    }\n    if (a.isNegative() && !root.abs().mod(2).equals(1)) {\n      throw new Error('Root must be odd when a is negative.')\n    }\n\n    // edge cases zero and infinity\n    if (a.isZero()) {\n      return inv ? new Big(Infinity) : 0\n    }\n    if (!a.isFinite()) {\n      return inv ? zero : a\n    }\n\n    let x = a.abs().pow(one.div(root))\n    // If a < 0, we require that root is an odd integer,\n    // so (-1) ^ (1/root) = -1\n    x = a.isNeg() ? x.neg() : x\n    return new BigNumber((inv ? one.div(x) : x).toPrecision(precision))\n  }\n})\n\nexport const createNthRootNumber = /* #__PURE__ */ factory(name, ['typed'], ({ typed }) => {\n  return typed(name, {\n    number: nthRootNumber,\n    'number, number': nthRootNumber\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { signNumber } from '../../plain/number/index.js'\n\nconst name = 'sign'\nconst dependencies = ['typed', 'BigNumber', 'Fraction', 'complex']\n\nexport const createSign = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber, complex, Fraction }) => {\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 | bigint | Fraction | Complex | Array | Matrix | Unit} x\n   *            The number for which to determine the sign\n   * @return {number | BigNumber | bigint | Fraction | Complex | Array | Matrix | Unit}\n   *            The sign of `x`\n   */\n  return typed(name, {\n    number: signNumber,\n\n    Complex: function (x) {\n      return x.im === 0 ? complex(signNumber(x.re)) : x.sign()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(x.cmp(0))\n    },\n\n    bigint: function (x) {\n      return x > 0n ? 1n : x < 0n ? -1n : 0n\n    },\n\n    Fraction: function (x) {\n      return new Fraction(x.s, 1)\n    },\n\n    // deep map collection, skip zeros since sign(0) = 0\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self, true)),\n\n    Unit: typed.referToSelf(self => x => {\n      if (!x._isDerived() && x.units[0].unit.offset !== 0) {\n        throw new TypeError('sign is ambiguous for units with offset')\n      }\n      return typed.find(self, x.valueType())(x.value)\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'sqrt'\nconst dependencies = ['config', 'typed', 'Complex']\n\nexport const createSqrt = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, Complex }) => {\n  /**\n   * Calculate the square root of a value.\n   *\n   * For matrices, if you want the matrix square root of a square matrix,\n   * use the `sqrtm` function. If you wish to apply `sqrt` elementwise to\n   * a matrix M, use `math.map(M, math.sqrt)`.\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 | Unit} x\n   *            Value for which to calculate the square root.\n   * @return {number | BigNumber | Complex | Unit}\n   *            Returns the square root of `x`\n   */\n  return typed('sqrt', {\n    number: _sqrtNumber,\n\n    Complex: function (x) {\n      return x.sqrt()\n    },\n\n    BigNumber: function (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\n    Unit: function (x) {\n      // Someday will work for complex units when they are implemented\n      return x.pow(0.5)\n    }\n\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  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})\n","import { factory } from '../../utils/factory.js'\nimport { squareNumber } from '../../plain/number/index.js'\n\nconst name = 'square'\nconst dependencies = ['typed']\n\nexport const createSquare = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Compute the square of a value, `x * x`.\n   * To avoid confusion with multiplying a square matrix by itself,\n   * this function does not apply to matrices. If you wish to square\n   * every element of a matrix, see the examples.\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.map([1, 2, 3, 4], math.square)  // returns Array [1, 4, 9, 16]\n   *\n   * See also:\n   *\n   *    multiply, cube, sqrt, pow\n   *\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit} x\n   *            Number for which to calculate the square\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit}\n   *            Squared value\n   */\n  return typed(name, {\n    number: squareNumber,\n\n    Complex: function (x) {\n      return x.mul(x)\n    },\n\n    BigNumber: function (x) {\n      return x.times(x)\n    },\n\n    bigint: function (x) {\n      return x * x\n    },\n\n    Fraction: function (x) {\n      return x.mul(x)\n    },\n\n    Unit: function (x) {\n      return x.pow(2)\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'subtract'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'subtractScalar',\n  'unaryMinus',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createSubtract = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, subtractScalar, unaryMinus, DenseMatrix, concat }) => {\n  // TODO: split function subtract in two: subtract and subtractScalar\n\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Fraction | Complex | Unit | Array | Matrix} x Initial value\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Value to subtract from `x`\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Subtraction of `x` and `y`\n   */\n  return typed(\n    name,\n    {\n      'any, any': subtractScalar\n    },\n    matrixAlgorithmSuite({\n      elop: subtractScalar,\n      SS: matAlgo05xSfSf,\n      DS: matAlgo01xDSid,\n      SD: matAlgo03xDSf,\n      Ss: matAlgo12xSfs,\n      sS: matAlgo10xSids\n    })\n  )\n})\n","import { factory } from '../../utils/factory.js'\nimport { xgcdNumber } from '../../plain/number/index.js'\n\nconst name = 'xgcd'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createXgcd = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\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 (a, b) {\n      const res = xgcdNumber(a, b)\n\n      return (config.matrix === 'Array')\n        ? res\n        : matrix(res)\n    },\n    'BigNumber, BigNumber': _xgcdBigNumber\n    // 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  function _xgcdBigNumber (a, b) {\n    // source: https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm\n    let // used to swap two variables\n      t\n\n    let // quotient\n      q\n\n    let // remainder\n      r\n\n    const zero = new BigNumber(0)\n    const one = new BigNumber(1)\n    let x = zero\n    let lastx = one\n    let y = one\n    let 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\n      t = x\n      x = lastx.minus(q.times(x))\n      lastx = t\n\n      t = y\n      y = lasty.minus(q.times(y))\n      lasty = t\n\n      a = b\n      b = r\n    }\n\n    let res\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    return (config.matrix === 'Array') ? res : matrix(res)\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'invmod'\nconst dependencies = ['typed', 'config', 'BigNumber', 'xgcd', 'equal', 'smaller', 'mod', 'add', 'isInteger']\n\nexport const createInvmod = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, BigNumber, xgcd, equal, smaller, mod, add, isInteger }) => {\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)             // returns 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    let res = xgcd(a, b)\n    res = res.valueOf()\n    let [gcd, inv] = res\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})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo09xS0Sf'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo09xS0Sf = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 matAlgo09xS0Sf (a, b, callback) {\n    // sparse matrix arrays\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = avalues && bvalues ? [] : undefined\n    const cindex = []\n    const cptr = []\n\n    // workspaces\n    const x = cvalues ? [] : undefined\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // vars\n    let i, j, k, k0, k1\n\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // column mark\n      const mark = j + 1\n      // check we need to process values\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]\n          // update workspace\n          w[i] = mark\n          x[i] = bvalues[k]\n        }\n      }\n      // loop A(:,j)\n      for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = aindex[k]\n        // check we need to process values\n        if (x) {\n          // b value @ i,j\n          const vb = w[i] === mark ? x[i] : zero\n          // invoke f\n          const vc = cf(avalues[k], vb)\n          // check zero value\n          if (!eq(vc, zero)) {\n            // push index\n            cindex.push(i)\n            // push value\n            cvalues.push(vc)\n          }\n        } else {\n          // push index\n          cindex.push(i)\n        }\n      }\n    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotMultiply'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'multiplyScalar',\n  'concat'\n]\n\nexport const createDotMultiply = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, multiplyScalar, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo09xS0Sf = createMatAlgo09xS0Sf({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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  return typed(name, matrixAlgorithmSuite({\n    elop: multiplyScalar,\n    SS: matAlgo09xS0Sf,\n    DS: matAlgo02xDS0,\n    Ss: matAlgo11xS0s\n  }))\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 */\nexport function 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  const BigNumber = x.constructor\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  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      return new BigNumber(0)\n    }\n    if (!x.isFinite()) {\n      if (y.isNegative()) {\n        return x\n      }\n      if (x.isNegative()) {\n        return new BigNumber(0)\n      }\n      return y\n    }\n    if (!y.isFinite()) {\n      if (x.isNegative()) {\n        return y\n      }\n      if (y.isNegative()) {\n        return new BigNumber(0)\n      }\n      return x\n    }\n  }\n  return bitwise(x, y, function (a, b) { return a & b })\n}\n\n/**\n * Bitwise not\n * @param {BigNumber} x\n * @return {BigNumber} Result of ~`x`, fully precise\n *\n */\nexport function bitNotBigNumber (x) {\n  if (x.isFinite() && !x.isInteger()) {\n    throw new Error('Integer expected in function bitNot')\n  }\n\n  const BigNumber = x.constructor\n  const prevPrec = BigNumber.precision\n  BigNumber.config({ precision: 1E9 })\n\n  const result = x.plus(new BigNumber(1))\n  result.s = -result.s || null\n\n  BigNumber.config({ precision: prevPrec })\n  return result\n}\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 */\nexport function 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  const BigNumber = x.constructor\n  if (x.isNaN() || y.isNaN()) {\n    return new BigNumber(NaN)\n  }\n\n  const negOne = new BigNumber(-1)\n  if (x.isZero() || y.eq(negOne) || x.eq(y)) {\n    return y\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()) ||\n      (x.isNegative() && !y.isNegative() && !y.isFinite())) {\n      return negOne\n    }\n    if (x.isNegative() && y.isNegative()) {\n      return x.isFinite() ? x : y\n    }\n    return x.isFinite() ? y : x\n  }\n\n  return bitwise(x, y, function (a, b) { 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 */\nexport function bitwise (x, y, func) {\n  const BigNumber = x.constructor\n\n  let xBits, yBits\n  const xSign = +(x.s < 0)\n  const ySign = +(y.s < 0)\n  if (xSign) {\n    xBits = decCoefficientToBinaryString(bitNotBigNumber(x))\n    for (let i = 0; i < xBits.length; ++i) {\n      xBits[i] ^= 1\n    }\n  } else {\n    xBits = decCoefficientToBinaryString(x)\n  }\n  if (ySign) {\n    yBits = decCoefficientToBinaryString(bitNotBigNumber(y))\n    for (let i = 0; i < yBits.length; ++i) {\n      yBits[i] ^= 1\n    }\n  } else {\n    yBits = decCoefficientToBinaryString(y)\n  }\n\n  let minBits, maxBits, minSign\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  let shortLen = minBits.length\n  let longLen = maxBits.length\n  const expFuncVal = func(xSign, ySign) ^ 1\n  let outVal = new BigNumber(expFuncVal ^ 1)\n  let twoPower = new BigNumber(1)\n  const two = new BigNumber(2)\n\n  const prevPrec = BigNumber.precision\n  BigNumber.config({ precision: 1E9 })\n\n  while (shortLen > 0) {\n    if (func(minBits[--shortLen], maxBits[--longLen]) === expFuncVal) {\n      outVal = outVal.plus(twoPower)\n    }\n    twoPower = twoPower.times(two)\n  }\n  while (longLen > 0) {\n    if (func(minSign, maxBits[--longLen]) === expFuncVal) {\n      outVal = outVal.plus(twoPower)\n    }\n    twoPower = twoPower.times(two)\n  }\n\n  BigNumber.config({ precision: prevPrec })\n\n  if (expFuncVal === 0) {\n    outVal.s = -outVal.s\n  }\n  return outVal\n}\n\n/* Extracted from decimal.js, and edited to specialize. */\nfunction decCoefficientToBinaryString (x) {\n  // Convert to string\n  const a = x.d // array with digits\n  let r = a[0] + ''\n\n  for (let i = 1; i < a.length; ++i) {\n    let s = a[i] + ''\n    for (let z = 7 - s.length; z--;) {\n      s = '0' + s\n    }\n\n    r += s\n  }\n\n  let j = r.length\n  while (r.charAt(j) === '0') {\n    j--\n  }\n\n  let xe = x.e\n  let str = r.slice(0, j + 1 || 1)\n  const strL = str.length\n  if (xe > 0) {\n    if (++xe > strL) {\n      // Append zeros.\n      xe -= strL\n      while (xe--) {\n        str += '0'\n      }\n    } else if (xe < strL) {\n      str = str.slice(0, xe) + '.' + str.slice(xe)\n    }\n  }\n\n  // Convert from base 10 (decimal) to base 2\n  const arr = [0]\n  for (let i = 0; i < str.length;) {\n    let arrL = arr.length\n    while (arrL--) {\n      arr[arrL] *= 10\n    }\n\n    arr[0] += parseInt(str.charAt(i++)) // convert to int\n    for (let 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/**\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 */\nexport function 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  const BigNumber = x.constructor\n  if (x.isNaN() || y.isNaN()) {\n    return new BigNumber(NaN)\n  }\n  if (x.isZero()) {\n    return y\n  }\n  if (y.isZero()) {\n    return x\n  }\n\n  if (x.eq(y)) {\n    return new BigNumber(0)\n  }\n\n  const negOne = new BigNumber(-1)\n  if (x.eq(negOne)) {\n    return bitNotBigNumber(y)\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    return new BigNumber(x.isNegative() === y.isNegative()\n      ? Infinity\n      : -Infinity)\n  }\n  return bitwise(x, y, function (a, b) { 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 */\nexport function 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  const BigNumber = x.constructor\n  if (x.isNaN() || y.isNaN() || (y.isNegative() && !y.isZero())) {\n    return new BigNumber(NaN)\n  }\n  if (x.isZero() || y.isZero()) {\n    return x\n  }\n  if (!x.isFinite() && !y.isFinite()) {\n    return new BigNumber(NaN)\n  }\n\n  // Math.pow(2, y) is fully precise for y < 55, and fast\n  if (y.lt(55)) {\n    return x.times(Math.pow(2, y.toNumber()) + '')\n  }\n  return x.times(new BigNumber(2).pow(y))\n}\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 */\nexport function 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  const BigNumber = x.constructor\n  if (x.isNaN() || y.isNaN() || (y.isNegative() && !y.isZero())) {\n    return new BigNumber(NaN)\n  }\n  if (x.isZero() || y.isZero()) {\n    return x\n  }\n  if (!y.isFinite()) {\n    if (x.isNegative()) {\n      return new BigNumber(-1)\n    }\n    if (!x.isFinite()) {\n      return new BigNumber(NaN)\n    }\n    return new BigNumber(0)\n  }\n\n  // Math.pow(2, y) is fully precise for y < 55, and fast\n  if (y.lt(55)) {\n    return x.div(Math.pow(2, y.toNumber()) + '').floor()\n  }\n  return x.div(new BigNumber(2).pow(y)).floor()\n}\n","import { isInteger } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function bitAndNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function bitAnd')\n  }\n\n  return x & y\n}\nbitAndNumber.signature = n2\n\nexport function bitNotNumber (x) {\n  if (!isInteger(x)) {\n    throw new Error('Integer expected in function bitNot')\n  }\n\n  return ~x\n}\nbitNotNumber.signature = n1\n\nexport function bitOrNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function bitOr')\n  }\n\n  return x | y\n}\nbitOrNumber.signature = n2\n\nexport function bitXorNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function bitXor')\n  }\n\n  return x ^ y\n}\nbitXorNumber.signature = n2\n\nexport function leftShiftNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function leftShift')\n  }\n\n  return x << y\n}\nleftShiftNumber.signature = n2\n\nexport function rightArithShiftNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function rightArithShift')\n  }\n\n  return x >> y\n}\nrightArithShiftNumber.signature = n2\n\nexport function rightLogShiftNumber (x, y) {\n  if (!isInteger(x) || !isInteger(y)) {\n    throw new Error('Integers expected in function rightLogShift')\n  }\n\n  return x >>> y\n}\nrightLogShiftNumber.signature = n2\n","import { bitAndBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitAndNumber } from '../../plain/number/index.js'\n\nconst name = 'bitAnd'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'concat'\n]\n\nexport const createBitAnd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Array | Matrix} x First value to and\n   * @param  {number | BigNumber | bigint | Array | Matrix} y Second value to and\n   * @return {number | BigNumber | bigint | Array | Matrix} AND of `x` and `y`\n   */\n  return typed(\n    name,\n    {\n      'number, number': bitAndNumber,\n      'BigNumber, BigNumber': bitAndBigNumber,\n      'bigint, bigint': (x, y) => x & y\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo06xS0S0,\n      DS: matAlgo02xDS0,\n      Ss: matAlgo11xS0s\n    })\n  )\n})\n","import { bitNotBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { bitNotNumber } from '../../plain/number/index.js'\n\nconst name = 'bitNot'\nconst dependencies = ['typed']\n\nexport const createBitNot = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | Array | Matrix} x Value to not\n   * @return {number | BigNumber | bigint | Array | Matrix} NOT of `x`\n   */\n  return typed(name, {\n    number: bitNotNumber,\n    BigNumber: bitNotBigNumber,\n    bigint: x => ~x,\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { bitOrBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitOrNumber } from '../../plain/number/index.js'\n\nconst name = 'bitOr'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createBitOr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Array | Matrix} x First value to or\n   * @param  {number | BigNumber | bigint | Array | Matrix} y Second value to or\n   * @return {number | BigNumber | bigint | Array | Matrix} OR of `x` and `y`\n   */\n  return typed(\n    name,\n    {\n      'number, number': bitOrNumber,\n      'BigNumber, BigNumber': bitOrBigNumber,\n      'bigint, bigint': (x, y) => x | y\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo04xSidSid,\n      DS: matAlgo01xDSid,\n      Ss: matAlgo10xSids\n    })\n  )\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo07xSSf'\nconst dependencies = ['typed', 'DenseMatrix']\n\nexport const createMatAlgo07xSSf = /* #__PURE__ */ factory(name, dependencies, ({ typed, DenseMatrix }) => {\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 matAlgo07xSSf (a, b, callback) {\n    // sparse matrix arrays\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // vars\n    let i, j\n\n    // result arrays\n    const cdata = []\n    // initialize c\n    for (i = 0; i < rows; i++) { cdata[i] = [] }\n\n    // workspaces\n    const xa = []\n    const xb = []\n    // marks indicating we have a value in x for a given column\n    const wa = []\n    const wb = []\n\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // columns mark\n      const mark = j + 1\n      // scatter the values of A(:,j) into workspace\n      _scatter(a, j, wa, xa, mark)\n      // scatter the values of B(:,j) into workspace\n      _scatter(b, j, wb, xb, mark)\n      // loop rows\n      for (i = 0; i < rows; i++) {\n        // matrix values @ i,j\n        const va = wa[i] === mark ? xa[i] : zero\n        const vb = wb[i] === mark ? xb[i] : zero\n        // invoke callback\n        cdata[i][j] = cf(va, vb)\n      }\n    }\n\n    // return dense matrix\n    return new DenseMatrix({\n      data: cdata,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n\n  function _scatter (m, j, w, x, mark) {\n    // a arrays\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n    // loop values in column j\n    for (let k = ptr[j], k1 = ptr[j + 1]; k < k1; k++) {\n      // row\n      const i = index[k]\n      // update workspace\n      w[i] = mark\n      x[i] = values[k]\n    }\n  }\n})\n","import { bitXor as bigBitXor } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { bitXorNumber } from '../../plain/number/index.js'\n\nconst name = 'bitXor'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createBitXor = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Array | Matrix} x First value to xor\n   * @param  {number | BigNumber | bigint | Array | Matrix} y Second value to xor\n   * @return {number | BigNumber | bigint | Array | Matrix} XOR of `x` and `y`\n   */\n  return typed(\n    name,\n    {\n      'number, number': bitXorNumber,\n      'BigNumber, BigNumber': bigBitXor,\n      'bigint, bigint': (x, y) => x ^ y\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'arg'\nconst dependencies = ['typed']\n\nexport const createArg = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 (x) {\n      return Math.atan2(0, x)\n    },\n\n    BigNumber: function (x) {\n      return x.constructor.atan2(0, x)\n    },\n\n    Complex: function (x) {\n      return x.arg()\n    },\n\n    // TODO: implement BigNumber support for function arg\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'conj'\nconst dependencies = ['typed']\n\nexport const createConj = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | BigNumber | Fraction': x => x,\n    Complex: x => x.conjugate(),\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 'im'\nconst dependencies = ['typed']\n\nexport const createIm = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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: () => 0,\n    'BigNumber | Fraction': x => x.mul(0),\n    Complex: x => x.im,\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\n\nconst name = 're'\nconst dependencies = ['typed']\n\nexport const createRe = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | BigNumber | Fraction': x => x,\n    Complex: x => x.re,\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","const n1 = 'number'\nconst n2 = 'number, number'\n\nexport function notNumber (x) {\n  return !x\n}\nnotNumber.signature = n1\n\nexport function orNumber (x, y) {\n  return !!(x || y)\n}\norNumber.signature = n2\n\nexport function xorNumber (x, y) {\n  return !!x !== !!y\n}\nxorNumber.signature = n2\n\nexport function andNumber (x, y) {\n  return !!(x && y)\n}\nandNumber.signature = n2\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { notNumber } from '../../plain/number/index.js'\n\nconst name = 'not'\nconst dependencies = ['typed']\n\nexport const createNot = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | 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    'null | undefined': () => true,\n\n    number: notNumber,\n\n    Complex: function (x) {\n      return x.re === 0 && x.im === 0\n    },\n\n    BigNumber: function (x) {\n      return x.isZero() || x.isNaN()\n    },\n\n    bigint: x => !x,\n\n    Unit: typed.referToSelf(self => x => typed.find(self, x.valueType())(x.value)),\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { orNumber } from '../../plain/number/index.js'\n\nconst name = 'or'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createOr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Complex | Unit | Array | Matrix} x First value to check\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    {\n      'number, number': orNumber,\n\n      'Complex, Complex': function (x, y) {\n        return (x.re !== 0 || x.im !== 0) || (y.re !== 0 || y.im !== 0)\n      },\n\n      'BigNumber, BigNumber': function (x, y) {\n        return (!x.isZero() && !x.isNaN()) || (!y.isZero() && !y.isNaN())\n      },\n\n      'bigint, bigint': orNumber,\n\n      'Unit, Unit': typed.referToSelf(self =>\n        (x, y) => self(x.value || 0, y.value || 0))\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo05xSfSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n","import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { xorNumber } from '../../plain/number/index.js'\n\nconst name = 'xor'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createXor = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Complex | Unit | Array | Matrix} x First value to check\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    {\n      'number, number': xorNumber,\n\n      'Complex, Complex': function (x, y) {\n        return ((x.re !== 0 || x.im !== 0) !== (y.re !== 0 || y.im !== 0))\n      },\n\n      'bigint, bigint': xorNumber,\n\n      'BigNumber, BigNumber': function (x, y) {\n        return ((!x.isZero() && !x.isNaN()) !== (!y.isZero() && !y.isNaN()))\n      },\n\n      'Unit, Unit': typed.referToSelf(self =>\n        (x, y) => self(x.value || 0, y.value || 0))\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n","import { isBigNumber, isMatrix, isNumber } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { arraySize, concat as _concat } from '../../utils/array.js'\nimport { IndexError } from '../../error/IndexError.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'concat'\nconst dependencies = ['typed', 'matrix', 'isInteger']\n\nexport const createConcat = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isInteger }) => {\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 (args) {\n      let i\n      const len = args.length\n      let dim = -1 // zero-based dimension\n      let prevDim\n      let asMatrix = false\n      const matrices = [] // contains multi dimensional arrays\n\n      for (i = 0; i < len; i++) {\n        const arg = args[i]\n\n        // test whether we need to return a Matrix (if not we return an Array)\n        if (isMatrix(arg)) {\n          asMatrix = true\n        }\n\n        if (isNumber(arg) || isBigNumber(arg)) {\n          if (i !== len - 1) {\n            throw new Error('Dimension must be specified as last argument')\n          }\n\n          // last argument contains the dimension on which to concatenate\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(dim, prevDim + 1)\n          }\n        } else {\n          // this is a matrix or array\n          const m = clone(arg).valueOf()\n          const size = arraySize(m)\n          matrices[i] = m\n          prevDim = dim\n          dim = size.length - 1\n\n          // verify whether each of the matrices has the same number of dimensions\n          if (i > 0 && dim !== prevDim) {\n            throw new 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      let res = matrices.shift()\n      while (matrices.length) {\n        res = _concat(res, matrices.shift(), dim)\n      }\n\n      return asMatrix ? matrix(res) : res\n    },\n\n    '...string': function (args) {\n      return args.join('')\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { validateIndex } from '../../utils/array.js'\n\nconst name = 'column'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\nexport const createColumn = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\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\n    'Array, number': function (value, column) {\n      return _column(matrix(clone(value)), column).valueOf()\n    }\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  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    validateIndex(column, value.size()[1])\n\n    const rowRange = range(0, value.size()[0])\n    const index = new Index(rowRange, column)\n    const result = value.subset(index)\n    return isMatrix(result)\n      ? result\n      : matrix([[result]])\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'count'\nconst dependencies = ['typed', 'size', 'prod']\n\nexport const createCount = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, prod }) => {\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 (x) {\n      return x.length\n    },\n\n    'Matrix | Array': function (x) {\n      return prod(size(x))\n    }\n  })\n})\n","import { arraySize, squeeze } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'cross'\nconst dependencies = ['typed', 'matrix', 'subtract', 'multiply']\n\nexport const createCross = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, multiply }) => {\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 (x, y) {\n      return matrix(_cross(x.toArray(), y.toArray()))\n    },\n\n    'Matrix, Array': function (x, y) {\n      return matrix(_cross(x.toArray(), y))\n    },\n\n    'Array, Matrix': function (x, y) {\n      return matrix(_cross(x, y.toArray()))\n    },\n\n    'Array, Array': _cross\n  })\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  function _cross (x, y) {\n    const highestDimension = Math.max(arraySize(x).length, arraySize(y).length)\n\n    x = squeeze(x)\n    y = squeeze(y)\n\n    const xSize = arraySize(x)\n    const ySize = 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 ' +\n      '(Size A = [' + xSize.join(', ') + '], B = [' + ySize.join(', ') + '])')\n    }\n\n    const product = [\n      subtract(multiply(x[1], y[2]), multiply(x[2], y[1])),\n      subtract(multiply(x[2], y[0]), multiply(x[0], y[2])),\n      subtract(multiply(x[0], y[1]), multiply(x[1], y[0]))\n    ]\n\n    if (highestDimension > 1) {\n      return [product]\n    } else {\n      return product\n    }\n  }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'diag'\nconst dependencies = ['typed', 'matrix', 'DenseMatrix', 'SparseMatrix']\n\nexport const createDiag = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, DenseMatrix, SparseMatrix }) => {\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\n    Array: function (x) {\n      return _diag(x, 0, arraySize(x), null)\n    },\n\n    'Array, number': function (x, k) {\n      return _diag(x, k, arraySize(x), null)\n    },\n\n    'Array, BigNumber': function (x, k) {\n      return _diag(x, k.toNumber(), arraySize(x), null)\n    },\n\n    'Array, string': function (x, format) {\n      return _diag(x, 0, arraySize(x), format)\n    },\n\n    'Array, number, string': function (x, k, format) {\n      return _diag(x, k, arraySize(x), format)\n    },\n\n    'Array, BigNumber, string': function (x, k, format) {\n      return _diag(x, k.toNumber(), arraySize(x), format)\n    },\n\n    Matrix: function (x) {\n      return _diag(x, 0, x.size(), x.storage())\n    },\n\n    'Matrix, number': function (x, k) {\n      return _diag(x, k, x.size(), x.storage())\n    },\n\n    'Matrix, BigNumber': function (x, k) {\n      return _diag(x, k.toNumber(), x.size(), x.storage())\n    },\n\n    'Matrix, string': function (x, format) {\n      return _diag(x, 0, x.size(), format)\n    },\n\n    'Matrix, number, string': function (x, k, format) {\n      return _diag(x, k, x.size(), format)\n    },\n\n    'Matrix, BigNumber, string': function (x, k, format) {\n      return _diag(x, k.toNumber(), x.size(), format)\n    }\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  function _diag (x, k, size, format) {\n    if (!isInteger(k)) {\n      throw new TypeError('Second parameter in function diag must be an integer')\n    }\n\n    const kSuper = k > 0 ? k : 0\n    const kSub = k < 0 ? -k : 0\n\n    // check dimensions\n    switch (size.length) {\n      case 1:\n        return _createDiagonalMatrix(x, k, format, size[0], kSub, kSuper)\n      case 2:\n        return _getDiagonal(x, k, format, size, kSub, kSuper)\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    const ms = [l + kSub, l + kSuper]\n\n    if (format && format !== 'sparse' && format !== 'dense') {\n      throw new TypeError(`Unknown matrix type ${format}\"`)\n    }\n\n    // create diagonal matrix\n    const m = format === 'sparse'\n      ? SparseMatrix.diagonal(ms, x, k)\n      : DenseMatrix.diagonal(ms, x, k)\n    // check we need to return a matrix\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 (isMatrix(x)) {\n      // get diagonal matrix\n      const dm = x.diagonal(k)\n      // check we need to return a matrix\n      if (format !== null) {\n        // check we need to change matrix format\n        if (format !== dm.storage()) { return matrix(dm, format) }\n        return dm\n      }\n      return dm.valueOf()\n    }\n    // vector size\n    const n = Math.min(s[0] - kSub, s[1] - kSuper)\n    // diagonal values\n    const vector = []\n    // loop diagonal\n    for (let i = 0; i < n; i++) {\n      vector[i] = x[i + kSub][i + kSuper]\n    }\n    // check we need to return a matrix\n    return format !== null ? matrix(vector) : vector\n  }\n})\n","import typed from 'typed-function'\nimport { typeOf as _typeOf } from './is.js'\n\n/**\n * Invoke a callback for functions like map and filter with a matching number of arguments\n * @param {function} callback\n * @param {any} value\n * @param {number | number[]} index\n * @param {Array} array\n * @param {string} mappingFnName   The name of the function that is invoking these callbacks, for example \"map\" or \"filter\"\n * @returns {*}\n */\nexport function applyCallback (callback, value, index, array, mappingFnName) {\n  if (typed.isTypedFunction(callback)) {\n    // invoke the typed callback function with the matching number of arguments only\n\n    const args3 = [value, index, array]\n    const signature3 = typed.resolve(callback, args3)\n    if (signature3) {\n      return tryWithArgs(signature3.implementation, args3)\n    }\n\n    const args2 = [value, index]\n    const signature2 = typed.resolve(callback, args2)\n    if (signature2) {\n      return tryWithArgs(signature2.implementation, args2)\n    }\n\n    const args1 = [value]\n    const signature1 = typed.resolve(callback, args1)\n    if (signature1) {\n      return tryWithArgs(signature1.implementation, args1)\n    }\n\n    // fallback (will throw an exception)\n    return tryWithArgs(callback, args3)\n  } else {\n    // A regular JavaScript function\n    return callback(value, index, array)\n  }\n\n  /**\n   * @param {function} signature The selected signature of the typed-function\n   * @param {Array} args List with arguments to apply to the selected signature\n   * @returns {*} Returns the return value of the invoked signature\n   * @throws {TypeError} Throws an error when no matching signature was found\n   */\n  function tryWithArgs (signature, args) {\n    try {\n      return signature.apply(signature, args)\n    } catch (err) {\n      // Enrich the error message so the user understands that it took place inside the callback function\n      if (err instanceof TypeError && err.data?.category === 'wrongType') {\n        const argsDesc = []\n        argsDesc.push(`value: ${_typeOf(value)}`)\n        if (args.length >= 2) { argsDesc.push(`index: ${_typeOf(index)}`) }\n        if (args.length >= 3) { argsDesc.push(`array: ${_typeOf(array)}`) }\n\n        throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` +\n          `${callback.name}(${argsDesc.join(', ')}) at index ${JSON.stringify(index)}`)\n      } else {\n        throw new TypeError(`Function ${mappingFnName} cannot apply callback arguments ` +\n          `to function ${callback.name}: ${err.message}`)\n      }\n    }\n  }\n}\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { filter, filterRegExp } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'filter'\nconst dependencies = ['typed']\n\nexport const createFilter = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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\n    'Matrix, function': function (x, test) {\n      return x.create(_filterCallback(x.toArray(), test))\n    },\n\n    'Array, RegExp': filterRegExp,\n\n    'Matrix, RegExp': function (x, test) {\n      return x.create(filterRegExp(x.toArray(), test))\n    }\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 */\nfunction _filterCallback (x, callback) {\n  return filter(x, function (value, index, array) {\n    // invoke the callback function with the right number of arguments\n    return applyCallback(callback, value, [index], array, 'filter')\n  })\n}\n","import { flatten as flattenArray } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'flatten'\nconst dependencies = ['typed', 'matrix']\n\nexport const createFlatten = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix }) => {\n  /**\n   * Flatten a multidimensional matrix into a single dimensional matrix.\n   * A new matrix is returned, the original matrix is left untouched.\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 (x) {\n      return flattenArray(x)\n    },\n\n    Matrix: function (x) {\n      const flat = flattenArray(x.toArray())\n      // TODO: return the same matrix type as x (Dense or Sparse Matrix)\n      return matrix(flat)\n    }\n  })\n})\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { forEach as forEachArray } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'forEach'\nconst dependencies = ['typed']\n\nexport const createForEach = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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\n    'Matrix, function': function (x, callback) {\n      x.forEach(callback)\n    }\n  })\n})\n\n/**\n * forEach for a multidimensional array\n * @param {Array} array\n * @param {Function} callback\n * @private\n */\nfunction _forEach (array, callback) {\n  const recurse = function (value, index) {\n    if (Array.isArray(value)) {\n      forEachArray(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      return applyCallback(callback, value, index, array, 'forEach')\n    }\n  }\n  recurse(array, [])\n}\n","import { factory } from '../../utils/factory.js'\nimport { getArrayDataType } from '../../utils/array.js'\nimport { typeOf } from '../../utils/is.js'\n\nconst name = 'getMatrixDataType'\nconst dependencies = ['typed']\n\nexport const createGetMatrixDataType = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 (x) {\n      return getArrayDataType(x, typeOf)\n    },\n    Matrix: function (x) {\n      return x.getDataType()\n    }\n  })\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { resize } from '../../utils/array.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'identity'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'BigNumber',\n  'DenseMatrix',\n  'SparseMatrix'\n]\n\nexport const createIdentity = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber, DenseMatrix, SparseMatrix }) => {\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\n    string: function (format) {\n      return matrix(format)\n    },\n\n    'number | BigNumber': function (rows) {\n      return _identity(rows, rows, config.matrix === 'Matrix' ? 'dense' : undefined)\n    },\n\n    'number | BigNumber, string': function (rows, format) {\n      return _identity(rows, rows, format)\n    },\n\n    'number | BigNumber, number | BigNumber': function (rows, cols) {\n      return _identity(rows, cols, config.matrix === 'Matrix' ? 'dense' : undefined)\n    },\n\n    'number | BigNumber, number | BigNumber, string': function (rows, cols, format) {\n      return _identity(rows, cols, format)\n    },\n\n    Array: function (size) {\n      return _identityVector(size)\n    },\n\n    'Array, string': function (size, format) {\n      return _identityVector(size, format)\n    },\n\n    Matrix: function (size) {\n      return _identityVector(size.valueOf(), size.storage())\n    },\n\n    'Matrix, string': function (size, format) {\n      return _identityVector(size.valueOf(), format)\n    }\n  })\n\n  function _identityVector (size, format) {\n    switch (size.length) {\n      case 0: return format ? matrix(format) : []\n      case 1: return _identity(size[0], size[0], format)\n      case 2: return _identity(size[0], size[1], format)\n      default: throw new Error('Vector containing two values expected')\n    }\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  function _identity (rows, cols, format) {\n    // BigNumber constructor with the right precision\n    const Big = (isBigNumber(rows) || isBigNumber(cols))\n      ? BigNumber\n      : null\n\n    if (isBigNumber(rows)) rows = rows.toNumber()\n    if (isBigNumber(cols)) cols = cols.toNumber()\n\n    if (!isInteger(rows) || rows < 1) {\n      throw new Error('Parameters in function identity must be positive integers')\n    }\n    if (!isInteger(cols) || cols < 1) {\n      throw new Error('Parameters in function identity must be positive integers')\n    }\n\n    const one = Big ? new BigNumber(1) : 1\n    const defaultValue = Big ? new Big(0) : 0\n    const size = [rows, cols]\n\n    // check we need to return a matrix\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      if (format === 'dense') {\n        return DenseMatrix.diagonal(size, one, 0, defaultValue)\n      }\n      throw new TypeError(`Unknown matrix type \"${format}\"`)\n    }\n\n    // create and resize array\n    const res = resize([], size, defaultValue)\n    // fill in ones on the diagonal\n    const minimum = rows < cols ? rows : cols\n    // fill diagonal\n    for (let d = 0; d < minimum; d++) {\n      res[d][d] = one\n    }\n    return res\n  }\n})\n","import { arraySize as size } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'kron'\nconst dependencies = ['typed', 'matrix', 'multiplyScalar']\n\nexport const createKron = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, multiplyScalar }) => {\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 (x, y) {\n      return matrix(_kron(x.toArray(), y.toArray()))\n    },\n\n    'Matrix, Array': function (x, y) {\n      return matrix(_kron(x.toArray(), y))\n    },\n\n    'Array, Matrix': function (x, y) {\n      return matrix(_kron(x, y.toArray()))\n    },\n\n    'Array, Array': _kron\n  })\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  function _kron (a, b) {\n    // Deal with the dimensions of the matricies.\n    if (size(a).length === 1) {\n      // Wrap it in a 2D Matrix\n      a = [a]\n    }\n    if (size(b).length === 1) {\n      // Wrap it in a 2D Matrix\n      b = [b]\n    }\n    if (size(a).length > 2 || size(b).length > 2) {\n      throw new RangeError('Vectors with dimensions greater then 2 are not supported expected ' +\n            '(Size x = ' + JSON.stringify(a.length) + ', y = ' + JSON.stringify(b.length) + ')')\n    }\n    const t = []\n    let r = []\n\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})\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'map'\nconst dependencies = ['typed']\n\nexport const createMap = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 callback is normally called with three arguments:\n   *    //    callback(value, index, Array)\n   *    // If you want to call with only one argument, use:\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\n    'Matrix, function': function (x, callback) {\n      return x.map(callback)\n    }\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 */\nfunction _map (array, callback) {\n  const recurse = function (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      // invoke the callback function with the right number of arguments\n      return applyCallback(callback, value, index, array, 'map')\n    }\n  }\n\n  return recurse(array, [])\n}\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'diff'\nconst dependencies = ['typed', 'matrix', 'subtract', 'number']\n\nexport const createDiff = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, number }) => {\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 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 | BigNumber} dim  Dimension\n   * @return {Array | Matrix}         Difference between array elements in given dimension\n   */\n  return typed(name, {\n    'Array | Matrix': function (arr) { // No dimension specified => assume dimension 0\n      if (isMatrix(arr)) {\n        return matrix(_diff(arr.toArray()))\n      } else {\n        return _diff(arr)\n      }\n    },\n    'Array | Matrix, number': function (arr, dim) {\n      if (!isInteger(dim)) throw new RangeError('Dimension must be a whole number')\n      if (isMatrix(arr)) {\n        return matrix(_recursive(arr.toArray(), dim))\n      } else {\n        return _recursive(arr, dim)\n      }\n    },\n    'Array, BigNumber': typed.referTo('Array,number', selfAn =>\n      (arr, dim) => selfAn(arr, number(dim))),\n    'Matrix, BigNumber': typed.referTo('Matrix,number', selfMn =>\n      (arr, dim) => selfMn(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  function _recursive (arr, dim) {\n    if (isMatrix(arr)) {\n      arr = arr.toArray() // Makes sure arrays like [ matrix([0, 1]), matrix([1, 0]) ] are processed properly\n    }\n    if (!Array.isArray(arr)) {\n      throw RangeError('Array/Matrix does not have that many dimensions')\n    }\n    if (dim > 0) {\n      const result = []\n      arr.forEach(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  /**\n   * Difference between elements in the array\n   *\n   * @param {Array} arr      An array\n   * @return {Array}         resulting array\n   */\n  function _diff (arr) {\n    const result = []\n    const size = arr.length\n    for (let i = 1; i < size; i++) {\n      result.push(_ElementDiff(arr[i - 1], arr[i]))\n    }\n    return result\n  }\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  function _ElementDiff (obj1, obj2) {\n    // Convert matrices to arrays\n    if (isMatrix(obj1)) obj1 = obj1.toArray()\n    if (isMatrix(obj2)) obj2 = obj2.toArray()\n\n    const obj1IsArray = Array.isArray(obj1)\n    const obj2IsArray = Array.isArray(obj2)\n    if (obj1IsArray && obj2IsArray) {\n      return _ArrayDiff(obj1, obj2)\n    }\n    if (!obj1IsArray && !obj2IsArray) {\n      return subtract(obj2, obj1) // Difference is (second - first) NOT (first - second)\n    }\n    throw TypeError('Cannot calculate difference between 1 array and 1 non-array')\n  }\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  function _ArrayDiff (arr1, arr2) {\n    if (arr1.length !== arr2.length) {\n      throw RangeError('Not all sub-arrays have the same length')\n    }\n    const result = []\n    const size = arr1.length\n    for (let i = 0; i < size; i++) {\n      result.push(_ElementDiff(arr1[i], arr2[i]))\n    }\n    return result\n  }\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { resize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ones'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createOnes = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\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()                    // returns []\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|BigNumber) | 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')\n        ? _ones([])\n        : _ones([], 'default')\n    },\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 (size) {\n      const last = size[size.length - 1]\n      if (typeof last === 'string') {\n        const 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\n    Array: _ones,\n\n    Matrix: function (size) {\n      const format = size.storage()\n      return _ones(size.valueOf(), format)\n    },\n\n    'Array | Matrix, string': function (size, format) {\n      return _ones(size.valueOf(), format)\n    }\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  function _ones (size, format) {\n    const hasBigNumbers = _normalize(size)\n    const defaultValue = hasBigNumbers ? new BigNumber(1) : 1\n    _validate(size)\n\n    if (format) {\n      // return a matrix\n      const m = matrix(format)\n      if (size.length > 0) {\n        return m.resize(size, defaultValue)\n      }\n      return m\n    } else {\n      // return an Array\n      const arr = []\n      if (size.length > 0) {\n        return resize(arr, size, defaultValue)\n      }\n      return arr\n    }\n  }\n\n  // replace BigNumbers with numbers, returns true if size contained BigNumbers\n  function _normalize (size) {\n    let hasBigNumbers = false\n    size.forEach(function (value, index, arr) {\n      if (isBigNumber(value)) {\n        hasBigNumbers = true\n        arr[index] = value.toNumber()\n      }\n    })\n    return hasBigNumbers\n  }\n\n  // validate arguments\n  function _validate (size) {\n    size.forEach(function (value) {\n      if (typeof value !== 'number' || !isInteger(value) || value < 0) {\n        throw new Error('Parameters in function ones must be positive integers')\n      }\n    })\n  }\n})\n","export function noBignumber () {\n  throw new Error('No \"bignumber\" implementation available')\n}\n\nexport function noFraction () {\n  throw new Error('No \"fraction\" implementation available')\n}\n\nexport function noMatrix () {\n  throw new Error('No \"matrix\" implementation available')\n}\n\nexport function noIndex () {\n  throw new Error('No \"index\" implementation available')\n}\n\nexport function noSubset () {\n  throw new Error('No \"matrix\" implementation available')\n}\n","import { factory } from '../../utils/factory.js'\nimport { noBignumber, noMatrix } from '../../utils/noop.js'\n\nconst name = 'range'\nconst dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']\n\nexport const createRange = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive }) => {\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 | Unit}`\n   *   Start of the range\n   * - `end: number | BigNumber | Unit`\n   *   End of the range, excluded by default, included when parameter includeEnd=true\n   * - `step: number | BigNumber | Unit`\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   *     math.range(math.unit(2, 'm'), math.unit(-3, 'm'), math.unit(-1, 'm')) // [2 m, 1 m, 0 m , -1 m, -2 m]\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\n    // TODO: a number or boolean should not be converted to string here\n    string: _strRange,\n    'string, boolean': _strRange,\n\n    'number, number': function (start, end) {\n      return _out(_range(start, end, 1, false))\n    },\n    'number, number, number': function (start, end, step) {\n      return _out(_range(start, end, step, false))\n    },\n    'number, number, boolean': function (start, end, includeEnd) {\n      return _out(_range(start, end, 1, includeEnd))\n    },\n    'number, number, number, boolean': function (start, end, step, includeEnd) {\n      return _out(_range(start, end, step, includeEnd))\n    },\n\n    'BigNumber, BigNumber': function (start, end) {\n      const BigNumber = start.constructor\n\n      return _out(_range(start, end, new BigNumber(1), false))\n    },\n    'BigNumber, BigNumber, BigNumber': function (start, end, step) {\n      return _out(_range(start, end, step, false))\n    },\n    'BigNumber, BigNumber, boolean': function (start, end, includeEnd) {\n      const BigNumber = start.constructor\n\n      return _out(_range(start, end, new BigNumber(1), includeEnd))\n    },\n    'BigNumber, BigNumber, BigNumber, boolean': function (start, end, step, includeEnd) {\n      return _out(_range(start, end, step, includeEnd))\n    },\n    'Unit, Unit, Unit': function (start, end, step) {\n      return _out(_range(start, end, step, false))\n    },\n    'Unit, Unit, Unit, boolean': function (start, end, step, includeEnd) {\n      return _out(_range(start, end, step, includeEnd))\n    }\n\n  })\n\n  function _out (arr) {\n    if (config.matrix === 'Matrix') {\n      return matrix ? matrix(arr) : noMatrix()\n    }\n\n    return arr\n  }\n\n  function _strRange (str, includeEnd) {\n    const r = _parse(str)\n    if (!r) {\n      throw new SyntaxError('String \"' + str + '\" is no valid range')\n    }\n\n    if (config.number === 'BigNumber') {\n      if (bignumber === undefined) {\n        noBignumber()\n      }\n\n      return _out(_range(\n        bignumber(r.start),\n        bignumber(r.end),\n        bignumber(r.step)),\n      includeEnd)\n    } else {\n      return _out(_range(r.start, r.end, r.step, includeEnd))\n    }\n  }\n\n  /**\n   * Create a range with numbers or BigNumbers\n   * @param {number | BigNumber | Unit} start\n   * @param {number | BigNumber | Unit} end\n   * @param {number | BigNumber | Unit} step\n   * @param {boolean} includeEnd\n   * @returns {Array} range\n   * @private\n   */\n  function _range (start, end, step, includeEnd) {\n    const array = []\n    const ongoing = isPositive(step)\n      ? includeEnd ? smallerEq : smaller\n      : includeEnd ? largerEq : larger\n    let x = start\n    while (ongoing(x, end)) {\n      array.push(x)\n      x = add(x, step)\n    }\n    return array\n  }\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  function _parse (str) {\n    const args = str.split(':')\n\n    // number\n    const 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\n    const invalid = nums.some(function (num) {\n      return isNaN(num)\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})\n","import { reshape as arrayReshape } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'reshape'\nconst dependencies = ['typed', 'isInteger', 'matrix']\n\nexport const createReshape = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\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\n    'Matrix, Array': function (x, sizes) {\n      return x.reshape(sizes, true)\n    },\n\n    'Array, Array': function (x, sizes) {\n      sizes.forEach(function (size) {\n        if (!isInteger(size)) {\n          throw new TypeError('Invalid size for dimension: ' + size)\n        }\n      })\n      return arrayReshape(x, sizes)\n    }\n\n  })\n})\n","import { isBigNumber, isMatrix } from '../../utils/is.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\nimport { isInteger } from '../../utils/number.js'\nimport { format } from '../../utils/string.js'\nimport { clone } from '../../utils/object.js'\nimport { resize as arrayResize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'resize'\nconst dependencies = ['config', 'matrix']\n\nexport const createResize = /* #__PURE__ */ factory(name, dependencies, ({ config, matrix }) => {\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('resize', arguments.length, 2, 3)\n    }\n\n    if (isMatrix(size)) {\n      size = size.valueOf() // get Array\n    }\n\n    if (isBigNumber(size[0])) {\n      // convert bignumbers to numbers\n      size = size.map(function (value) {\n        return !isBigNumber(value) ? value : value.toNumber()\n      })\n    }\n\n    // check x is a Matrix\n    if (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    }\n\n    // check result should be a matrix\n    const 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 clone(x)\n    } else {\n      // output an array/matrix\n      if (!Array.isArray(x)) {\n        x = [x]\n      }\n      x = clone(x)\n\n      const res = arrayResize(x, size, defaultValue)\n      return asMatrix ? matrix(res) : res\n    }\n  }\n\n  /**\n   * Resize a string\n   * @param {string} str\n   * @param {number[]} size\n   * @param {string} [defaultChar=' ']\n   * @private\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(size.length, 1)\n    }\n    const len = size[0]\n    if (typeof len !== 'number' || !isInteger(len)) {\n      throw new TypeError('Invalid size, must contain positive integers ' +\n          '(size: ' + format(size) + ')')\n    }\n\n    if (str.length > len) {\n      return str.substring(0, len)\n    } else if (str.length < len) {\n      let res = str\n      for (let i = 0, ii = len - str.length; i < ii; i++) {\n        res += defaultChar\n      }\n      return res\n    } else {\n      return str\n    }\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { arraySize } from '../../utils/array.js'\n\nconst name = 'rotate'\nconst dependencies = [\n  'typed',\n  'multiply',\n  'rotationMatrix'\n]\n\nexport const createRotate = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed, multiply, 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 [-12, 11]\n     *    math.rotate(matrix([11, 12]), math.pi / 2)                   // returns [-12, 11]\n     *\n     *    math.rotate([1, 0, 0], unit('90deg'), [0, 0, 1])             // returns [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 [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 (w, theta) {\n      _validateSize(w, 2)\n      const matrixRes = multiply(rotationMatrix(theta), w)\n      return matrixRes.toArray()\n    },\n\n    'Matrix , number | BigNumber | Complex | Unit': function (w, theta) {\n      _validateSize(w, 2)\n      return multiply(rotationMatrix(theta), w)\n    },\n\n    'Array, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) {\n      _validateSize(w, 3)\n      const matrixRes = multiply(rotationMatrix(theta, v), w)\n      return matrixRes\n    },\n\n    'Matrix, number | BigNumber | Complex | Unit, Array | Matrix': function (w, theta, v) {\n      _validateSize(w, 3)\n      return multiply(rotationMatrix(theta, v), w)\n    }\n  })\n\n  function _validateSize (v, expectedSize) {\n    const actualSize = Array.isArray(v) ? arraySize(v) : v.size()\n    if (actualSize.length > 2) {\n      throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n    }\n    if (actualSize.length === 2 && actualSize[1] !== 1) {\n      throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n    }\n    if (actualSize[0] !== expectedSize) {\n      throw new RangeError(`Vector must be of dimensions 1x${expectedSize}`)\n    }\n  }\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'rotationMatrix'\nconst dependencies = [\n  'typed',\n  'config',\n  'multiplyScalar',\n  'addScalar',\n  'unaryMinus',\n  'norm',\n  'matrix',\n  'BigNumber',\n  'DenseMatrix',\n  'SparseMatrix',\n  'cos',\n  'sin'\n]\n\nexport const createRotationMatrix = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed, config, multiplyScalar,\n    addScalar, unaryMinus, norm, BigNumber,\n    matrix, DenseMatrix, SparseMatrix, cos, 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\n  return typed(name, {\n    '': function () {\n      return (config.matrix === 'Matrix') ? matrix([]) : []\n    },\n\n    string: function (format) {\n      return matrix(format)\n    },\n\n    'number | BigNumber | Complex | Unit': function (theta) {\n      return _rotationMatrix2x2(theta, config.matrix === 'Matrix' ? 'dense' : undefined)\n    },\n\n    'number | BigNumber | Complex | Unit, string': function (theta, format) {\n      return _rotationMatrix2x2(theta, format)\n    },\n\n    'number | BigNumber | Complex | Unit, Array': function (theta, v) {\n      const matrixV = matrix(v)\n      _validateVector(matrixV)\n      return _rotationMatrix3x3(theta, matrixV, undefined)\n    },\n\n    'number | BigNumber | Complex | Unit, Matrix': function (theta, v) {\n      _validateVector(v)\n      const storageType = v.storage() || (config.matrix === 'Matrix' ? 'dense' : undefined)\n      return _rotationMatrix3x3(theta, v, storageType)\n    },\n\n    'number | BigNumber | Complex | Unit, Array, string': function (theta, v, format) {\n      const matrixV = matrix(v)\n      _validateVector(matrixV)\n      return _rotationMatrix3x3(theta, matrixV, format)\n    },\n\n    'number | BigNumber | Complex | Unit, Matrix, string': function (theta, v, format) {\n      _validateVector(v)\n      return _rotationMatrix3x3(theta, v, format)\n    }\n\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  function _rotationMatrix2x2 (theta, format) {\n    const Big = isBigNumber(theta)\n\n    const minusOne = Big ? new BigNumber(-1) : -1\n    const cosTheta = cos(theta)\n    const sinTheta = sin(theta)\n    const data = [[cosTheta, multiplyScalar(minusOne, sinTheta)], [sinTheta, cosTheta]]\n\n    return _convertToFormat(data, format)\n  }\n\n  function _validateVector (v) {\n    const size = v.size()\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((p, curr) => multiplyScalar(p, curr))\n  }\n\n  function _convertToFormat (data, format) {\n    if (format) {\n      if (format === 'sparse') {\n        return new SparseMatrix(data)\n      }\n      if (format === 'dense') {\n        return new DenseMatrix(data)\n      }\n      throw new TypeError(`Unknown matrix type \"${format}\"`)\n    }\n    return data\n  }\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  function _rotationMatrix3x3 (theta, v, format) {\n    const normV = norm(v)\n    if (normV === 0) {\n      throw new RangeError('Rotation around zero vector')\n    }\n\n    const Big = isBigNumber(theta) ? BigNumber : null\n\n    const one = Big ? new Big(1) : 1\n    const minusOne = Big ? new Big(-1) : -1\n    const vx = Big ? new Big(v.get([0]) / normV) : v.get([0]) / normV\n    const vy = Big ? new Big(v.get([1]) / normV) : v.get([1]) / normV\n    const vz = Big ? new Big(v.get([2]) / normV) : v.get([2]) / normV\n    const c = cos(theta)\n    const oneMinusC = addScalar(one, unaryMinus(c))\n    const s = sin(theta)\n\n    const r11 = addScalar(c, _mul([vx, vx, oneMinusC]))\n    const r12 = addScalar(_mul([vx, vy, oneMinusC]), _mul([minusOne, vz, s]))\n    const r13 = addScalar(_mul([vx, vz, oneMinusC]), _mul([vy, s]))\n\n    const r21 = addScalar(_mul([vx, vy, oneMinusC]), _mul([vz, s]))\n    const r22 = addScalar(c, _mul([vy, vy, oneMinusC]))\n    const r23 = addScalar(_mul([vy, vz, oneMinusC]), _mul([minusOne, vx, s]))\n\n    const r31 = addScalar(_mul([vx, vz, oneMinusC]), _mul([minusOne, vy, s]))\n    const r32 = addScalar(_mul([vy, vz, oneMinusC]), _mul([vx, s]))\n    const r33 = addScalar(c, _mul([vz, vz, oneMinusC]))\n\n    const data = [[r11, r12, r13], [r21, r22, r23], [r31, r32, r33]]\n\n    return _convertToFormat(data, format)\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { validateIndex } from '../../utils/array.js'\n\nconst name = 'row'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\nexport const createRow = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\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\n    'Array, number': function (value, row) {\n      return _row(matrix(clone(value)), row).valueOf()\n    }\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  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    validateIndex(row, value.size()[0])\n\n    const columnRange = range(0, value.size()[1])\n    const index = new Index(row, columnRange)\n    const result = value.subset(index)\n    return isMatrix(result)\n      ? result\n      : matrix([[result]])\n  }\n})\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { noMatrix } from '../../utils/noop.js'\n\nconst name = 'size'\nconst dependencies = ['typed', 'config', '?matrix']\n\nexport const createSize = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix }) => {\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 (x) {\n      return x.create(x.size())\n    },\n\n    Array: arraySize,\n\n    string: function (x) {\n      return (config.matrix === 'Array') ? [x.length] : matrix([x.length])\n    },\n\n    'number | Complex | BigNumber | Unit | boolean | null': function (x) {\n      // scalar\n      return (config.matrix === 'Array')\n        ? []\n        : matrix ? matrix([]) : noMatrix()\n    }\n  })\n})\n","import { clone } from '../../utils/object.js'\nimport { squeeze as arraySqueeze } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'squeeze'\nconst dependencies = ['typed', 'matrix']\n\nexport const createSqueeze = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix }) => {\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 (x) {\n      return arraySqueeze(clone(x))\n    },\n\n    Matrix: function (x) {\n      const res = arraySqueeze(x.toArray())\n      // FIXME: return the same type of matrix as the input\n      return Array.isArray(res) ? matrix(res) : res\n    },\n\n    any: function (x) {\n      // scalar\n      return clone(x)\n    }\n  })\n})\n","import { isIndex } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { isEmptyIndex, validateIndex, validateIndexSourceSize } from '../../utils/array.js'\nimport { getSafeProperty, setSafeProperty } from '../../utils/customs.js'\nimport { DimensionError } from '../../error/DimensionError.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'subset'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createSubset = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\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   *     math.subset(d, math.index([false, true], 0)) // returns [[3]]\n   *\n   *     // replace a subset\n   *     const e = []\n   *     const f = math.subset(e, math.index(0, [0, 2]), [5, 6])  // f = [[5, 0, 6]]\n   *     const g = math.subset(f, math.index(1, 1), 7, 0)         // g = [[5, 0, 6], [0, 7, 0]]\n   *     math.subset(g, math.index([false, true], 1), 8)          // returns [[5, 0, 6], [0, 8, 0]]\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\n  return typed(name, {\n    // get subset\n    'Matrix, Index': function (value, index) {\n      if (isEmptyIndex(index)) { return matrix() }\n      validateIndexSourceSize(value, index)\n      return value.subset(index)\n    },\n\n    'Array, Index': typed.referTo('Matrix, Index', function (subsetRef) {\n      return function (value, index) {\n        const subsetResult = subsetRef(matrix(value), index)\n        return index.isScalar() ? subsetResult : subsetResult.valueOf()\n      }\n    }),\n\n    'Object, Index': _getObjectProperty,\n\n    'string, Index': _getSubstring,\n\n    // set subset\n    'Matrix, Index, any, any': function (value, index, replacement, defaultValue) {\n      if (isEmptyIndex(index)) { return value }\n      validateIndexSourceSize(value, index)\n      return value.clone().subset(index, _broadcastReplacement(replacement, index), defaultValue)\n    },\n\n    'Array, Index, any, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n      return function (value, index, replacement, defaultValue) {\n        const subsetResult = subsetRef(matrix(value), index, replacement, defaultValue)\n        return subsetResult.isMatrix ? subsetResult.valueOf() : subsetResult\n      }\n    }),\n\n    'Array, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n      return function (value, index, replacement) {\n        return subsetRef(matrix(value), index, replacement, undefined).valueOf()\n      }\n    }),\n\n    'Matrix, Index, any': typed.referTo('Matrix, Index, any, any', function (subsetRef) {\n      return function (value, index, replacement) { return subsetRef(value, index, replacement, undefined) }\n    }),\n\n    'string, Index, string': _setSubstring,\n    'string, Index, string, string': _setSubstring,\n    'Object, Index, any': _setObjectProperty\n  })\n\n  /**\n   * Broadcasts a replacment value to be the same size as index\n   * @param {number | BigNumber | Array | Matrix} replacement Replacement value to try to broadcast\n   * @param {*} index Index value\n   * @returns broadcasted replacement that matches the size of index\n   */\n\n  function _broadcastReplacement (replacement, index) {\n    if (typeof replacement === 'string') {\n      throw new Error('can\\'t boradcast a string')\n    }\n    if (index._isScalar) {\n      return replacement\n    }\n\n    const indexSize = index.size()\n    if (indexSize.every(d => d > 0)) {\n      try {\n        return add(replacement, zeros(indexSize))\n      } catch (error) {\n        return replacement\n      }\n    } else {\n      return replacement\n    }\n  }\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 */\nfunction _getSubstring (str, index) {\n  if (!isIndex(index)) {\n    // TODO: better error message\n    throw new TypeError('Index expected')\n  }\n\n  if (isEmptyIndex(index)) { return '' }\n  validateIndexSourceSize(Array.from(str), index)\n\n  if (index.size().length !== 1) {\n    throw new DimensionError(index.size().length, 1)\n  }\n\n  // validate whether the range is out of range\n  const strLen = str.length\n  validateIndex(index.min()[0], strLen)\n  validateIndex(index.max()[0], strLen)\n\n  const range = index.dimension(0)\n\n  let substr = ''\n  range.forEach(function (v) {\n    substr += str.charAt(v)\n  })\n\n  return substr\n}\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 used when resizing\n *                                the string. is ' ' by default\n * @returns {string} result\n * @private\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  if (isEmptyIndex(index)) { return str }\n  validateIndexSourceSize(Array.from(str), index)\n  if (index.size().length !== 1) {\n    throw new DimensionError(index.size().length, 1)\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  const range = index.dimension(0)\n  const len = range.size()[0]\n\n  if (len !== replacement.length) {\n    throw new DimensionError(range.size()[0], replacement.length)\n  }\n\n  // validate whether the range is out of range\n  const strLen = str.length\n  validateIndex(index.min()[0])\n  validateIndex(index.max()[0])\n\n  // copy the string into an array with characters\n  const chars = []\n  for (let 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  })\n\n  // initialize undefined characters with a space\n  if (chars.length > strLen) {\n    for (let 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/**\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 */\nfunction _getObjectProperty (object, index) {\n  if (isEmptyIndex(index)) { return undefined }\n\n  if (index.size().length !== 1) {\n    throw new DimensionError(index.size(), 1)\n  }\n\n  const key = index.dimension(0)\n  if (typeof key !== 'string') {\n    throw new TypeError('String expected as index to retrieve an object property')\n  }\n\n  return getSafeProperty(object, key)\n}\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 */\nfunction _setObjectProperty (object, index, replacement) {\n  if (isEmptyIndex(index)) { return object }\n  if (index.size().length !== 1) {\n    throw new DimensionError(index.size(), 1)\n  }\n\n  const key = index.dimension(0)\n  if (typeof key !== 'string') {\n    throw new TypeError('String expected as index to retrieve an object property')\n  }\n\n  // clone the object, and apply the property to the clone\n  const updated = clone(object)\n  setSafeProperty(updated, key, replacement)\n\n  return updated\n}\n","import { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'transpose'\nconst dependencies = ['typed', 'matrix']\n\nexport const createTranspose = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix }) => {\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(name, {\n    Array: x => transposeMatrix(matrix(x)).valueOf(),\n    Matrix: transposeMatrix,\n    any: clone // scalars\n  })\n\n  function transposeMatrix (x) {\n    // matrix size\n    const size = x.size()\n\n    // result\n    let c\n\n    // process dimensions\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          const rows = size[0]\n          const columns = size[1]\n\n          // check columns\n          if (columns === 0) {\n            // throw exception\n            throw new RangeError('Cannot transpose a 2D matrix with no columns (size: ' + format(size) + ')')\n          }\n\n          // process storage format\n          switch (x.storage()) {\n            case 'dense':\n              c = _denseTranspose(x, rows, columns)\n              break\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: ' + format(size) + ')')\n    }\n    return c\n  }\n\n  function _denseTranspose (m, rows, columns) {\n    // matrix array\n    const data = m._data\n    // transposed matrix data\n    const transposed = []\n    let transposedRow\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // initialize row\n      transposedRow = transposed[j] = []\n      // loop rows\n      for (let i = 0; i < rows; i++) {\n        // set data\n        transposedRow[i] = clone(data[i][j])\n      }\n    }\n    // return matrix\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    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n    // result matrices\n    const cvalues = values ? [] : undefined\n    const cindex = []\n    const cptr = []\n    // row counts\n    const w = []\n    for (let x = 0; x < rows; x++) { w[x] = 0 }\n    // vars\n    let p, l, j\n    // loop values in matrix\n    for (p = 0, l = index.length; p < l; p++) {\n      // number of values in row\n      w[index[p]]++\n    }\n    // cumulative sum\n    let sum = 0\n    // initialize cptr with the cummulative sum of row counts\n    for (let i = 0; i < rows; i++) {\n      // update cptr\n      cptr.push(sum)\n      // update sum\n      sum += w[i]\n      // update w\n      w[i] = cptr[i]\n    }\n    // update cptr\n    cptr.push(sum)\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // values & index in column\n      for (let k0 = ptr[j], k1 = ptr[j + 1], k = k0; k < k1; k++) {\n        // C values & index\n        const q = w[index[k]]++\n        // C[j, i] = A[i, j]\n        cindex[q] = j\n        // check we need to process values (pattern matrix)\n        if (values) { cvalues[q] = clone(values[k]) }\n      }\n    }\n    // return matrix\n    return m.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [columns, rows],\n      datatype: m._datatype\n    })\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'ctranspose'\nconst dependencies = ['typed', 'transpose', 'conj']\n\nexport const createCtranspose = /* #__PURE__ */ factory(name, dependencies, ({ typed, transpose, conj }) => {\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 (x) {\n      return conj(transpose(x))\n    }\n  })\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { resize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'zeros'\nconst dependencies = ['typed', 'config', 'matrix', 'BigNumber']\n\nexport const createZeros = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, BigNumber }) => {\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()                   // returns []\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|BigNumber) | 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')\n        ? _zeros([])\n        : _zeros([], 'default')\n    },\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 (size) {\n      const last = size[size.length - 1]\n      if (typeof last === 'string') {\n        const 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\n    Array: _zeros,\n\n    Matrix: function (size) {\n      const format = size.storage()\n      return _zeros(size.valueOf(), format)\n    },\n\n    'Array | Matrix, string': function (size, format) {\n      return _zeros(size.valueOf(), format)\n    }\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  function _zeros (size, format) {\n    const hasBigNumbers = _normalize(size)\n    const defaultValue = hasBigNumbers ? new BigNumber(0) : 0\n    _validate(size)\n\n    if (format) {\n      // return a matrix\n      const m = matrix(format)\n      if (size.length > 0) {\n        return m.resize(size, defaultValue)\n      }\n      return m\n    } else {\n      // return an Array\n      const arr = []\n      if (size.length > 0) {\n        return resize(arr, size, defaultValue)\n      }\n      return arr\n    }\n  }\n\n  // replace BigNumbers with numbers, returns true if size contained BigNumbers\n  function _normalize (size) {\n    let hasBigNumbers = false\n    size.forEach(function (value, index, arr) {\n      if (isBigNumber(value)) {\n        hasBigNumbers = true\n        arr[index] = value.toNumber()\n      }\n    })\n    return hasBigNumbers\n  }\n\n  // validate arguments\n  function _validate (size) {\n    size.forEach(function (value) {\n      if (typeof value !== 'number' || !isInteger(value) || value < 0) {\n        throw new Error('Parameters in function zeros must be positive integers')\n      }\n    })\n  }\n})\n\n// TODO: zeros contains almost the same code as ones. Reuse this?\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'fft'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'addScalar',\n  'multiplyScalar',\n  'divideScalar',\n  'exp',\n  'tau',\n  'i',\n  'dotDivide',\n  'conj',\n  'pow',\n  'ceil',\n  'log2'\n]\n\nexport const createFft = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  matrix,\n  addScalar,\n  multiplyScalar,\n  divideScalar,\n  exp,\n  tau,\n  i: I,\n  dotDivide,\n  conj,\n  pow,\n  ceil,\n  log2\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) {\n      return matrix.create(_ndFft(matrix.toArray()))\n    }\n  })\n\n  /**\n   * Perform an N-dimensional Fourier transform\n   *\n   * @param {Array} arr      The array\n   * @return {Array}         resulting array\n   */\n  function _ndFft (arr) {\n    const size = arraySize(arr)\n    if (size.length === 1) return _fft(arr, size[0])\n    // ndFft along dimension 1,...,N-1 then 1dFft along dimension 0\n    return _1dFft(arr.map(slice => _ndFft(slice, size.slice(1))), 0)\n  }\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  function _1dFft (arr, dim) {\n    const size = arraySize(arr)\n    if (dim !== 0) return new Array(size[0]).fill(0).map((_, i) => _1dFft(arr[i], dim - 1))\n    if (size.length === 1) return _fft(arr)\n    function _transpose (arr) { // Swap first 2 dimensions\n      const size = arraySize(arr)\n      return new Array(size[1]).fill(0).map((_, j) => new Array(size[0]).fill(0).map((_, i) => arr[i][j]))\n    }\n    return _transpose(_1dFft(_transpose(arr), 1))\n  }\n  /**\n   * Perform an 1-dimensional non-power-of-2 Fourier transform using Chirp-Z Transform\n   *\n   * @param {Array} arr      The array\n   * @return {Array}         resulting array\n   */\n  function _czt (arr) {\n    const n = arr.length\n    const w = exp(divideScalar(multiplyScalar(-1, multiplyScalar(I, tau)), n))\n    const chirp = []\n    for (let i = 1 - n; i < n; i++) {\n      chirp.push(pow(w, divideScalar(pow(i, 2), 2)))\n    }\n    const N2 = pow(2, ceil(log2(n + n - 1)))\n    const xp = [\n      ...new Array(n).fill(0).map((_, i) => multiplyScalar(arr[i], chirp[n - 1 + i])),\n      ...new Array(N2 - n).fill(0)\n    ]\n    const ichirp = [\n      ...new Array(n + n - 1).fill(0).map((_, i) => divideScalar(1, chirp[i])),\n      ...new Array(N2 - (n + n - 1)).fill(0)\n    ]\n    const fftXp = _fft(xp)\n    const fftIchirp = _fft(ichirp)\n    const fftProduct = new Array(N2).fill(0).map((_, i) => multiplyScalar(fftXp[i], fftIchirp[i]))\n    const ifftProduct = dotDivide(conj(_ndFft(conj(fftProduct))), N2)\n    const ret = []\n    for (let i = n - 1; i < n + n - 1; i++) {\n      ret.push(multiplyScalar(ifftProduct[i], chirp[i]))\n    }\n    return ret\n  }\n  /**\n   * Perform an 1-dimensional Fourier transform\n   *\n   * @param {Array} arr      The array\n   * @return {Array}         resulting array\n   */\n  function _fft (arr) {\n    const len = arr.length\n    if (len === 1) return [arr[0]]\n    if (len % 2 === 0) {\n      const ret = [\n        ..._fft(arr.filter((_, i) => i % 2 === 0), len / 2),\n        ..._fft(arr.filter((_, i) => i % 2 === 1), len / 2)\n      ]\n      for (let k = 0; k < len / 2; k++) {\n        const p = ret[k]\n        const q = multiplyScalar(\n          ret[k + len / 2],\n          exp(\n            multiplyScalar(multiplyScalar(tau, I), divideScalar(-k, len))\n          )\n        )\n        ret[k] = addScalar(p, q)\n        ret[k + len / 2] = addScalar(p, multiplyScalar(-1, q))\n      }\n      return ret\n    } else {\n      // use chirp-z transform for non-power-of-2 FFT\n      return _czt(arr)\n    }\n    // throw new Error('Can only calculate FFT of power-of-two size')\n  }\n})\n","import { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'ifft'\nconst dependencies = [\n  'typed',\n  'fft',\n  'dotDivide',\n  'conj'\n]\n\nexport const createIfft = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  fft,\n  dotDivide,\n  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 (arr) {\n      const size = isMatrix(arr) ? arr.size() : arraySize(arr)\n      return dotDivide(conj(fft(conj(arr))), size.reduce((acc, curr) => acc * curr, 1))\n    }\n  })\n})\n","import { isUnit, isNumber, isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'solveODE'\nconst dependencies = [\n  'typed',\n  'add',\n  'subtract',\n  'multiply',\n  'divide',\n  'max',\n  'map',\n  'abs',\n  'isPositive',\n  'isNegative',\n  'larger',\n  'smaller',\n  'matrix',\n  'bignumber',\n  'unaryMinus'\n]\n\nexport const createSolveODE = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    add,\n    subtract,\n    multiply,\n    divide,\n    max,\n    map,\n    abs,\n    isPositive,\n    isNegative,\n    larger,\n    smaller,\n    matrix,\n    bignumber,\n    unaryMinus\n  }\n) => {\n  /**\n     * Numerical Integration of Ordinary Differential Equations\n     *\n     * Two variable step methods are provided:\n     * - \"RK23\": Bogacki–Shampine method\n     * - \"RK45\": Dormand-Prince method RK5(4)7M (default)\n     *\n     * The arguments are expected as follows.\n     *\n     * - `func` should be the forcing function `f(t, y)`\n     * - `tspan` should be a vector of two numbers or units `[tStart, tEnd]`\n     * - `y0` the initial state values, should be a scalar or a flat array\n     * - `options` should be an object with the following information:\n     *   - `method` ('RK45'): ['RK23', 'RK45']\n     *   - `tol` (1e-3): Numeric tolerance of the method, the solver keeps the error estimates less than this value\n     *   - `firstStep`: Initial step size\n     *   - `minStep`: minimum step size of the method\n     *   - `maxStep`: maximum step size of the method\n     *   - `minDelta` (0.2): minimum ratio of change for the step\n     *   - `maxDelta` (5): maximum ratio of change for the step\n     *   - `maxIter` (1e4): maximum number of iterations\n     *\n     * The returned value is an object with `{t, y}` please note that even though `t` means time, it can represent any other independant variable like `x`:\n     * - `t` an array of size `[n]`\n     * - `y` the states array can be in two ways\n     *   - **if `y0` is a scalar:** returns an array-like of size `[n]`\n     *   - **if `y0` is a flat array-like of size [m]:** returns an array like of size `[n, m]`\n     *\n     * Syntax:\n     *\n     *     math.solveODE(func, tspan, y0)\n     *     math.solveODE(func, tspan, y0, options)\n     *\n     * Examples:\n     *\n     *     function func(t, y) {return y}\n     *     const tspan = [0, 4]\n     *     const y0 = 1\n     *     math.solveODE(func, tspan, y0)\n     *     math.solveODE(func, tspan, [1, 2])\n     *     math.solveODE(func, tspan, y0, { method:\"RK23\", maxStep:0.1 })\n     *\n     * See also:\n     *\n     *     derivative, simplifyCore\n     *\n     * @param {function} func The forcing function f(t,y)\n     * @param {Array | Matrix} tspan The time span\n     * @param {number | BigNumber | Unit | Array | Matrix} y0 The initial value\n     * @param {Object} [options] Optional configuration options\n     * @return {Object} Return an object with t and y values as arrays\n     */\n\n  function _rk (butcherTableau) {\n    // generates an adaptive runge kutta method from it's butcher tableau\n\n    return function (f, tspan, y0, options) {\n      // adaptive runge kutta methods\n      const wrongTSpan = !((tspan.length === 2) && (tspan.every(isNumOrBig) || tspan.every(isUnit)))\n      if (wrongTSpan) {\n        throw new Error('\"tspan\" must be an Array of two numeric values or two units [tStart, tEnd]')\n      }\n      const t0 = tspan[0] // initial time\n      const tf = tspan[1] // final time\n      const isForwards = larger(tf, t0)\n      const firstStep = options.firstStep\n      if (firstStep !== undefined && !isPositive(firstStep)) {\n        throw new Error('\"firstStep\" must be positive')\n      }\n      const maxStep = options.maxStep\n      if (maxStep !== undefined && !isPositive(maxStep)) {\n        throw new Error('\"maxStep\" must be positive')\n      }\n      const minStep = options.minStep\n      if (minStep && isNegative(minStep)) {\n        throw new Error('\"minStep\" must be positive or zero')\n      }\n      const timeVars = [t0, tf, firstStep, minStep, maxStep].filter(x => x !== undefined)\n      if (!(timeVars.every(isNumOrBig) || timeVars.every(isUnit))) {\n        throw new Error('Inconsistent type of \"t\" dependant variables')\n      }\n      const steps = 1 // divide time in this number of steps\n      const tol = options.tol ? options.tol : 1e-4 // define a tolerance (must be an option)\n      const minDelta = options.minDelta ? options.minDelta : 0.2\n      const maxDelta = options.maxDelta ? options.maxDelta : 5\n      const maxIter = options.maxIter ? options.maxIter : 10_000 // stop inifite evaluation if something goes wrong\n      const hasBigNumbers = [t0, tf, ...y0, maxStep, minStep].some(isBigNumber)\n      const [a, c, b, bp] = hasBigNumbers\n        ? [\n            bignumber(butcherTableau.a),\n            bignumber(butcherTableau.c),\n            bignumber(butcherTableau.b),\n            bignumber(butcherTableau.bp)\n          ]\n        : [butcherTableau.a, butcherTableau.c, butcherTableau.b, butcherTableau.bp]\n\n      let h = firstStep\n        ? isForwards ? firstStep : unaryMinus(firstStep)\n        : divide(subtract(tf, t0), steps) // define the first step size\n      const t = [t0] // start the time array\n      const y = [y0] // start the solution array\n\n      const deltaB = subtract(b, bp) // b - bp\n\n      let n = 0\n      let iter = 0\n      const ongoing = _createOngoing(isForwards)\n      const trimStep = _createTrimStep(isForwards)\n      // iterate unitil it reaches either the final time or maximum iterations\n      while (ongoing(t[n], tf)) {\n        const k = []\n\n        // trim the time step so that it doesn't overshoot\n        h = trimStep(t[n], tf, h)\n\n        // calculate the first value of k\n        k.push(f(t[n], y[n]))\n\n        // calculate the rest of the values of k\n        for (let i = 1; i < c.length; ++i) {\n          k.push(\n            f(\n              add(t[n], multiply(c[i], h)),\n              add(y[n], multiply(h, a[i], k))\n            )\n          )\n        }\n\n        // estimate the error by comparing solutions of different orders\n        const TE = max(\n          abs(\n            map(multiply(deltaB, k), (X) =>\n              isUnit(X) ? X.value : X\n            )\n          )\n        )\n\n        if (TE < tol && tol / TE > 1 / 4) {\n          // push solution if within tol\n          t.push(add(t[n], h))\n          y.push(add(y[n], multiply(h, b, k)))\n          n++\n        }\n\n        // estimate the delta value that will affect the step size\n        let delta = 0.84 * (tol / TE) ** (1 / 5)\n\n        if (smaller(delta, minDelta)) {\n          delta = minDelta\n        } else if (larger(delta, maxDelta)) {\n          delta = maxDelta\n        }\n\n        delta = hasBigNumbers ? bignumber(delta) : delta\n        h = multiply(h, delta)\n\n        if (maxStep && larger(abs(h), maxStep)) {\n          h = isForwards ? maxStep : unaryMinus(maxStep)\n        } else if (minStep && smaller(abs(h), minStep)) {\n          h = isForwards ? minStep : unaryMinus(minStep)\n        }\n        iter++\n        if (iter > maxIter) {\n          throw new Error('Maximum number of iterations reached, try changing options')\n        }\n      }\n      return { t, y }\n    }\n  }\n\n  function _rk23 (f, tspan, y0, options) {\n    // Bogacki–Shampine method\n\n    // Define the butcher table\n    const a = [\n      [],\n      [1 / 2],\n      [0, 3 / 4],\n      [2 / 9, 1 / 3, 4 / 9]\n    ]\n\n    const c = [null, 1 / 2, 3 / 4, 1]\n    const b = [2 / 9, 1 / 3, 4 / 9, 0]\n    const bp = [7 / 24, 1 / 4, 1 / 3, 1 / 8]\n\n    const butcherTableau = { a, c, b, bp }\n\n    // Solve an adaptive step size rk method\n    return _rk(butcherTableau)(f, tspan, y0, options)\n  }\n\n  function _rk45 (f, tspan, y0, options) {\n    // Dormand Prince method\n\n    // Define the butcher tableau\n    const a = [\n      [],\n      [1 / 5],\n      [3 / 40, 9 / 40],\n      [44 / 45, -56 / 15, 32 / 9],\n      [19372 / 6561, -25360 / 2187, 64448 / 6561, -212 / 729],\n      [9017 / 3168, -355 / 33, 46732 / 5247, 49 / 176, -5103 / 18656],\n      [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84]\n    ]\n\n    const c = [null, 1 / 5, 3 / 10, 4 / 5, 8 / 9, 1, 1]\n    const b = [35 / 384, 0, 500 / 1113, 125 / 192, -2187 / 6784, 11 / 84, 0]\n    const bp = [5179 / 57600, 0, 7571 / 16695, 393 / 640, -92097 / 339200, 187 / 2100, 1 / 40]\n\n    const butcherTableau = { a, c, b, bp }\n\n    // Solve an adaptive step size rk method\n    return _rk(butcherTableau)(f, tspan, y0, options)\n  }\n\n  function _solveODE (f, tspan, y0, opt) {\n    const method = opt.method ? opt.method : 'RK45'\n    const methods = {\n      RK23: _rk23,\n      RK45: _rk45\n    }\n    if (method.toUpperCase() in methods) {\n      const methodOptions = { ...opt } // clone the options object\n      delete methodOptions.method // delete the method as it won't be needed\n      return methods[method.toUpperCase()](f, tspan, y0, methodOptions)\n    } else {\n      // throw an error indicating there is no such method\n      const methodsWithQuotes = Object.keys(methods).map(x => `\"${x}\"`)\n      // generates a string of methods like: \"BDF\", \"RK23\" and \"RK45\"\n      const availableMethodsString = `${methodsWithQuotes.slice(0, -1).join(', ')} and ${methodsWithQuotes.slice(-1)}`\n      throw new Error(`Unavailable method \"${method}\". Available methods are ${availableMethodsString}`)\n    }\n  }\n\n  function _createOngoing (isForwards) {\n    // returns the correct function to test if it's still iterating\n    return isForwards ? smaller : larger\n  }\n\n  function _createTrimStep (isForwards) {\n    const outOfBounds = isForwards ? larger : smaller\n    return function (t, tf, h) {\n      const next = add(t, h)\n      return outOfBounds(next, tf) ? subtract(tf, t) : h\n    }\n  }\n\n  function isNumOrBig (x) {\n    // checks if it's a number or bignumber\n    return isBigNumber(x) || isNumber(x)\n  }\n\n  function _matrixSolveODE (f, T, y0, options) {\n    // receives matrices and returns matrices\n    const sol = _solveODE(f, T.toArray(), y0.toArray(), options)\n    return { t: matrix(sol.t), y: matrix(sol.y) }\n  }\n\n  return typed('solveODE', {\n    'function, Array, Array, Object': _solveODE,\n    'function, Matrix, Matrix, Object': _matrixSolveODE,\n    'function, Array, Array': (f, T, y0) => _solveODE(f, T, y0, {}),\n    'function, Matrix, Matrix': (f, T, y0) => _matrixSolveODE(f, T, y0, {}),\n    'function, Array, number | BigNumber | Unit': (f, T, y0) => {\n      const sol = _solveODE(f, T, [y0], {})\n      return { t: sol.t, y: sol.y.map((Y) => Y[0]) }\n    },\n    'function, Matrix, number | BigNumber | Unit': (f, T, y0) => {\n      const sol = _solveODE(f, T.toArray(), [y0], {})\n      return { t: matrix(sol.t), y: matrix(sol.y.map((Y) => Y[0])) }\n    },\n    'function, Array, number | BigNumber | Unit, Object': (f, T, y0, options) => {\n      const sol = _solveODE(f, T, [y0], options)\n      return { t: sol.t, y: sol.y.map((Y) => Y[0]) }\n    },\n    'function, Matrix, number | BigNumber | Unit, Object': (f, T, y0, options) => {\n      const sol = _solveODE(f, T.toArray(), [y0], options)\n      return { t: matrix(sol.t), y: matrix(sol.y.map((Y) => Y[0])) }\n    }\n  })\n})\n","/* eslint-disable no-loss-of-precision */\n\nimport { deepMap } from '../../utils/collection.js'\nimport { sign } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'erf'\nconst dependencies = [\n  'typed'\n]\n\nexport const createErf = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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   * See also:\n   *    zeta\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 (x) {\n      const y = Math.abs(x)\n\n      if (y >= MAX_NUM) {\n        return sign(x)\n      }\n      if (y <= THRESH) {\n        return sign(x) * erf1(y)\n      }\n      if (y <= 4.0) {\n        return sign(x) * (1 - erfc2(y))\n      }\n      return sign(x) * (1 - erfc3(y))\n    },\n\n    'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self))\n\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  /**\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  function erf1 (y) {\n    const ysq = y * y\n    let xnum = P[0][4] * ysq\n    let xden = ysq\n    let 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    return y * (xnum + P[0][3]) / (xden + Q[0][3])\n  }\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  function erfc2 (y) {\n    let xnum = P[1][8] * y\n    let xden = y\n    let 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    const result = (xnum + P[1][7]) / (xden + Q[1][7])\n    const ysq = parseInt(y * 16) / 16\n    const del = (y - ysq) * (y + ysq)\n    return Math.exp(-ysq * ysq) * Math.exp(-del) * result\n  }\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  function erfc3 (y) {\n    let ysq = 1 / (y * y)\n    let xnum = P[2][5] * ysq\n    let xden = ysq\n    let 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    let result = ysq * (xnum + P[2][4]) / (xden + Q[2][4])\n    result = (SQRPI - result) / y\n    ysq = parseInt(y * 16) / 16\n    const del = (y - ysq) * (y + ysq)\n    return Math.exp(-ysq * ysq) * Math.exp(-del) * result\n  }\n})\n\n/**\n * Upper bound for the first approximation interval, 0 <= x <= THRESH\n * @constant\n */\nconst THRESH = 0.46875\n\n/**\n * Constant used by W. J. Cody's Fortran77 implementation to denote sqrt(pi)\n * @constant\n */\nconst SQRPI = 5.6418958354775628695e-1\n\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 */\nconst P = [[\n  3.16112374387056560e00, 1.13864154151050156e02,\n  3.77485237685302021e02, 3.20937758913846947e03,\n  1.85777706184603153e-1\n], [\n  5.64188496988670089e-1, 8.88314979438837594e00,\n  6.61191906371416295e01, 2.98635138197400131e02,\n  8.81952221241769090e02, 1.71204761263407058e03,\n  2.05107837782607147e03, 1.23033935479799725e03,\n  2.15311535474403846e-8\n], [\n  3.05326634961232344e-1, 3.60344899949804439e-1,\n  1.25781726111229246e-1, 1.60837851487422766e-2,\n  6.58749161529837803e-4, 1.63153871373020978e-2\n]]\n\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 */\nconst Q = [[\n  2.36012909523441209e01, 2.44024637934444173e02,\n  1.28261652607737228e03, 2.84423683343917062e03\n], [\n  1.57449261107098347e01, 1.17693950891312499e02,\n  5.37181101862009858e02, 1.62138957456669019e03,\n  3.29079923573345963e03, 4.36261909014324716e03,\n  3.43936767414372164e03, 1.23033935480374942e03\n], [\n  2.56852019228982242e00, 1.87295284992346047e00,\n  5.27905102951428412e-1, 6.05183413124413191e-2,\n  2.33520497626869185e-3\n]]\n\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 */\nconst MAX_NUM = Math.pow(2, 53)\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'zeta'\nconst dependencies = ['typed', 'config', 'multiply', 'pow', 'divide', 'factorial', 'equal', 'smallerEq', 'isNegative', 'gamma', 'sin', 'subtract', 'add', '?Complex', '?BigNumber', 'pi']\n\nexport const createZeta = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiply, pow, divide, factorial, equal, smallerEq, isNegative, gamma, sin, subtract, add, Complex, BigNumber, pi }) => {\n  /**\n   * Compute the Riemann Zeta function of a value using an infinite series for\n   * all of the complex plane using Riemann's Functional equation.\n   *\n   * Based off the paper by Xavier Gourdon and Pascal Sebah\n   * ( http://numbers.computation.free.fr/Constants/Miscellaneous/zetaevaluations.pdf )\n   *\n   * Implementation and slight modification by Anik Patel\n   *\n   * Note: the implementation is accurate up to about 6 digits.\n   *\n   * Syntax:\n   *\n   *    math.zeta(n)\n   *\n   * Examples:\n   *\n   *    math.zeta(5)       // returns 1.0369277551433895\n   *    math.zeta(-0.5)    // returns -0.2078862249773449\n   *    math.zeta(math.i)  // returns 0.0033002236853253153 - 0.4181554491413212i\n   *\n   * See also:\n   *    erf\n   *\n   * @param {number | Complex | BigNumber} s   A Real, Complex or BigNumber parameter to the Riemann Zeta Function\n   * @return {number | Complex | BigNumber}    The Riemann Zeta of `s`\n   */\n  return typed(name, {\n    number: (s) => zetaNumeric(s, value => value, () => 20),\n    BigNumber: (s) => zetaNumeric(\n      s,\n      value => new BigNumber(value),\n      () => {\n        // relTol is for example 1e-12. Extract the positive exponent 12 from that\n        return Math.abs(Math.log10(config.relTol))\n      }\n    ),\n    Complex: zetaComplex\n  })\n\n  /**\n   * @param {number | BigNumber} s\n   * @param {(value: number) => number | BigNumber} createValue\n   * @param {(value: number | BigNumber | Complex) => number} determineDigits\n   * @returns {number | BigNumber}\n   */\n  function zetaNumeric (s, createValue, determineDigits) {\n    if (equal(s, 0)) {\n      return createValue(-0.5)\n    }\n    if (equal(s, 1)) {\n      return createValue(NaN)\n    }\n    if (!isFinite(s)) {\n      return isNegative(s) ? createValue(NaN) : createValue(1)\n    }\n\n    return zeta(s, createValue, determineDigits, s => s)\n  }\n\n  /**\n   * @param {Complex} s\n   * @returns {Complex}\n   */\n  function zetaComplex (s) {\n    if (s.re === 0 && s.im === 0) {\n      return new Complex(-0.5)\n    }\n    if (s.re === 1) {\n      return new Complex(NaN, NaN)\n    }\n    if (s.re === Infinity && s.im === 0) {\n      return new Complex(1)\n    }\n    if (s.im === Infinity || s.re === -Infinity) {\n      return new Complex(NaN, NaN)\n    }\n\n    return zeta(s, value => value, s => Math.round(1.3 * 15 + 0.9 * Math.abs(s.im)), s => s.re)\n  }\n\n  /**\n   * @param {number | BigNumber | Complex} s\n   * @param {(value: number) => number | BigNumber | Complex} createValue\n   * @param {(value: number | BigNumber | Complex) => number} determineDigits\n   * @param {(value: number | BigNumber | Complex) => number} getRe\n   * @returns {*|number}\n   */\n  function zeta (s, createValue, determineDigits, getRe) {\n    const n = determineDigits(s)\n    if (getRe(s) > -(n - 1) / 2) {\n      return f(s, createValue(n), createValue)\n    } else {\n      // Function Equation for reflection to x < 1\n      let c = multiply(pow(2, s), pow(createValue(pi), subtract(s, 1)))\n      c = multiply(c, (sin(multiply(divide(createValue(pi), 2), s))))\n      c = multiply(c, gamma(subtract(1, s)))\n      return multiply(c, zeta(subtract(1, s), createValue, determineDigits, getRe))\n    }\n  }\n\n  /**\n   * Calculate a portion of the sum\n   * @param {number | BigNumber} k   a positive integer\n   * @param {number | BigNumber} n   a positive integer\n   * @return {number}    the portion of the sum\n   **/\n  function d (k, n) {\n    let S = k\n    for (let j = k; smallerEq(j, n); j = add(j, 1)) {\n      const factor = divide(\n        multiply(factorial(add(n, subtract(j, 1))), pow(4, j)),\n        multiply(factorial(subtract(n, j)), factorial(multiply(2, j)))\n      )\n      S = add(S, factor)\n    }\n\n    return multiply(n, S)\n  }\n\n  /**\n   * Calculate the positive Riemann Zeta function\n   * @param {number} s   a real or complex number with s.re > 1\n   * @param {number} n   a positive integer\n   * @param {(number) => number | BigNumber | Complex} createValue\n   * @return {number}    Riemann Zeta of s\n   **/\n  function f (s, n, createValue) {\n    const c = divide(1, multiply(d(createValue(0), n), subtract(1, pow(2, subtract(1, s)))))\n    let S = createValue(0)\n    for (let k = createValue(1); smallerEq(k, n); k = add(k, 1)) {\n      S = add(S, divide(multiply((-1) ** (k - 1), d(k, n)), pow(k, s)))\n    }\n    return multiply(c, S)\n  }\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'mode'\nconst dependencies = ['typed', 'isNaN', 'isNumeric']\n\nexport const createMode = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNaN, isNumeric }) => {\n  /**\n  * Computes the mode of a set of numbers or a list with values(numbers or characters).\n  * If there are multiple 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\n    '...': function (args) {\n      return _mode(args)\n    }\n  })\n\n  /**\n   * Calculates the mode in an 1-dimensional array\n   * @param {Array} values\n   * @return {Array} mode\n   * @private\n   */\n  function _mode (values) {\n    values = flatten(values.valueOf())\n    const num = values.length\n    if (num === 0) {\n      throw new Error('Cannot calculate mode of an empty array')\n    }\n\n    const count = {}\n    let mode = []\n    let max = 0\n    for (let i = 0; i < values.length; i++) {\n      const 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    return mode\n  }\n})\n","import { typeOf } from '../../../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 */\nexport function improveErrorMessage (err, fnName, value) {\n  // TODO: add information with the index (also needs transform in expression parser)\n  let details\n\n  if (String(err).includes('Unexpected type')) {\n    details = arguments.length > 2\n      ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')'\n      : ' (type: ' + err.data.actual + ')'\n\n    return new TypeError('Cannot calculate ' + fnName + ', unexpected type of argument' + details)\n  }\n\n  if (String(err).includes('complex numbers')) {\n    details = arguments.length > 2\n      ? ' (type: ' + typeOf(value) + ', value: ' + JSON.stringify(value) + ')'\n      : ''\n\n    return new TypeError('Cannot calculate ' + fnName + ', no ordering relation is defined for complex numbers' + details)\n  }\n\n  return err\n}\n","import { deepForEach } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'prod'\nconst dependencies = ['typed', 'config', 'multiplyScalar', 'numeric']\n\nexport const createProd = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiplyScalar, numeric }) => {\n  /**\n   * Compute the product of a matrix or a list with values.\n   * In case of a multidimensional 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\n    // prod([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': function (array, dim) {\n      // TODO: implement prod(A, dim)\n      throw new Error('prod(A, dim) is not yet supported')\n      // return reduce(arguments[0], arguments[1], math.prod)\n    },\n\n    // prod(a, b, c, d, ...)\n    '...': function (args) {\n      return _prod(args)\n    }\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  function _prod (array) {\n    let prod\n\n    deepForEach(array, function (value) {\n      try {\n        prod = (prod === undefined) ? value : multiplyScalar(prod, value)\n      } catch (err) {\n        throw improveErrorMessage(err, 'prod', value)\n      }\n    })\n\n    // make sure returning numeric value: parse a string into a numeric value\n    if (typeof prod === 'string') {\n      prod = numeric(prod, safeNumberType(prod, config))\n    }\n\n    if (prod === undefined) {\n      throw new Error('Cannot calculate prod of an empty array')\n    }\n\n    return prod\n  }\n})\n","import { format as formatString } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'format'\nconst dependencies = ['typed']\n\nexport const createFormat = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | BigNumber`\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 | BigNumber`\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'`,\n   *      `precision` 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'`\n   *      is 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 had 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.24e+6'\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.4e+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: formatString,\n    'any, Object | function | number | BigNumber': formatString\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'bin'\nconst dependencies = ['typed', 'format']\n\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 | BigNumber} value    Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string}         The formatted value\n */\nexport const createBin = factory(name, dependencies, ({ typed, format }) => {\n  return typed(name, {\n    'number | BigNumber': function (n) {\n      return format(n, { notation: 'bin' })\n    },\n    'number | BigNumber, number | BigNumber': function (n, wordSize) {\n      return format(n, { notation: 'bin', wordSize })\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'oct'\nconst dependencies = ['typed', 'format']\n\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 | BigNumber} value    Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string}         The formatted value\n */\n\nexport const createOct = factory(name, dependencies, ({ typed, format }) => {\n  return typed(name, {\n    'number | BigNumber': function (n) {\n      return format(n, { notation: 'oct' })\n    },\n    'number | BigNumber, number | BigNumber': function (n, wordSize) {\n      return format(n, { notation: 'oct', wordSize })\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'hex'\nconst dependencies = ['typed', 'format']\n\n/**\n * Format a number as hexadecimal.\n *\n * Syntax:\n *\n *    math.hex(value)\n *\n * Examples:\n *\n *    math.hex(240) // returns \"0xF0\"\n *\n * See also:\n *\n *    oct\n *    bin\n *\n * @param {number | BigNumber} value    Value to be stringified\n * @param {number | BigNumber} wordSize Optional word size (see `format`)\n * @return {string}         The formatted value\n */\nexport const createHex = factory(name, dependencies, ({ typed, format }) => {\n  return typed(name, {\n    'number | BigNumber': function (n) {\n      return format(n, { notation: 'hex' })\n    },\n    'number | BigNumber, number | BigNumber': function (n, wordSize) {\n      return format(n, { notation: 'hex', wordSize })\n    }\n  })\n})\n","export const printTemplate = /\\$([\\w.]+)/g\n","import { format } from '../../utils/string.js'\nimport { isString } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { printTemplate } from '../../utils/print.js'\n\nconst name = 'print'\nconst dependencies = ['typed']\n\nexport const createPrint = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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/**\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 */\nfunction _print (template, values, options) {\n  return template.replace(printTemplate, function (original, key) {\n    const keys = key.split('.')\n    let value = values[keys.shift()]\n    if (value !== undefined && value.isMatrix) {\n      value = value.toArray()\n    }\n    while (keys.length && value !== undefined) {\n      const k = keys.shift()\n      value = k ? value[k] : value + '.'\n    }\n\n    if (value !== undefined) {\n      if (!isString(value)) {\n        return format(value, options)\n      } else {\n        return value\n      }\n    }\n\n    return original\n  }\n  )\n}\n","import { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'to'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'concat'\n]\n\nexport const createTo = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, concat }) => {\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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('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  return typed(\n    name,\n    { 'Unit, Unit | string': (x, unit) => x.to(unit) },\n    matrixAlgorithmSuite({ Ds: true })\n  )\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'isPrime'\nconst dependencies = ['typed']\n\nexport const createIsPrime = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 | bigint | 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 (x) {\n      if (x <= 3) {\n        return x > 1\n      }\n      if (x % 2 === 0 || x % 3 === 0) {\n        return false\n      }\n      for (let i = 5; i * i <= x; i += 6) {\n        if (x % i === 0 || x % (i + 2) === 0) {\n          return false\n        }\n      }\n      return true\n    },\n\n    bigint: function (x) {\n      if (x <= 3n) {\n        return x > 1n\n      }\n      if (x % 2n === 0n || x % 3n === 0n) {\n        return false\n      }\n      for (let i = 5n; i * i <= x; i += 6n) {\n        if (x % i === 0n || x % (i + 2n) === 0n) {\n          return false\n        }\n      }\n      return true\n    },\n\n    BigNumber: function (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      if (n.lt(Math.pow(2, 32))) {\n        const x = n.toNumber()\n        for (let i = 5; i * i <= x; i += 6) {\n          if (x % i === 0 || x % (i + 2) === 0) {\n            return false\n          }\n        }\n        return true\n      }\n\n      function modPow (base, exponent, modulus) {\n        // exponent can be huge, use non-recursive variant\n        let accumulator = 1\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        return accumulator\n      }\n\n      // https://en.wikipedia.org/wiki/Miller%E2%80%93Rabin_primality_test#Deterministic_variants\n      const Decimal = n.constructor.clone({ precision: n.toFixed(0).length * 2 })\n      n = new Decimal(n)\n      let r = 0\n      let d = n.sub(1)\n      while (d.mod(2).eq(0)) {\n        d = d.div(2)\n        r += 1\n      }\n      let bases = null\n      // https://en.wikipedia.org/wiki/Miller–Rabin_primality_test#Testing_against_small_sets_of_bases\n      if (n.lt('3317044064679887385961981')) {\n        bases = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41].filter(x => x < n)\n      } else {\n        const max = Math.min(n.toNumber() - 2, Math.floor(2 * Math.pow(n.toFixed(0).length * Math.log(10), 2)))\n        bases = []\n        for (let i = 2; i <= max; i += 1) {\n          bases.push(max)\n        }\n      }\n      for (let i = 0; i < bases.length; i += 1) {\n        const a = bases[i]\n        const adn = modPow(n.sub(n).add(a), d, n)\n        if (!adn.eq(1)) {\n          for (let i = 0, x = adn; !x.eq(n.sub(1)); i += 1, x = x.mul(x).mod(n)) {\n            if (i === r - 1) {\n              return false\n            }\n          }\n        }\n      }\n      return true\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { noBignumber, noFraction } from '../../utils/noop.js'\n\nconst name = 'numeric'\nconst dependencies = ['number', '?bignumber', '?fraction']\n\nexport const createNumeric = /* #__PURE__ */ factory(name, dependencies, ({ number, bignumber, fraction }) => {\n  const validInputTypes = {\n    string: true,\n    number: true,\n    BigNumber: true,\n    Fraction: true\n  }\n\n  // Load the conversion functions for each output type\n  const validOutputTypes = {\n    number: (x) => number(x),\n    BigNumber: bignumber\n      ? (x) => bignumber(x)\n      : noBignumber,\n    bigint: (x) => BigInt(x),\n    Fraction: fraction\n      ? (x) => fraction(x)\n      : noFraction\n  }\n\n  /**\n   * Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.\n   *\n   * Syntax:\n   *\n   *    math.numeric(x)\n   *\n   * Examples:\n   *\n   *    math.numeric('4')                           // returns 4\n   *    math.numeric('4', 'number')                 // returns 4\n   *    math.numeric('4', 'bigint')                 // returns 4n\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 0.4\n   *\n   * See also:\n   *\n   *    number, fraction, bignumber, bigint, string, format\n   *\n   * @param {string | number | BigNumber | bigint | 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 | bigint | Fraction}\n   *              Returns an instance of the numeric in the requested type\n   */\n  return function numeric (value, outputType = 'number', check) {\n    if (check !== undefined) {\n      throw new SyntaxError('numeric() takes one or two arguments')\n    }\n    const inputType = 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    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})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'divideScalar'\nconst dependencies = ['typed', 'numeric']\n\nexport const createDivideScalar = /* #__PURE__ */ factory(name, dependencies, ({ typed, numeric }) => {\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 | bigint | Fraction | Complex | Unit} x   Numerator\n   * @param  {number | BigNumber | bigint | Fraction | Complex} y          Denominator\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit}     Quotient, `x / y`\n   * @private\n   */\n  return typed(name, {\n    'number, number': function (x, y) {\n      return x / y\n    },\n\n    'Complex, Complex': function (x, y) {\n      return x.div(y)\n    },\n\n    'BigNumber, BigNumber': function (x, y) {\n      return x.div(y)\n    },\n\n    'bigint, bigint': function (x, y) {\n      return x / y\n    },\n\n    'Fraction, Fraction': function (x, y) {\n      return x.div(y)\n    },\n\n    'Unit, number | Complex | Fraction | BigNumber | Unit':\n      (x, y) => x.divide(y),\n\n    'number | Fraction | Complex | BigNumber, Unit':\n    (x, y) => y.divideInto(x)\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { arraySize as size } from '../../utils/array.js'\nimport { powNumber } from '../../plain/number/index.js'\n\nconst name = 'pow'\nconst dependencies = [\n  'typed',\n  'config',\n  'identity',\n  'multiply',\n  'matrix',\n  'inv',\n  'fraction',\n  'number',\n  'Complex'\n]\n\nexport const createPow = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, identity, multiply, matrix, inv, number, fraction, Complex }) => {\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 | bigint | Complex | Unit | Array | Matrix} x  The base\n   * @param  {number | BigNumber | bigint | Complex} y                          The exponent\n   * @return {number | BigNumber | bigint | Complex | Array | Matrix} The value of `x` to the power `y`\n   */\n  return typed(name, {\n    'number, number': _pow,\n\n    'Complex, Complex': function (x, y) {\n      return x.pow(y)\n    },\n\n    'BigNumber, BigNumber': function (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\n    'bigint, bigint': (x, y) => x ** y,\n\n    'Fraction, Fraction': function (x, y) {\n      const 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\n    'Array, number': _powArray,\n\n    'Array, BigNumber': function (x, y) {\n      return _powArray(x, y.toNumber())\n    },\n\n    'Matrix, number': _powMatrix,\n\n    'Matrix, BigNumber': function (x, y) {\n      return _powMatrix(x, y.toNumber())\n    },\n\n    'Unit, number | BigNumber': function (x, y) {\n      return x.pow(y)\n    }\n\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  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 && !isInteger(y) && x < 0) {\n      // Check to see if y can be represented as a fraction\n      try {\n        const yFrac = fraction(y)\n        const yNum = number(yFrac)\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) {\n        // fraction() throws an error if y is Infinity, etc.\n      }\n\n      // Unable to express y as a fraction, so continue on\n    }\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    if (config.predictable &&\n        ((x < -1 && y === Infinity) ||\n         (x > -1 && x < 0 && y === -Infinity))) {\n      return NaN\n    }\n\n    if (isInteger(y) || x >= 0 || config.predictable) {\n      return powNumber(x, y)\n    } else {\n      // TODO: the following infinity checks are duplicated from powNumber. Deduplicate this somehow\n\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) ||\n        (x * x > 1 && y === -Infinity)) {\n        return 0\n      }\n\n      return new Complex(x, 0).pow(y, 0)\n    }\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  function _powArray (x, y) {\n    if (!isInteger(y)) {\n      throw new TypeError('For A^b, b must be an integer (value is ' + y + ')')\n    }\n    // verify that A is a 2 dimensional square matrix\n    const s = size(x)\n    if (s.length !== 2) {\n      throw new Error('For A^b, A must be 2 dimensional (A has ' + s.length + ' dimensions)')\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    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        throw error\n      }\n    }\n\n    let res = identity(s[0]).valueOf()\n    let px = x\n    while (y >= 1) {\n      if ((y & 1) === 1) {\n        res = multiply(px, res)\n      }\n      y >>= 1\n      px = multiply(px, px)\n    }\n    return res\n  }\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  function _powMatrix (x, y) {\n    return matrix(_powArray(x.valueOf(), y))\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { nearlyEqual, splitNumber } from '../../utils/number.js'\nimport { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { roundNumber } from '../../plain/number/index.js'\n\nconst NO_INT = 'Number of decimals in function round must be an integer'\n\nconst name = 'round'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'BigNumber',\n  'DenseMatrix'\n]\n\nexport const createRound = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, equalScalar, zeros, BigNumber, DenseMatrix }) => {\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n\n  function toExponent (epsilon) {\n    return Math.abs(splitNumber(epsilon).exponent)\n  }\n\n  /**\n   * Round a value towards the nearest rounded value.\n   * For matrices, the function is evaluated element wise.\n   *\n   * Syntax:\n   *\n   *    math.round(x)\n   *    math.round(x, n)\n   *    math.round(unit, valuelessUnit)\n   *    math.round(unit, n, valuelessUnit)\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   *    const unit = math.unit('3.241 cm')\n   *    const cm = math.unit('cm')\n   *    const mm = math.unit('mm')\n   *    math.round(unit, 1, cm)      // returns Unit 3.2 cm\n   *    math.round(unit, 1, mm)      // returns Unit 32.4 mm\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 | Unit | Array | Matrix} x  Value to be rounded\n   * @param  {number | BigNumber | Array} [n=0]                            Number of decimals\n   * @param  {Unit} [valuelessUnit]                                        A valueless unit\n   * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value\n   */\n  return typed(name, {\n    number: function (x) {\n      // Handle round off errors by first rounding to relTol precision\n      const xEpsilon = roundNumber(x, toExponent(config.relTol))\n      const xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n      return roundNumber(xSelected)\n    },\n\n    'number, number': function (x, n) {\n      // Same as number: unless user specifies more decimals than relTol\n      const epsilonExponent = toExponent(config.relTol)\n      if (n >= epsilonExponent) { return roundNumber(x, n) }\n\n      const xEpsilon = roundNumber(x, epsilonExponent)\n      const xSelected = nearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n      return roundNumber(xSelected, n)\n    },\n\n    'number, BigNumber': function (x, n) {\n      if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n      return new BigNumber(x).toDecimalPlaces(n.toNumber())\n    },\n\n    Complex: function (x) {\n      return x.round()\n    },\n\n    'Complex, number': function (x, n) {\n      if (n % 1) { throw new TypeError(NO_INT) }\n\n      return x.round(n)\n    },\n\n    'Complex, BigNumber': function (x, n) {\n      if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n      const _n = n.toNumber()\n      return x.round(_n)\n    },\n\n    BigNumber: function (x) {\n      // Handle round off errors by first rounding to relTol precision\n      const xEpsilon = new BigNumber(x).toDecimalPlaces(toExponent(config.relTol))\n      const xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n      return xSelected.toDecimalPlaces(0)\n    },\n\n    'BigNumber, BigNumber': function (x, n) {\n      if (!n.isInteger()) { throw new TypeError(NO_INT) }\n\n      // Same as BigNumber: unless user specifies more decimals than relTol\n      const epsilonExponent = toExponent(config.relTol)\n      if (n >= epsilonExponent) { return x.toDecimalPlaces(n.toNumber()) }\n\n      const xEpsilon = x.toDecimalPlaces(epsilonExponent)\n      const xSelected = bigNearlyEqual(x, xEpsilon, config.relTol, config.absTol) ? xEpsilon : x\n      return xSelected.toDecimalPlaces(n.toNumber())\n    },\n\n    Fraction: function (x) {\n      return x.round()\n    },\n\n    'Fraction, number': function (x, n) {\n      if (n % 1) { throw new TypeError(NO_INT) }\n      return x.round(n)\n    },\n\n    'Fraction, BigNumber': function (x, n) {\n      if (!n.isInteger()) { throw new TypeError(NO_INT) }\n      return x.round(n.toNumber())\n    },\n\n    'Unit, number, Unit': typed.referToSelf(self => function (x, n, unit) {\n      const valueless = x.toNumeric(unit)\n      return unit.multiply(self(valueless, n))\n    }),\n\n    'Unit, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)),\n\n    'Unit, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)),\n\n    'Array | Matrix, number, Unit': typed.referToSelf(self => (x, n, unit) => {\n      // deep map collection, skip zeros since round(0) = 0\n      return deepMap(x, (value) => self(value, n, unit), true)\n    }),\n\n    'Array | Matrix, BigNumber, Unit': typed.referToSelf(self => (x, n, unit) => self(x, n.toNumber(), unit)),\n\n    'Array | Matrix, Unit': typed.referToSelf(self => (x, unit) => self(x, 0, unit)),\n\n    'Array | Matrix': typed.referToSelf(self => x => {\n      // deep map collection, skip zeros since round(0) = 0\n      return deepMap(x, self, true)\n    }),\n\n    'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      return matAlgo11xS0s(x, n, self, false)\n    }),\n\n    'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      return matAlgo14xDs(x, n, self, false)\n    }),\n\n    'Array, number | BigNumber': typed.referToSelf(self => (x, n) => {\n      // use matrix implementation\n      return matAlgo14xDs(matrix(x), n, self, false).valueOf()\n    }),\n\n    'number | Complex | BigNumber | Fraction, SparseMatrix': typed.referToSelf(self => (x, n) => {\n      // check scalar is zero\n      if (equalScalar(x, 0)) {\n        // do not execute algorithm, result will be a zero matrix\n        return zeros(n.size(), n.storage())\n      }\n      return matAlgo12xSfs(n, x, self, true)\n    }),\n\n    'number | Complex | BigNumber | Fraction, DenseMatrix': typed.referToSelf(self => (x, n) => {\n      // check scalar is zero\n      if (equalScalar(x, 0)) {\n        // do not execute algorithm, result will be a zero matrix\n        return zeros(n.size(), n.storage())\n      }\n      return matAlgo14xDs(n, x, self, true)\n    }),\n\n    'number | Complex | BigNumber | Fraction, Array': typed.referToSelf(self => (x, n) => {\n      // use matrix implementation\n      return matAlgo14xDs(matrix(n), x, self, true).valueOf()\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { logNumber } from '../../plain/number/index.js'\n\nconst name = 'log'\nconst dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n\nexport const createLog = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\n  /**\n   * Calculate the logarithm of a value.\n   *\n   * To avoid confusion with the matrix logarithm, this function does not\n   * apply to matrices.\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} 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}\n   *            Returns the logarithm of `x`\n   */\n  return typed(name, {\n    number: function (x) {\n      if (x >= 0 || config.predictable) {\n        return logNumber(x)\n      } else {\n        // negative value -> complex value computation\n        return new Complex(x, 0).log()\n      }\n    },\n\n    Complex: function (x) {\n      return x.log()\n    },\n\n    BigNumber: function (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\n    'any, any': typed.referToSelf(self => (x, base) => {\n      // calculate logarithm for a specified base, log(x, base)\n      return divideScalar(self(x), self(base))\n    })\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { deepMap } from '../../utils/collection.js'\nimport { log1p as _log1p } from '../../utils/number.js'\n\nconst name = 'log1p'\nconst dependencies = ['typed', 'config', 'divideScalar', 'log', 'Complex']\n\nexport const createLog1p = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, log, Complex }) => {\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 (x) {\n      if (x >= -1 || config.predictable) {\n        return _log1p(x)\n      } else {\n        // negative value -> complex value computation\n        return _log1pComplex(new Complex(x, 0))\n      }\n    },\n\n    Complex: _log1pComplex,\n\n    BigNumber: function (x) {\n      const y = x.plus(1)\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\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self)),\n\n    'any, any': typed.referToSelf(self => (x, base) => {\n      // calculate logarithm for a specified base, log1p(x, base)\n      return divideScalar(self(x), log(base))\n    })\n  })\n\n  /**\n   * Calculate the natural logarithm of a complex number + 1\n   * @param {Complex} x\n   * @returns {Complex}\n   * @private\n   */\n  function _log1pComplex (x) {\n    const xRe1p = x.re + 1\n    return new Complex(\n      Math.log(Math.sqrt(xRe1p * xRe1p + x.im * x.im)),\n      Math.atan2(x.im, xRe1p)\n    )\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'nthRoots'\nconst dependencies = ['config', 'typed', 'divideScalar', 'Complex']\n\nexport const createNthRoots = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, divideScalar, Complex }) => {\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  const _calculateExactResult = [\n    function realPos (val) { return new Complex(val, 0) },\n    function imagPos (val) { return new Complex(0, val) },\n    function realNeg (val) { return new Complex(-val, 0) },\n    function imagNeg (val) { return new Complex(0, -val) }\n  ]\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  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    const aIsNumeric = typeof (a) === 'number'\n    let offset\n    // determine the offset (argument of a)/(pi/2)\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    const arg = a.arg()\n    const abs = a.abs()\n    const roots = []\n    const r = Math.pow(abs, 1 / root)\n    for (let k = 0; k < root; k++) {\n      const 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      if (halfPiFactor === Math.round(halfPiFactor)) {\n        roots.push(_calculateExactResult[halfPiFactor % 4](r))\n        continue\n      }\n      roots.push(new Complex({ r, phi: (arg + 2 * Math.PI * k) / root }))\n    }\n    return roots\n  }\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   *    math.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   * @param {number} [root=2] Optional root, default value is 2\n   * @return {number | BigNumber | Fraction | Complex} Returns the nth roots\n   */\n  return typed(name, {\n    Complex: function (x) {\n      return _nthComplexRoots(x, 2)\n    },\n    'Complex, number': _nthComplexRoots\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotPow'\nconst dependencies = [\n  'typed',\n  'equalScalar',\n  'matrix',\n  'pow',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createDotPow = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar, matrix, pow, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n\n  const powScalarSignatures = {}\n  for (const signature in pow.signatures) {\n    if (Object.prototype.hasOwnProperty.call(pow.signatures, signature)) {\n      if (!signature.includes('Matrix') && !signature.includes('Array')) {\n        powScalarSignatures[signature] = pow.signatures[signature]\n      }\n    }\n  }\n  const powScalar = typed(powScalarSignatures)\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  return typed(name, matrixAlgorithmSuite({\n    elop: powScalar,\n    SS: matAlgo07xSSf,\n    DS: matAlgo03xDSf,\n    Ss: matAlgo11xS0s,\n    sS: matAlgo12xSfs\n  }))\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'dotDivide'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'divideScalar',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createDotDivide = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, divideScalar, DenseMatrix, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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  return typed(name, matrixAlgorithmSuite({\n    elop: divideScalar,\n    SS: matAlgo07xSSf,\n    DS: matAlgo03xDSf,\n    SD: matAlgo02xDS0,\n    Ss: matAlgo11xS0s,\n    sS: matAlgo12xSfs\n  }))\n})\n","import { isArray, isMatrix, isDenseMatrix, isSparseMatrix } from '../../../../utils/is.js'\nimport { arraySize } from '../../../../utils/array.js'\nimport { format } from '../../../../utils/string.js'\n\nexport function createSolveValidation ({ DenseMatrix }) {\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    const mSize = m.size()\n\n    if (mSize.length !== 2) {\n      throw new RangeError('Matrix must be two dimensional (size: ' + format(mSize) + ')')\n    }\n\n    const rows = mSize[0]\n    const columns = mSize[1]\n\n    if (rows !== columns) {\n      throw new RangeError('Matrix must be square (size: ' + format(mSize) + ')')\n    }\n\n    let data = []\n\n    if (isMatrix(b)) {\n      const bSize = b.size()\n      const bdata = b._data\n\n      // 1-dim vector\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 (let i = 0; i < rows; i++) {\n          data[i] = [bdata[i]]\n        }\n\n        return new DenseMatrix({\n          data,\n          size: [rows, 1],\n          datatype: b._datatype\n        })\n      }\n\n      // 2-dim column\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 (isDenseMatrix(b)) {\n          if (copy) {\n            data = []\n\n            for (let i = 0; i < rows; i++) {\n              data[i] = [bdata[i][0]]\n            }\n\n            return new DenseMatrix({\n              data,\n              size: [rows, 1],\n              datatype: b._datatype\n            })\n          }\n\n          return b\n        }\n\n        if (isSparseMatrix(b)) {\n          for (let i = 0; i < rows; i++) { data[i] = [0] }\n\n          const values = b._values\n          const index = b._index\n          const ptr = b._ptr\n\n          for (let k1 = ptr[1], k = ptr[0]; k < k1; k++) {\n            const i = index[k]\n            data[i][0] = values[k]\n          }\n\n          return new DenseMatrix({\n            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 (isArray(b)) {\n      const bsize = 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 (let i = 0; i < rows; i++) {\n          data[i] = [b[i]]\n        }\n\n        return new DenseMatrix({\n          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 (let i = 0; i < rows; i++) {\n          data[i] = [b[i][0]]\n        }\n\n        return new DenseMatrix({\n          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}\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'lsolve'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'equalScalar',\n  'DenseMatrix'\n]\n\nexport const createLsolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n  const solveValidation = createSolveValidation({ 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  return typed(name, {\n\n    'SparseMatrix, Array | Matrix': function (m, b) {\n      return _sparseForwardSubstitution(m, b)\n    },\n\n    'DenseMatrix, Array | Matrix': function (m, b) {\n      return _denseForwardSubstitution(m, b)\n    },\n\n    'Array, Array | Matrix': function (a, b) {\n      const m = matrix(a)\n      const r = _denseForwardSubstitution(m, b)\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    const bdata = b._data\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    // result\n    const x = []\n\n    const mdata = m._data\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      const bj = bdata[j][0] || 0\n      let xj\n\n      if (!equalScalar(bj, 0)) {\n        // non-degenerate row, find solution\n\n        const 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)\n\n        // loop rows\n        for (let i = j + 1; i < rows; i++) {\n          bdata[i] = [subtractScalar(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\n    const bdata = b._data\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n\n    // result\n    const x = []\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      const bj = bdata[j][0] || 0\n\n      if (!equalScalar(bj, 0)) {\n        // non-degenerate row, find solution\n\n        let vjj = 0\n        // matrix values & indices (column j)\n        const jValues = []\n        const jIndices = []\n\n        // first and last index in the column\n        const firstIndex = ptr[j]\n        const lastIndex = ptr[j + 1]\n\n        // values in column, find value at [j, j]\n        for (let k = firstIndex; k < lastIndex; k++) {\n          const i = index[k]\n\n          // check row (rows are not sorted!)\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        }\n\n        // at this point we must have a value in vjj\n        if (equalScalar(vjj, 0)) {\n          throw new Error('Linear system cannot be solved since matrix is singular')\n        }\n\n        const xj = divideScalar(bj, vjj)\n\n        for (let k = 0, l = jIndices.length; k < l; k++) {\n          const i = jIndices[k]\n          bdata[i] = [subtractScalar(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})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'usolve'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'equalScalar',\n  'DenseMatrix'\n]\n\nexport const createUsolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n  const solveValidation = createSolveValidation({ 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  return typed(name, {\n\n    'SparseMatrix, Array | Matrix': function (m, b) {\n      return _sparseBackwardSubstitution(m, b)\n    },\n\n    'DenseMatrix, Array | Matrix': function (m, b) {\n      return _denseBackwardSubstitution(m, b)\n    },\n\n    'Array, Array | Matrix': function (a, b) {\n      const m = matrix(a)\n      const r = _denseBackwardSubstitution(m, b)\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\n    const bdata = b._data\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    // result\n    const x = []\n\n    const mdata = m._data\n    // loop columns backwards\n    for (let j = columns - 1; j >= 0; j--) {\n      // b[j]\n      const bj = bdata[j][0] || 0\n      // x[j]\n      let xj\n\n      if (!equalScalar(bj, 0)) {\n        // value at [j, j]\n        const 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)\n\n        // loop rows\n        for (let i = j - 1; i >= 0; i--) {\n          // update copy of b\n          bdata[i] = [subtractScalar(bdata[i][0] || 0, multiplyScalar(xj, mdata[i][j]))]\n        }\n      } else {\n        // zero value at j\n        xj = 0\n      }\n      // update x\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\n    const bdata = b._data\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n\n    // result\n    const x = []\n\n    // loop columns backwards\n    for (let j = columns - 1; j >= 0; j--) {\n      const bj = bdata[j][0] || 0\n\n      if (!equalScalar(bj, 0)) {\n        // non-degenerate row, find solution\n\n        let vjj = 0\n\n        // upper triangular matrix values & index (column j)\n        const jValues = []\n        const jIndices = []\n\n        // first & last indeces in column\n        const firstIndex = ptr[j]\n        const lastIndex = ptr[j + 1]\n\n        // values in column, find value at [j, j], loop backwards\n        for (let k = lastIndex - 1; k >= firstIndex; k--) {\n          const i = index[k]\n\n          // check row (rows are not sorted!)\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        }\n\n        // at this point we must have a value in vjj\n        if (equalScalar(vjj, 0)) {\n          throw new Error('Linear system cannot be solved since matrix is singular')\n        }\n\n        const xj = divideScalar(bj, vjj)\n\n        for (let k = 0, lastIndex = jIndices.length; k < lastIndex; k++) {\n          const i = jIndices[k]\n          bdata[i] = [subtractScalar(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})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'lsolveAll'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'equalScalar',\n  'DenseMatrix'\n]\n\nexport const createLsolveAll = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n  const solveValidation = createSolveValidation({ 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  return typed(name, {\n\n    'SparseMatrix, Array | Matrix': function (m, b) {\n      return _sparseForwardSubstitution(m, b)\n    },\n\n    'DenseMatrix, Array | Matrix': function (m, b) {\n      return _denseForwardSubstitution(m, b)\n    },\n\n    'Array, Array | Matrix': function (a, b) {\n      const m = matrix(a)\n      const R = _denseForwardSubstitution(m, b)\n      return R.map(r => r.valueOf())\n    }\n  })\n\n  function _denseForwardSubstitution (m, b_) {\n    // the algorithm is derived from\n    // https://www.overleaf.com/read/csvgqdxggyjv\n\n    // array of right-hand sides\n    const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n    const M = m._data\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    // loop columns\n    for (let i = 0; i < columns; i++) {\n      let L = B.length\n\n      // loop right-hand sides\n      for (let k = 0; k < L; k++) {\n        const b = B[k]\n\n        if (!equalScalar(M[i][i], 0)) {\n          // non-singular row\n\n          b[i] = divideScalar(b[i], M[i][i])\n\n          for (let j = i + 1; j < columns; j++) {\n            // b[j] -= b[i] * M[j,i]\n            b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i]))\n          }\n        } else if (!equalScalar(b[i], 0)) {\n          // singular row, nonzero RHS\n\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\n          const bNew = [...b]\n          bNew[i] = 1\n\n          for (let j = i + 1; j < columns; j++) {\n            bNew[j] = subtractScalar(bNew[j], M[j][i])\n          }\n\n          B.push(bNew)\n        }\n      }\n    }\n\n    return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n  }\n\n  function _sparseForwardSubstitution (m, b_) {\n    // array of right-hand sides\n    const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n\n    // loop columns\n    for (let i = 0; i < columns; i++) {\n      let L = B.length\n\n      // loop right-hand sides\n      for (let k = 0; k < L; k++) {\n        const b = B[k]\n\n        // values & indices (column i)\n        const iValues = []\n        const iIndices = []\n\n        // first & last indeces in column\n        const firstIndex = ptr[i]\n        const lastIndex = ptr[i + 1]\n\n        // find the value at [i, i]\n        let Mii = 0\n        for (let j = firstIndex; j < lastIndex; j++) {\n          const J = index[j]\n          // check row\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\n          b[i] = divideScalar(b[i], Mii)\n\n          for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n            const J = iIndices[j]\n            b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j]))\n          }\n        } else if (!equalScalar(b[i], 0)) {\n          // singular row, nonzero RHS\n\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\n          const bNew = [...b]\n          bNew[i] = 1\n\n          for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n            const J = iIndices[j]\n            bNew[J] = subtractScalar(bNew[J], iValues[j])\n          }\n\n          B.push(bNew)\n        }\n      }\n    }\n\n    return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\n\nconst name = 'usolveAll'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'equalScalar',\n  'DenseMatrix'\n]\n\nexport const createUsolveAll = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, multiplyScalar, subtractScalar, equalScalar, DenseMatrix }) => {\n  const solveValidation = createSolveValidation({ 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  return typed(name, {\n\n    'SparseMatrix, Array | Matrix': function (m, b) {\n      return _sparseBackwardSubstitution(m, b)\n    },\n\n    'DenseMatrix, Array | Matrix': function (m, b) {\n      return _denseBackwardSubstitution(m, b)\n    },\n\n    'Array, Array | Matrix': function (a, b) {\n      const m = matrix(a)\n      const R = _denseBackwardSubstitution(m, b)\n      return R.map(r => r.valueOf())\n    }\n  })\n\n  function _denseBackwardSubstitution (m, b_) {\n    // the algorithm is derived from\n    // https://www.overleaf.com/read/csvgqdxggyjv\n\n    // array of right-hand sides\n    const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n    const M = m._data\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    // loop columns backwards\n    for (let i = columns - 1; i >= 0; i--) {\n      let L = B.length\n\n      // loop right-hand sides\n      for (let k = 0; k < L; k++) {\n        const b = B[k]\n\n        if (!equalScalar(M[i][i], 0)) {\n          // non-singular row\n\n          b[i] = divideScalar(b[i], M[i][i])\n\n          for (let j = i - 1; j >= 0; j--) {\n            // b[j] -= b[i] * M[j,i]\n            b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i]))\n          }\n        } else if (!equalScalar(b[i], 0)) {\n          // singular row, nonzero RHS\n\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\n          const bNew = [...b]\n          bNew[i] = 1\n\n          for (let j = i - 1; j >= 0; j--) {\n            bNew[j] = subtractScalar(bNew[j], M[j][i])\n          }\n\n          B.push(bNew)\n        }\n      }\n    }\n\n    return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n  }\n\n  function _sparseBackwardSubstitution (m, b_) {\n    // array of right-hand sides\n    const B = [solveValidation(m, b_, true)._data.map(e => e[0])]\n\n    const rows = m._size[0]\n    const columns = m._size[1]\n\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n\n    // loop columns backwards\n    for (let i = columns - 1; i >= 0; i--) {\n      let L = B.length\n\n      // loop right-hand sides\n      for (let k = 0; k < L; k++) {\n        const b = B[k]\n\n        // values & indices (column i)\n        const iValues = []\n        const iIndices = []\n\n        // first & last indeces in column\n        const firstIndex = ptr[i]\n        const lastIndex = ptr[i + 1]\n\n        // find the value at [i, i]\n        let Mii = 0\n        for (let j = lastIndex - 1; j >= firstIndex; j--) {\n          const J = index[j]\n          // check row\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\n          b[i] = divideScalar(b[i], Mii)\n\n          // loop upper triangular\n          for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n            const J = iIndices[j]\n            b[J] = subtractScalar(b[J], multiplyScalar(b[i], iValues[j]))\n          }\n        } else if (!equalScalar(b[i], 0)) {\n          // singular row, nonzero RHS\n\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\n          const bNew = [...b]\n          bNew[i] = 1\n\n          // loop upper triangular\n          for (let j = 0, lastIndex = iIndices.length; j < lastIndex; j++) {\n            const J = iIndices[j]\n            bNew[J] = subtractScalar(bNew[J], iValues[j])\n          }\n\n          B.push(bNew)\n        }\n      }\n    }\n\n    return B.map(x => new DenseMatrix({ data: x.map(e => [e]), size: [rows, 1] }))\n  }\n})\n","import { factory } from '../../../utils/factory.js'\nimport { DimensionError } from '../../../error/DimensionError.js'\n\nconst name = 'matAlgo08xS0Sid'\nconst dependencies = ['typed', 'equalScalar']\n\nexport const createMatAlgo08xS0Sid = /* #__PURE__ */ factory(name, dependencies, ({ typed, equalScalar }) => {\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 && B(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 matAlgo08xS0Sid (a, b, callback) {\n    // sparse matrix arrays\n    const avalues = a._values\n    const aindex = a._index\n    const aptr = a._ptr\n    const asize = a._size\n    const adt = a._datatype || a._data === undefined ? a._datatype : a.getDataType()\n    // sparse matrix arrays\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    const bsize = b._size\n    const bdt = b._datatype || b._data === undefined ? b._datatype : b.getDataType()\n\n    // validate dimensions\n    if (asize.length !== bsize.length) { throw new DimensionError(asize.length, bsize.length) }\n\n    // check rows & columns\n    if (asize[0] !== bsize[0] || asize[1] !== bsize[1]) { throw new RangeError('Dimension mismatch. Matrix A (' + asize + ') must match Matrix B (' + bsize + ')') }\n\n    // sparse matrix cannot be a Pattern matrix\n    if (!avalues || !bvalues) { throw new Error('Cannot perform operation on Pattern Sparse Matrices') }\n\n    // rows & columns\n    const rows = asize[0]\n    const columns = asize[1]\n\n    // datatype\n    let dt\n    // equal signature to use\n    let eq = equalScalar\n    // zero value\n    let zero = 0\n    // callback signature to use\n    let cf = callback\n\n    // process data types\n    if (typeof adt === 'string' && adt === bdt && adt !== 'mixed') {\n      // datatype\n      dt = adt\n      // find signature that matches (dt, dt)\n      eq = typed.find(equalScalar, [dt, dt])\n      // convert 0 to the same datatype\n      zero = typed.convert(0, dt)\n      // callback\n      cf = typed.find(callback, [dt, dt])\n    }\n\n    // result arrays\n    const cvalues = []\n    const cindex = []\n    const cptr = []\n\n    // workspace\n    const x = []\n    // marks indicating we have a value in x for a given column\n    const w = []\n\n    // vars\n    let k, k0, k1, i\n\n    // loop columns\n    for (let j = 0; j < columns; j++) {\n      // update cptr\n      cptr[j] = cindex.length\n      // columns mark\n      const mark = j + 1\n      // loop values in a\n      for (k0 = aptr[j], k1 = aptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = aindex[k]\n        // mark workspace\n        w[i] = mark\n        // set value\n        x[i] = avalues[k]\n        // add index\n        cindex.push(i)\n      }\n      // loop values in b\n      for (k0 = bptr[j], k1 = bptr[j + 1], k = k0; k < k1; k++) {\n        // row\n        i = bindex[k]\n        // check value exists in workspace\n        if (w[i] === mark) {\n          // evaluate callback\n          x[i] = cf(x[i], bvalues[k])\n        }\n      }\n      // initialize first index in j\n      k = cptr[j]\n      // loop index in j\n      while (k < cindex.length) {\n        // row\n        i = cindex[k]\n        // value @ i\n        const v = x[i]\n        // check for zero value\n        if (!eq(v, zero)) {\n          // push value\n          cvalues.push(v)\n          // increment pointer\n          k++\n        } else {\n          // remove value @ i, do not increment pointer\n          cindex.splice(k, 1)\n        }\n      }\n    }\n    // update cptr\n    cptr[columns] = cindex.length\n\n    // return sparse matrix\n    return a.createSparseMatrix({\n      values: cvalues,\n      index: cindex,\n      ptr: cptr,\n      size: [rows, columns],\n      datatype: adt === a._datatype && bdt === b._datatype ? dt : undefined\n    })\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nexport const createUseMatrixForArrayScalar = /* #__PURE__ */ factory('useMatrixForArrayScalar', ['typed', 'matrix'], ({ typed, matrix }) => ({\n  'Array, number': typed.referTo('DenseMatrix, number',\n    selfDn => (x, y) => selfDn(matrix(x), y).valueOf()),\n\n  'Array, BigNumber': typed.referTo('DenseMatrix, BigNumber',\n    selfDB => (x, y) => selfDB(matrix(x), y).valueOf()),\n\n  'number, Array': typed.referTo('number, DenseMatrix',\n    selfnD => (x, y) => selfnD(x, matrix(y)).valueOf()),\n\n  'BigNumber, Array': typed.referTo('BigNumber, DenseMatrix',\n    selfBD => (x, y) => selfBD(x, matrix(y)).valueOf())\n}))\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\nimport { leftShiftNumber } from '../../plain/number/index.js'\nimport { leftShiftBigNumber } from '../../utils/bignumber/bitwise.js'\n\nconst name = 'leftShift'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createLeftShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\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, 4], 4)       // returns Array [16, 32, 64]\n   *\n   * See also:\n   *\n   *    leftShift, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n   *\n   * @param  {number | BigNumber | bigint | Array | Matrix} x Value to be shifted\n   * @param  {number | BigNumber | bigint} y Amount of shifts\n   * @return {number | BigNumber | bigint | Array | Matrix} `x` shifted left `y` times\n   */\n  return typed(\n    name,\n    {\n      'number, number': leftShiftNumber,\n\n      'BigNumber, BigNumber': leftShiftBigNumber,\n\n      'bigint, bigint': (x, y) => x << y,\n\n      'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo11xS0s(x, y, self, false)\n      }),\n\n      'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo14xDs(x, y, self, false)\n      }),\n\n      'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo10xSids(y, x, self, true)\n      }),\n\n      'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo14xDs(y, x, self, true)\n      })\n    },\n    useMatrixForArrayScalar,\n    matrixAlgorithmSuite({\n      SS: matAlgo08xS0Sid,\n      DS: matAlgo01xDSid,\n      SD: matAlgo02xDS0\n    })\n  )\n})\n","import { rightArithShiftBigNumber } from '../../utils/bignumber/bitwise.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\nimport { rightArithShiftNumber } from '../../plain/number/index.js'\n\nconst name = 'rightArithShift'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createRightArithShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\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, 4]\n   *\n   * See also:\n   *\n   *    bitAnd, bitNot, bitOr, bitXor, rightArithShift, rightLogShift\n   *\n   * @param  {number | BigNumber | bigint | Array | Matrix} x Value to be shifted\n   * @param  {number | BigNumber | bigint} y Amount of shifts\n   * @return {number | BigNumber | bigint | Array | Matrix} `x` zero-filled shifted right `y` times\n   */\n  return typed(\n    name,\n    {\n      'number, number': rightArithShiftNumber,\n\n      'BigNumber, BigNumber': rightArithShiftBigNumber,\n\n      'bigint, bigint': (x, y) => x >> y,\n\n      'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo11xS0s(x, y, self, false)\n      }),\n\n      'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo14xDs(x, y, self, false)\n      }),\n\n      'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo10xSids(y, x, self, true)\n      }),\n\n      'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo14xDs(y, x, self, true)\n      })\n    },\n    useMatrixForArrayScalar,\n    matrixAlgorithmSuite({\n      SS: matAlgo08xS0Sid,\n      DS: matAlgo01xDSid,\n      SD: matAlgo02xDS0\n    })\n  )\n})\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatAlgo08xS0Sid } from '../../type/matrix/utils/matAlgo08xS0Sid.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { rightLogShiftNumber } from '../../plain/number/index.js'\nimport { createUseMatrixForArrayScalar } from './useMatrixForArrayScalar.js'\n\nconst name = 'rightLogShift'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createRightLogShift = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, DenseMatrix, concat }) => {\n  const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo08xS0Sid = createMatAlgo08xS0Sid({ typed, equalScalar })\n  const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const useMatrixForArrayScalar = createUseMatrixForArrayScalar({ typed, matrix })\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, 4]\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(\n    name,\n    {\n      'number, number': rightLogShiftNumber,\n\n      // 'BigNumber, BigNumber': ..., // TODO: implement BigNumber support for rightLogShift\n\n      'SparseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo11xS0s(x, y, self, false)\n      }),\n\n      'DenseMatrix, number | BigNumber': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(y, 0)) {\n          return x.clone()\n        }\n        return matAlgo14xDs(x, y, self, false)\n      }),\n\n      'number | BigNumber, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo10xSids(y, x, self, true)\n      }),\n\n      'number | BigNumber, DenseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (equalScalar(x, 0)) {\n          return zeros(y.size(), y.storage())\n        }\n        return matAlgo14xDs(y, x, self, true)\n      })\n    },\n    useMatrixForArrayScalar,\n    matrixAlgorithmSuite({\n      SS: matAlgo08xS0Sid,\n      DS: matAlgo01xDSid,\n      SD: matAlgo02xDS0\n    })\n  )\n})\n","import { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\nimport { createMatAlgo06xS0S0 } from '../../type/matrix/utils/matAlgo06xS0S0.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { andNumber } from '../../plain/number/index.js'\n\nconst name = 'and'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'zeros',\n  'not',\n  'concat'\n]\n\nexport const createAnd = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo06xS0S0 = createMatAlgo06xS0S0({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ typed })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Complex | Unit | Array | Matrix} x First value to check\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    {\n      'number, number': andNumber,\n\n      'Complex, Complex': function (x, y) {\n        return (x.re !== 0 || x.im !== 0) && (y.re !== 0 || y.im !== 0)\n      },\n\n      'BigNumber, BigNumber': function (x, y) {\n        return !x.isZero() && !y.isZero() && !x.isNaN() && !y.isNaN()\n      },\n\n      'bigint, bigint': andNumber,\n\n      'Unit, Unit': typed.referToSelf(self =>\n        (x, y) => self(x.value || 0, y.value || 0)),\n\n      'SparseMatrix, any': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (not(y)) {\n          // return zero matrix\n          return zeros(x.size(), x.storage())\n        }\n        return matAlgo11xS0s(x, y, self, false)\n      }),\n\n      'DenseMatrix, any': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (not(y)) {\n          // return zero matrix\n          return zeros(x.size(), x.storage())\n        }\n        return matAlgo14xDs(x, y, self, false)\n      }),\n\n      'any, SparseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (not(x)) {\n          // return zero matrix\n          return zeros(x.size(), x.storage())\n        }\n        return matAlgo11xS0s(y, x, self, true)\n      }),\n\n      'any, DenseMatrix': typed.referToSelf(self => (x, y) => {\n        // check scalar\n        if (not(x)) {\n          // return zero matrix\n          return zeros(x.size(), x.storage())\n        }\n        return matAlgo14xDs(y, x, self, true)\n      }),\n\n      'Array, any': typed.referToSelf(self => (x, y) => {\n        // use matrix implementation\n        return self(matrix(x), y).valueOf()\n      }),\n\n      'any, Array': typed.referToSelf(self => (x, y) => {\n        // use matrix implementation\n        return self(x, matrix(y)).valueOf()\n      })\n    },\n    matrixAlgorithmSuite({\n      SS: matAlgo06xS0S0,\n      DS: matAlgo02xDS0\n    })\n  )\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'compare'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'equalScalar',\n  'BigNumber',\n  'Fraction',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createCompare = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, equalScalar, matrix, BigNumber, Fraction, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo05xSfSf = createMatAlgo05xSfSf({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const compareUnits = createCompareUnits({ 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 absTol and relTol. 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 | bigint | Fraction | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | Fraction | Unit | string | Array | Matrix} y Second value to compare\n   * @return {number | BigNumber | bigint | 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  return typed(\n    name,\n    createCompareNumber({ typed, config }),\n    {\n      'boolean, boolean': function (x, y) {\n        return x === y ? 0 : (x > y ? 1 : -1)\n      },\n\n      'BigNumber, BigNumber': function (x, y) {\n        return bigNearlyEqual(x, y, config.relTol, config.absTol)\n          ? new BigNumber(0)\n          : new BigNumber(x.cmp(y))\n      },\n\n      'bigint, bigint': function (x, y) {\n        return x === y ? 0n : (x > y ? 1n : -1n)\n      },\n\n      'Fraction, Fraction': function (x, y) {\n        return new Fraction(x.compare(y))\n      },\n\n      'Complex, Complex': function () {\n        throw new TypeError('No ordering relation is defined for complex numbers')\n      }\n    },\n    compareUnits,\n    matrixAlgorithmSuite({\n      SS: matAlgo05xSfSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createCompareNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return nearlyEqual(x, y, config.relTol, config.absTol)\n        ? 0\n        : (x > y ? 1 : -1)\n    }\n  })\n})\n","import naturalSort from 'javascript-natural-sort'\nimport { isDenseMatrix, isSparseMatrix, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'compareNatural'\nconst dependencies = [\n  'typed',\n  'compare'\n]\n\nexport const createCompareNatural = /* #__PURE__ */ factory(name, dependencies, ({ typed, compare }) => {\n  const compareBooleans = compare.signatures['boolean,boolean']\n\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 relTol and absTol.\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  return typed(name, { 'any, any': _compareNatural }) // just to check # args\n\n  function _compareNatural (x, y) {\n    const typeX = typeOf(x)\n    const typeY = typeOf(y)\n    let c\n\n    // numeric types\n    if ((typeX === 'number' || typeX === 'BigNumber' || typeX === 'Fraction') &&\n        (typeY === 'number' || typeY === 'BigNumber' || typeY === 'Fraction')) {\n      c = compare(x, y)\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 naturalSort(typeX, typeY)\n      }\n    }\n\n    // matrix types\n    const matTypes = ['Array', 'DenseMatrix', 'SparseMatrix']\n    if (matTypes.includes(typeX) || matTypes.includes(typeY)) {\n      c = compareMatricesAndArrays(_compareNatural, x, y)\n      if (c !== 0) {\n        return c\n      } else {\n        return naturalSort(typeX, typeY)\n      }\n    }\n\n    // in case of different types, order by name of type, i.e. 'BigNumber' < 'Complex'\n    if (typeX !== typeY) {\n      return naturalSort(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 _compareNatural(x.value, y.value)\n      }\n\n      // compare by units\n      return compareArrays(_compareNatural, x.formatUnits(), y.formatUnits())\n    }\n\n    if (typeX === 'boolean') {\n      return compareBooleans(x, y)\n    }\n\n    if (typeX === 'string') {\n      return naturalSort(x, y)\n    }\n\n    if (typeX === 'Object') {\n      return compareObjects(_compareNatural, x, y)\n    }\n\n    if (typeX === 'null') {\n      return 0\n    }\n\n    if (typeX === 'undefined') {\n      return 0\n    }\n\n    // this should not occur...\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  function compareMatricesAndArrays (compareNatural, x, y) {\n    if (isSparseMatrix(x) && isSparseMatrix(y)) {\n      return compareArrays(compareNatural, x.toJSON().values, y.toJSON().values)\n    }\n    if (isSparseMatrix(x)) {\n      // note: convert to array is expensive\n      return compareMatricesAndArrays(compareNatural, x.toArray(), y)\n    }\n    if (isSparseMatrix(y)) {\n      // note: convert to array is expensive\n      return compareMatricesAndArrays(compareNatural, x, y.toArray())\n    }\n\n    // convert DenseArray into Array\n    if (isDenseMatrix(x)) {\n      return compareMatricesAndArrays(compareNatural, x.toJSON().data, y)\n    }\n    if (isDenseMatrix(y)) {\n      return compareMatricesAndArrays(compareNatural, x, y.toJSON().data)\n    }\n\n    // convert scalars to array\n    if (!Array.isArray(x)) {\n      return compareMatricesAndArrays(compareNatural, [x], y)\n    }\n    if (!Array.isArray(y)) {\n      return compareMatricesAndArrays(compareNatural, x, [y])\n    }\n\n    return compareArrays(compareNatural, x, y)\n  }\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  function compareArrays (compareNatural, x, y) {\n    // compare each value\n    for (let i = 0, ii = Math.min(x.length, y.length); i < ii; i++) {\n      const v = compareNatural(x[i], y[i])\n      if (v !== 0) {\n        return v\n      }\n    }\n\n    // compare the size of the arrays\n    if (x.length > y.length) { return 1 }\n    if (x.length < y.length) { return -1 }\n\n    // both Arrays have equal size and content\n    return 0\n  }\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  function compareObjects (compareNatural, x, y) {\n    const keysX = Object.keys(x)\n    const keysY = Object.keys(y)\n\n    // compare keys\n    keysX.sort(naturalSort)\n    keysY.sort(naturalSort)\n    const c = compareArrays(compareNatural, keysX, keysY)\n    if (c !== 0) {\n      return c\n    }\n\n    // compare values\n    for (let i = 0; i < keysX.length; i++) {\n      const v = compareNatural(x[keysX[i]], y[keysY[i]])\n      if (v !== 0) {\n        return v\n      }\n    }\n\n    return 0\n  }\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 */\nfunction compareComplexNumbers (x, y) {\n  if (x.re > y.re) { return 1 }\n  if (x.re < y.re) { return -1 }\n\n  if (x.im > y.im) { return 1 }\n  if (x.im < y.im) { return -1 }\n\n  return 0\n}\n","import { compareText as _compareText } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'compareText'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'concat'\n]\n\n_compareText.signature = 'any, any'\n\nexport const createCompareText = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, concat }) => {\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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  return typed(name, _compareText, matrixAlgorithmSuite({\n    elop: _compareText,\n    Ds: true\n  }))\n})\n\nexport const createCompareTextNumber = /* #__PURE__ */ factory(\n  name, ['typed'], ({ typed }) => typed(name, _compareText)\n)\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'equal'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createEqual = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 relTol and absTol. 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 | bigint | boolean | Complex | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    createEqualNumber({ typed, equalScalar }),\n    matrixAlgorithmSuite({\n      elop: equalScalar,\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createEqualNumber = factory(name, ['typed', 'equalScalar'], ({ typed, equalScalar }) => {\n  return typed(name, {\n    'any, any': function (x, y) {\n      // strict equality for null and undefined?\n      if (x === null) { return y === null }\n      if (y === null) { return x === null }\n      if (x === undefined) { return y === undefined }\n      if (y === undefined) { return x === undefined }\n\n      return equalScalar(x, y)\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'equalText'\nconst dependencies = [\n  'typed',\n  'compareText',\n  'isZero'\n]\n\nexport const createEqualText = /* #__PURE__ */ factory(name, dependencies, ({ typed, compareText, isZero }) => {\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 (x, y) {\n      return isZero(compareText(x, y))\n    }\n  })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'smaller'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createSmaller = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const compareUnits = createCompareUnits({ 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 relTol and absTol. 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 | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    createSmallerNumber({ typed, config }),\n    {\n      'boolean, boolean': (x, y) => x < y,\n\n      'BigNumber, BigNumber': function (x, y) {\n        return x.lt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol)\n      },\n\n      'bigint, bigint': (x, y) => x < y,\n\n      'Fraction, Fraction': (x, y) => (x.compare(y) === -1),\n\n      'Complex, Complex': function (x, y) {\n        throw new TypeError('No ordering relation is defined for complex numbers')\n      }\n    },\n    compareUnits,\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createSmallerNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return x < y && !nearlyEqual(x, y, config.relTol, config.absTol)\n    }\n  })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'smallerEq'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createSmallerEq = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const compareUnits = createCompareUnits({ 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 relTol and absTol. 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 | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    createSmallerEqNumber({ typed, config }),\n    {\n      'boolean, boolean': (x, y) => (x <= y),\n\n      'BigNumber, BigNumber': function (x, y) {\n        return x.lte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n      },\n\n      'bigint, bigint': (x, y) => (x <= y),\n\n      'Fraction, Fraction': (x, y) => (x.compare(y) !== 1),\n\n      'Complex, Complex': function () {\n        throw new TypeError('No ordering relation is defined for complex numbers')\n      }\n    },\n    compareUnits,\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createSmallerEqNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return x <= y || nearlyEqual(x, y, config.relTol, config.absTol)\n    }\n  })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'larger'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createLarger = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const compareUnits = createCompareUnits({ 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 relTol and absTol. 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 | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    createLargerNumber({ typed, config }),\n    {\n      'boolean, boolean': (x, y) => x > y,\n\n      'BigNumber, BigNumber': function (x, y) {\n        return x.gt(y) && !bigNearlyEqual(x, y, config.relTol, config.absTol)\n      },\n\n      'bigint, bigint': (x, y) => x > y,\n\n      'Fraction, Fraction': (x, y) => (x.compare(y) === 1),\n\n      'Complex, Complex': function () {\n        throw new TypeError('No ordering relation is defined for complex numbers')\n      }\n    },\n    compareUnits,\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createLargerNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return x > y && !nearlyEqual(x, y, config.relTol, config.absTol)\n    }\n  })\n})\n","import { nearlyEqual as bigNearlyEqual } from '../../utils/bignumber/nearlyEqual.js'\nimport { nearlyEqual } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\nimport { createCompareUnits } from './compareUnits.js'\n\nconst name = 'largerEq'\nconst dependencies = [\n  'typed',\n  'config',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createLargerEq = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\n  const compareUnits = createCompareUnits({ 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 relTol and absTol. 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 | bigint | Fraction | boolean | Unit | string | Array | Matrix} x First value to compare\n   * @param  {number | BigNumber | bigint | 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  return typed(\n    name,\n    createLargerEqNumber({ typed, config }),\n    {\n      'boolean, boolean': (x, y) => x >= y,\n\n      'BigNumber, BigNumber': function (x, y) {\n        return x.gte(y) || bigNearlyEqual(x, y, config.relTol, config.absTol)\n      },\n\n      'bigint, bigint': function (x, y) {\n        return x >= y\n      },\n\n      'Fraction, Fraction': (x, y) => (x.compare(y) !== -1),\n\n      'Complex, Complex': function () {\n        throw new TypeError('No ordering relation is defined for complex numbers')\n      }\n    },\n    compareUnits,\n    matrixAlgorithmSuite({\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n})\n\nexport const createLargerEqNumber = /* #__PURE__ */ factory(name, ['typed', 'config'], ({ typed, config }) => {\n  return typed(name, {\n    'number, number': function (x, y) {\n      return x >= y || nearlyEqual(x, y, config.relTol, config.absTol)\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'deepEqual'\nconst dependencies = [\n  'typed',\n  'equal'\n]\n\nexport const createDeepEqual = /* #__PURE__ */ factory(name, dependencies, ({ typed, equal }) => {\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 (x, y) {\n      return _deepEqual(x.valueOf(), y.valueOf())\n    }\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  function _deepEqual (x, y) {\n    if (Array.isArray(x)) {\n      if (Array.isArray(y)) {\n        const len = x.length\n        if (len !== y.length) {\n          return false\n        }\n\n        for (let 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})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo07xSSf } from '../../type/matrix/utils/matAlgo07xSSf.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'unequal'\nconst dependencies = [\n  'typed',\n  'config',\n  'equalScalar',\n  'matrix',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createUnequal = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, equalScalar, matrix, DenseMatrix, concat }) => {\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo07xSSf = createMatAlgo07xSSf({ typed, DenseMatrix })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 relTol and absTol. 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  return typed(\n    name,\n    createUnequalNumber({ typed, equalScalar }),\n    matrixAlgorithmSuite({\n      elop: _unequal,\n      SS: matAlgo07xSSf,\n      DS: matAlgo03xDSf,\n      Ss: matAlgo12xSfs\n    })\n  )\n\n  function _unequal (x, y) {\n    return !equalScalar(x, y)\n  }\n})\n\nexport const createUnequalNumber = factory(name, ['typed', 'equalScalar'], ({ typed, equalScalar }) => {\n  return typed(name, {\n    'any, any': function (x, y) {\n      // strict equality for null and undefined?\n      if (x === null) { return y !== null }\n      if (y === null) { return x !== null }\n      if (x === undefined) { return y !== undefined }\n      if (y === undefined) { return x !== undefined }\n\n      return !equalScalar(x, y)\n    }\n  })\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'partitionSelect'\nconst dependencies = ['typed', 'isNumeric', 'isNaN', 'compare']\n\nexport const createPartitionSelect = /* #__PURE__ */ factory(name, dependencies, ({ typed, isNumeric, isNaN, compare }) => {\n  const asc = compare\n  const desc = (a, b) => -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, math.compareText)   // 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   *    // the input array is mutated\n   *    arr = [5, 2, 1]\n   *    math.partitionSelect(arr, 0) // returns 1, arr is now: [1, 2, 5]\n   *    math.partitionSelect(arr, 1, 'desc') // returns 2, arr is now: [5, 2, 1]\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  return typed(name, {\n    'Array | Matrix, number': function (x, k) {\n      return _partitionSelect(x, k, asc)\n    },\n\n    'Array | Matrix, number, string': function (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\n    'Array | Matrix, number, function': _partitionSelect\n  })\n\n  function _partitionSelect (x, k, compare) {\n    if (!isInteger(k) || k < 0) {\n      throw new Error('k must be a non-negative integer')\n    }\n\n    if (isMatrix(x)) {\n      const size = x.size()\n      if (size.length > 1) {\n        throw new Error('Only one dimensional matrices supported')\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  /**\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  function quickSelect (arr, k, compare) {\n    if (k >= arr.length) {\n      throw new Error('k out of bounds')\n    }\n\n    // check for NaN values since these can cause an infinite while loop\n    for (let i = 0; i < arr.length; i++) {\n      if (isNumeric(arr[i]) && isNaN(arr[i])) {\n        return arr[i] // return NaN\n      }\n    }\n\n    let from = 0\n    let to = arr.length - 1\n\n    // if from == to we reached the kth element\n    while (from < to) {\n      let r = from\n      let w = to\n      const pivot = arr[Math.floor(Math.random() * (to - from + 1)) + from]\n\n      // stop if the reader and writer meets\n      while (r < w) {\n        // arr[r] >= pivot\n        if (compare(arr[r], pivot) >= 0) { // put the large values at the end\n          const tmp = arr[w]\n          arr[w] = arr[r]\n          arr[r] = tmp\n          --w\n        } else { // the value is smaller than the pivot, skip\n          ++r\n        }\n      }\n\n      // if we stepped up (r++) we need to step one down (arr[r] > pivot)\n      if (compare(arr[r], pivot) > 0) {\n        --r\n      }\n\n      // the r pointer is on the end of the first k elements\n      if (k <= r) {\n        to = r\n      } else {\n        from = r + 1\n      }\n    }\n\n    return arr[k]\n  }\n})\n","import { arraySize as size } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'sort'\nconst dependencies = ['typed', 'matrix', 'compare', 'compareNatural']\n\nexport const createSort = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, compare, compareNatural }) => {\n  const compareAsc = compare\n  const compareDesc = (a, b) => -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  return typed(name, {\n    Array: function (x) {\n      _arrayIsVector(x)\n      return x.sort(compareAsc)\n    },\n\n    Matrix: function (x) {\n      _matrixIsVector(x)\n      return matrix(x.toArray().sort(compareAsc), x.storage())\n    },\n\n    'Array, function': function (x, _comparator) {\n      _arrayIsVector(x)\n      return x.sort(_comparator)\n    },\n\n    'Matrix, function': function (x, _comparator) {\n      _matrixIsVector(x)\n      return matrix(x.toArray().sort(_comparator), x.storage())\n    },\n\n    'Array, string': function (x, order) {\n      _arrayIsVector(x)\n      return x.sort(_comparator(order))\n    },\n\n    'Matrix, string': function (x, order) {\n      _matrixIsVector(x)\n      return matrix(x.toArray().sort(_comparator(order)), x.storage())\n    }\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  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  /**\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  function _arrayIsVector (array) {\n    if (size(array).length !== 1) {\n      throw new Error('One dimensional array expected')\n    }\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  function _matrixIsVector (matrix) {\n    if (matrix.size().length !== 1) {\n      throw new Error('One dimensional matrix expected')\n    }\n  }\n})\n","import { deepForEach, reduce, containsCollections } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'max'\nconst dependencies = ['typed', 'config', 'numeric', 'larger']\n\nexport const createMax = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, larger }) => {\n  /**\n   * Compute the maximum value of a matrix or a  list with values.\n   * In case of a multidimensional 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, dimension)\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\n    // max([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': function (array, dim) {\n      return reduce(array, dim.valueOf(), _largest)\n    },\n\n    // max(a, b, c, d, ...)\n    '...': function (args) {\n      if (containsCollections(args)) {\n        throw new TypeError('Scalar values expected in function max')\n      }\n\n      return _max(args)\n    }\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  function _largest (x, y) {\n    try {\n      return larger(x, y) ? x : y\n    } catch (err) {\n      throw improveErrorMessage(err, 'max', y)\n    }\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  function _max (array) {\n    let res\n\n    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 improveErrorMessage(err, 'max', value)\n      }\n    })\n\n    if (res === undefined) {\n      throw new Error('Cannot calculate max of an empty array')\n    }\n\n    // make sure returning numeric value: parse a string into a numeric value\n    if (typeof res === 'string') {\n      res = numeric(res, safeNumberType(res, config))\n    }\n\n    return res\n  }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'min'\nconst dependencies = ['typed', 'config', 'numeric', 'smaller']\n\nexport const createMin = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, smaller }) => {\n  /**\n   * Compute the minimum value of a matrix or a  list of values.\n   * In case of a multidimensional 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, dimension)\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\n    // min([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': function (array, dim) {\n      return reduce(array, dim.valueOf(), _smallest)\n    },\n\n    // min(a, b, c, d, ...)\n    '...': function (args) {\n      if (containsCollections(args)) {\n        throw new TypeError('Scalar values expected in function min')\n      }\n\n      return _min(args)\n    }\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  function _smallest (x, y) {\n    try {\n      return smaller(x, y) ? x : y\n    } catch (err) {\n      throw improveErrorMessage(err, 'min', y)\n    }\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  function _min (array) {\n    let min\n\n    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 improveErrorMessage(err, 'min', value)\n      }\n    })\n\n    if (min === undefined) {\n      throw new Error('Cannot calculate min of an empty array')\n    }\n\n    // make sure returning numeric value: parse a string into a numeric value\n    if (typeof min === 'string') {\n      min = numeric(min, safeNumberType(min, config))\n    }\n\n    return min\n  }\n})\n","import { isArray, isMatrix, isString, typeOf } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ImmutableDenseMatrix'\nconst dependencies = [\n  'smaller',\n  'DenseMatrix'\n]\n\nexport const createImmutableDenseMatrixClass = /* #__PURE__ */ factory(name, dependencies, ({ smaller, DenseMatrix }) => {\n  function ImmutableDenseMatrix (data, datatype) {\n    if (!(this instanceof ImmutableDenseMatrix)) { throw new SyntaxError('Constructor must be called with the new operator') }\n    if (datatype && !isString(datatype)) { throw new Error('Invalid datatype: ' + datatype) }\n\n    if (isMatrix(data) || isArray(data)) {\n      // use DenseMatrix implementation\n      const matrix = new DenseMatrix(data, datatype)\n      // internal structures\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 && isArray(data.data) && 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 (' + 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  /**\n   * Attach type information\n   */\n  ImmutableDenseMatrix.prototype.type = 'ImmutableDenseMatrix'\n  ImmutableDenseMatrix.prototype.isImmutableDenseMatrix = true\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 | 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  ImmutableDenseMatrix.prototype.subset = function (index) {\n    switch (arguments.length) {\n      case 1:\n      {\n        // use base implementation\n        const m = DenseMatrix.prototype.subset.call(this, index)\n        // check result is a matrix\n        if (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        return m\n      }\n      // intentional fall through\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  /**\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  ImmutableDenseMatrix.prototype.set = function () {\n    throw new Error('Cannot invoke set on an Immutable Matrix instance')\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   * @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  ImmutableDenseMatrix.prototype.resize = function () {\n    throw new Error('Cannot invoke resize on an Immutable Matrix instance')\n  }\n\n  /**\n   * Disallows reshaping in favor of immutability.\n   *\n   * @throws {Error} Operation not allowed\n   */\n  ImmutableDenseMatrix.prototype.reshape = function () {\n    throw new Error('Cannot invoke reshape on an Immutable Matrix instance')\n  }\n\n  /**\n   * Create a clone of the matrix\n   * @return {ImmutableDenseMatrix} clone\n   */\n  ImmutableDenseMatrix.prototype.clone = function () {\n    return new ImmutableDenseMatrix({\n      data: clone(this._data),\n      size: clone(this._size),\n      datatype: this._datatype\n    })\n  }\n\n  /**\n   * Get a JSON representation of the matrix\n   * @returns {Object}\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  /**\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  ImmutableDenseMatrix.fromJSON = function (json) {\n    return new ImmutableDenseMatrix(json)\n  }\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  ImmutableDenseMatrix.prototype.swapRows = function () {\n    throw new Error('Cannot invoke swapRows on an Immutable Matrix instance')\n  }\n\n  /**\n   * Calculate the minimum value in the set\n   * @return {Number | undefined} min\n   */\n  ImmutableDenseMatrix.prototype.min = function () {\n    // check min has been calculated before\n    if (this._min === null) {\n      // minimum\n      let m = null\n      // compute min\n      this.forEach(function (v) {\n        if (m === null || smaller(v, m)) { m = v }\n      })\n      this._min = m !== null ? m : undefined\n    }\n    return this._min\n  }\n\n  /**\n   * Calculate the maximum value in the set\n   * @return {Number | undefined} max\n   */\n  ImmutableDenseMatrix.prototype.max = function () {\n    // check max has been calculated before\n    if (this._max === null) {\n      // maximum\n      let m = null\n      // compute max\n      this.forEach(function (v) {\n        if (m === null || smaller(m, v)) { m = v }\n      })\n      this._max = m !== null ? m : undefined\n    }\n    return this._max\n  }\n\n  return ImmutableDenseMatrix\n}, { isClass: true })\n","import { isArray, isMatrix, isRange } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Index'\nconst dependencies = ['ImmutableDenseMatrix', 'getMatrixDataType']\n\nexport const createIndexClass = /* #__PURE__ */ factory(name, dependencies, ({ ImmutableDenseMatrix, getMatrixDataType }) => {\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   *     An Array with Booleans\n   *     A Matrix with the Set values\n   *     A Matrix with Booleans\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._sourceSize = []\n    this._isScalar = true\n\n    for (let i = 0, ii = arguments.length; i < ii; i++) {\n      const arg = arguments[i]\n      const argIsArray = isArray(arg)\n      const argIsMatrix = isMatrix(arg)\n      let sourceSize = null\n      if (isRange(arg)) {\n        this._dimensions.push(arg)\n        this._isScalar = false\n      } else if (argIsArray || argIsMatrix) {\n        // create matrix\n        let m\n\n        if (getMatrixDataType(arg) === 'boolean') {\n          if (argIsArray) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg).valueOf())\n          if (argIsMatrix) m = _createImmutableMatrix(_booleansArrayToNumbersForIndex(arg._data).valueOf())\n          sourceSize = arg.valueOf().length\n        } else {\n          m = _createImmutableMatrix(arg.valueOf())\n        }\n\n        this._dimensions.push(m)\n        // size\n        const size = m.size()\n        // scalar\n        if (size.length !== 1 || size[0] !== 1 || sourceSize !== null) {\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      }\n      this._sourceSize.push(sourceSize)\n      // TODO: implement support for wildcard '*'\n    }\n  }\n\n  /**\n   * Attach type information\n   */\n  Index.prototype.type = 'Index'\n  Index.prototype.isIndex = true\n\n  function _createImmutableMatrix (arg) {\n    // loop array elements\n    for (let i = 0, l = arg.length; i < l; i++) {\n      if (typeof arg[i] !== 'number' || !isInteger(arg[i])) {\n        throw new TypeError('Index parameters must be positive integer numbers')\n      }\n    }\n    // create matrix\n    return new ImmutableDenseMatrix(arg)\n  }\n\n  /**\n   * Create a clone of the index\n   * @memberof Index\n   * @return {Index} clone\n   */\n  Index.prototype.clone = function () {\n    const index = new Index()\n    index._dimensions = clone(this._dimensions)\n    index._isScalar = this._isScalar\n    index._sourceSize = this._sourceSize\n    return index\n  }\n\n  /**\n   * Create an index from an array with ranges/numbers\n   * @memberof Index\n   * @param {Array.<Array | number>} ranges\n   * @return {Index} index\n   * @private\n   */\n  Index.create = function (ranges) {\n    const index = new Index()\n    Index.apply(index, ranges)\n    return index\n  }\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  Index.prototype.size = function () {\n    const size = []\n\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      const d = this._dimensions[i]\n      size[i] = (typeof d === 'string') ? 1 : d.size()[0]\n    }\n\n    return size\n  }\n\n  /**\n   * Get the maximum value for each of the indexes ranges.\n   * @memberof Index\n   * @returns {number[]} max\n   */\n  Index.prototype.max = function () {\n    const values = []\n\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      const range = this._dimensions[i]\n      values[i] = (typeof range === 'string') ? range : range.max()\n    }\n\n    return values\n  }\n\n  /**\n   * Get the minimum value for each of the indexes ranges.\n   * @memberof Index\n   * @returns {number[]} min\n   */\n  Index.prototype.min = function () {\n    const values = []\n\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      const range = this._dimensions[i]\n      values[i] = (typeof range === 'string') ? range : range.min()\n    }\n\n    return values\n  }\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  Index.prototype.forEach = function (callback) {\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      callback(this._dimensions[i], i, this)\n    }\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  Index.prototype.dimension = function (dim) {\n    return this._dimensions[dim] || null\n  }\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  Index.prototype.isObjectProperty = function () {\n    return this._dimensions.length === 1 && typeof this._dimensions[0] === 'string'\n  }\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  Index.prototype.getObjectProperty = function () {\n    return this.isObjectProperty() ? this._dimensions[0] : null\n  }\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  Index.prototype.isScalar = function () {\n    return this._isScalar\n  }\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  Index.prototype.toArray = function () {\n    const array = []\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      const dimension = this._dimensions[i]\n      array.push((typeof dimension === 'string') ? dimension : dimension.toArray())\n    }\n    return array\n  }\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  Index.prototype.valueOf = Index.prototype.toArray\n\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  Index.prototype.toString = function () {\n    const strings = []\n\n    for (let i = 0, ii = this._dimensions.length; i < ii; i++) {\n      const dimension = this._dimensions[i]\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  /**\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  Index.prototype.toJSON = function () {\n    return {\n      mathjs: 'Index',\n      dimensions: this._dimensions\n    }\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  Index.fromJSON = function (json) {\n    return Index.create(json.dimensions)\n  }\n\n  return Index\n}, { isClass: true })\n\n/**\n * Receives an array of booleans and returns an array of Numbers for Index\n * @param {Array} booleanArrayIndex An array of booleans\n * @return {Array} A set of numbers ready for index\n */\nfunction _booleansArrayToNumbersForIndex (booleanArrayIndex) {\n  // gets an array of booleans and returns an array of numbers\n  const indexOfNumbers = []\n  booleanArrayIndex.forEach((bool, idx) => {\n    if (bool) {\n      indexOfNumbers.push(idx)\n    }\n  })\n  return indexOfNumbers\n}\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'FibonacciHeap'\nconst dependencies = ['smaller', 'larger']\n\nexport const createFibonacciHeapClass = /* #__PURE__ */ factory(name, dependencies, ({ smaller, larger }) => {\n  const oneOverLogPhi = 1.0 / Math.log((1.0 + Math.sqrt(5.0)) / 2.0)\n\n  /**\n   * Fibonacci Heap implementation, used interally for Matrix math.\n   * @class FibonacciHeap\n   * @constructor FibonacciHeap\n   */\n  function FibonacciHeap () {\n    if (!(this instanceof FibonacciHeap)) { throw new SyntaxError('Constructor must be called with the new operator') }\n\n    // initialize fields\n    this._minimum = null\n    this._size = 0\n  }\n\n  /**\n   * Attach type information\n   */\n  FibonacciHeap.prototype.type = 'FibonacciHeap'\n  FibonacciHeap.prototype.isFibonacciHeap = true\n\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  FibonacciHeap.prototype.insert = function (key, value) {\n    // create node\n    const node = {\n      key,\n      value,\n      degree: 0\n    }\n    // check we have a node in the minimum\n    if (this._minimum) {\n      // minimum node\n      const minimum = this._minimum\n      // update left & right of node\n      node.left = minimum\n      node.right = minimum.right\n      minimum.right = node\n      node.right.left = node\n      // update minimum node in heap if needed\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\n      // this is the first node\n      this._minimum = node\n    }\n    // increment number of nodes in heap\n    this._size++\n    // return node\n    return node\n  }\n\n  /**\n   * Returns the number of nodes in heap. Running time: O(1) actual.\n   * @memberof FibonacciHeap\n   */\n  FibonacciHeap.prototype.size = function () {\n    return this._size\n  }\n\n  /**\n   * Removes all elements from this heap.\n   * @memberof FibonacciHeap\n   */\n  FibonacciHeap.prototype.clear = function () {\n    this._minimum = null\n    this._size = 0\n  }\n\n  /**\n   * Returns true if the heap is empty, otherwise false.\n   * @memberof FibonacciHeap\n   */\n  FibonacciHeap.prototype.isEmpty = function () {\n    return this._size === 0\n  }\n\n  /**\n   * Extracts the node with minimum key from heap. Amortized running\n   * time: O(log n).\n   * @memberof FibonacciHeap\n   */\n  FibonacciHeap.prototype.extractMinimum = function () {\n    // node to remove\n    const node = this._minimum\n    // check we have a minimum\n    if (node === null) { return node }\n    // current minimum\n    let minimum = this._minimum\n    // get number of children\n    let numberOfChildren = node.degree\n    // pointer to the first child\n    let x = node.child\n    // for each child of node do...\n    while (numberOfChildren > 0) {\n      // store node in right side\n      const tempRight = x.right\n      // remove x from child list\n      x.left.right = x.right\n      x.right.left = x.left\n      // add x to root list of heap\n      x.left = minimum\n      x.right = minimum.right\n      minimum.right = x\n      x.right.left = x\n      // set Parent[x] to null\n      x.parent = null\n      x = tempRight\n      numberOfChildren--\n    }\n    // remove node from root list of heap\n    node.left.right = node.right\n    node.right.left = node.left\n    // update minimum\n    if (node === node.right) {\n      // empty\n      minimum = null\n    } else {\n      // update minimum\n      minimum = node.right\n      // we need to update the pointer to the root with minimum key\n      minimum = _findMinimumNode(minimum, this._size)\n    }\n    // decrement size of heap\n    this._size--\n    // update minimum\n    this._minimum = minimum\n    // return node\n    return node\n  }\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  FibonacciHeap.prototype.remove = function (node) {\n    // decrease key value\n    this._minimum = _decreaseKey(this._minimum, node, -1)\n    // remove the smallest\n    this.extractMinimum()\n  }\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  function _decreaseKey (minimum, node, key) {\n    // set node key\n    node.key = key\n    // get parent node\n    const parent = node.parent\n    if (parent && smaller(node.key, parent.key)) {\n      // remove node from parent\n      _cut(minimum, node, parent)\n      // remove all nodes from parent to the root parent\n      _cascadingCut(minimum, parent)\n    }\n    // update minimum node if needed\n    if (smaller(node.key, minimum.key)) { minimum = node }\n    // return minimum\n    return minimum\n  }\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  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--\n    // reset y.child if necessary\n    if (parent.child === node) { parent.child = node.right }\n    // remove child if degree is 0\n    if (parent.degree === 0) { parent.child = null }\n    // add node to root list of heap\n    node.left = minimum\n    node.right = minimum.right\n    minimum.right = node\n    node.right.left = node\n    // set parent[node] to null\n    node.parent = null\n    // set mark[node] to false\n    node.mark = false\n  }\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  function _cascadingCut (minimum, node) {\n    // store parent node\n    const parent = node.parent\n    // if there's a parent...\n    if (!parent) { return }\n    // if node is unmarked, set it marked\n    if (!node.mark) {\n      node.mark = true\n    } else {\n      // it's marked, cut it from parent\n      _cut(minimum, node, parent)\n      // cut its parent as well\n      _cascadingCut(parent)\n    }\n  }\n\n  /**\n   * Make the first node a child of the second one. Running time: O(1) actual.\n   * @memberof FibonacciHeap\n   */\n  const _linkNodes = function (node, parent) {\n    // remove node from root list of heap\n    node.left.right = node.right\n    node.right.left = node.left\n    // make node a Child of parent\n    node.parent = parent\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    }\n    // increase degree[parent]\n    parent.degree++\n    // set mark[node] false\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    const arraySize = Math.floor(Math.log(size) * oneOverLogPhi) + 1\n    // create list with initial capacity\n    const array = new Array(arraySize)\n    // find the number of root nodes.\n    let numRoots = 0\n    let x = minimum\n    if (x) {\n      numRoots++\n      x = x.right\n      while (x !== minimum) {\n        numRoots++\n        x = x.right\n      }\n    }\n    // vars\n    let y\n    // For each node in root list do...\n    while (numRoots > 0) {\n      // access this node's degree..\n      let d = x.degree\n      // get next node\n      const next = x.right\n      // check if there is a node already in array with the same degree\n      while (true) {\n        // get node with the same degree is any\n        y = array[d]\n        if (!y) { break }\n        // make one node with the same degree a child of the other, do this based on the key value.\n        if (larger(x.key, y.key)) {\n          const temp = y\n          y = x\n          x = temp\n        }\n        // make y a child of x\n        _linkNodes(y, x)\n        // we have handled this degree, go to next one.\n        array[d] = null\n        d++\n      }\n      // save this node for later when we might encounter another of the same degree.\n      array[d] = x\n      // move forward through list.\n      x = next\n      numRoots--\n    }\n    // Set min to null (effectively losing the root list) and reconstruct the root list from the array entries in array[].\n    minimum = null\n    // loop nodes in array\n    for (let i = 0; i < arraySize; i++) {\n      // get current node\n      y = array[i]\n      if (!y) { continue }\n      // check if we have a linked list\n      if (minimum) {\n        // First remove node from root list.\n        y.left.right = y.right\n        y.right.left = y.left\n        // now add to root list, again.\n        y.left = minimum\n        y.right = minimum.right\n        minimum.right = y\n        y.right.left = y\n        // check if this is a new min.\n        if (smaller(y.key, minimum.key)) { minimum = y }\n      } else { minimum = y }\n    }\n    return minimum\n  }\n\n  return FibonacciHeap\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'Spa'\nconst dependencies = ['addScalar', 'equalScalar', 'FibonacciHeap']\n\nexport const createSpaClass = /* #__PURE__ */ factory(name, dependencies, ({ addScalar, equalScalar, FibonacciHeap }) => {\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)) { throw new SyntaxError('Constructor must be called with the new operator') }\n\n    // allocate vector, TODO use typed arrays\n    this._values = []\n    this._heap = new FibonacciHeap()\n  }\n\n  /**\n   * Attach type information\n   */\n  Spa.prototype.type = 'Spa'\n  Spa.prototype.isSpa = true\n\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  Spa.prototype.set = function (i, v) {\n    // check we have a value @ i\n    if (!this._values[i]) {\n      // insert in heap\n      const node = this._heap.insert(i, v)\n      // set the value @ i\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    const node = this._values[i]\n    if (node) { return node.value }\n    return 0\n  }\n\n  Spa.prototype.accumulate = function (i, v) {\n    // node @ i\n    let node = this._values[i]\n    if (!node) {\n      // insert in heap\n      node = this._heap.insert(i, v)\n      // initialize value\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    const heap = this._heap\n    const values = this._values\n    // nodes\n    const nodes = []\n    // node with minimum key, save it\n    let node = heap.extractMinimum()\n    if (node) { nodes.push(node) }\n    // extract nodes from heap (ordered)\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      }\n      // extract next node, save it\n      node = heap.extractMinimum()\n      if (node) { nodes.push(node) }\n    }\n    // reinsert all nodes in heap\n    for (let i = 0; i < nodes.length; i++) {\n      // current node\n      const n = nodes[i]\n      // insert node in heap\n      node = heap.insert(n.key, n.value)\n      // update values\n      values[node.key] = node\n    }\n  }\n\n  Spa.prototype.swap = function (i, j) {\n    // node @ i and j\n    let nodei = this._values[i]\n    let nodej = this._values[j]\n    // check we need to insert indeces\n    if (!nodei && nodej) {\n      // insert in heap\n      nodei = this._heap.insert(i, nodej.value)\n      // remove from heap\n      this._heap.remove(nodej)\n      // set values\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)\n      // remove from heap\n      this._heap.remove(nodei)\n      // set values\n      this._values[j] = nodej\n      this._values[i] = undefined\n    } else if (nodei && nodej) {\n      // swap values\n      const v = nodei.value\n      nodei.value = nodej.value\n      nodej.value = v\n    }\n  }\n\n  return Spa\n}, { isClass: true })\n","import { memoize } from '../function.js'\n\n/**\n * Calculate BigNumber e\n * @param {function} BigNumber   BigNumber constructor\n * @returns {BigNumber} Returns e\n */\nexport const createBigNumberE = memoize(function (BigNumber) {\n  return new BigNumber(1).exp()\n}, { 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 */\nexport const createBigNumberPhi = memoize(function (BigNumber) {\n  return new BigNumber(1).plus(new BigNumber(5).sqrt()).div(2)\n}, { hasher })\n\n/**\n * Calculate BigNumber pi.\n * @param {function} BigNumber   BigNumber constructor\n * @returns {BigNumber} Returns pi\n */\nexport const createBigNumberPi = memoize(function (BigNumber) {\n  return BigNumber.acos(-1)\n}, { hasher })\n\n/**\n * Calculate BigNumber tau, tau = 2 * pi\n * @param {function} BigNumber   BigNumber constructor\n * @returns {BigNumber} Returns tau\n */\nexport const createBigNumberTau = memoize(function (BigNumber) {\n  return createBigNumberPi(BigNumber).times(2)\n}, { 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 */\nfunction hasher (args) {\n  return args[0].precision\n}\n","import { isComplex, isUnit, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { memoize } from '../../utils/function.js'\nimport { endsWith } from '../../utils/string.js'\nimport { clone, hasOwnProperty } from '../../utils/object.js'\nimport { createBigNumberPi as createPi } from '../../utils/bignumber/constants.js'\n\nconst name = 'Unit'\nconst dependencies = [\n  '?on',\n  'config',\n  'addScalar',\n  'subtractScalar',\n  'multiplyScalar',\n  'divideScalar',\n  'pow',\n  'abs',\n  'fix',\n  'round',\n  'equal',\n  'isNumeric',\n  'format',\n  'number',\n  'Complex',\n  'BigNumber',\n  'Fraction'\n]\n\nexport const createUnitClass = /* #__PURE__ */ factory(name, dependencies, ({\n  on,\n  config,\n  addScalar,\n  subtractScalar,\n  multiplyScalar,\n  divideScalar,\n  pow,\n  abs,\n  fix,\n  round,\n  equal,\n  isNumeric,\n  format,\n  number,\n  Complex,\n  BigNumber,\n  Fraction\n}) => {\n  const toNumber = number\n  /**\n   * A unit can be constructed in the following ways:\n   *\n   *     const a = new Unit(value, valuelessUnit)\n   *     const b = new Unit(null, valuelessUnit)\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 | Unit} valuelessUnit   A unit without value. Can have prefix, like \"cm\"\n   */\n  function Unit (value, valuelessUnit) {\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) || isComplex(value))) {\n      throw new TypeError('First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined')\n    }\n\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\n    // The justification behind this is that if the constructor is explicitly called,\n    // the caller wishes the units to be returned exactly as supplied.\n    this.skipAutomaticSimplification = true\n\n    if (valuelessUnit === undefined) {\n      this.units = []\n      this.dimensions = BASE_DIMENSIONS.map(x => 0)\n    } else if (typeof valuelessUnit === 'string') {\n      const u = Unit.parse(valuelessUnit)\n      this.units = u.units\n      this.dimensions = u.dimensions\n    } else if (isUnit(valuelessUnit) && valuelessUnit.value === null) {\n      // clone from valuelessUnit\n      this.fixPrefix = valuelessUnit.fixPrefix\n      this.skipAutomaticSimplification = valuelessUnit.skipAutomaticSimplification\n      this.dimensions = valuelessUnit.dimensions.slice(0)\n      this.units = valuelessUnit.units.map(u => Object.assign({}, u))\n    } else {\n      throw new TypeError('Second parameter in Unit constructor must be a string or valueless Unit')\n    }\n\n    this.value = this._normalize(value)\n  }\n\n  /**\n   * Attach type information\n   */\n  Object.defineProperty(Unit, 'name', { value: 'Unit' })\n  Unit.prototype.constructor = Unit\n  Unit.prototype.type = 'Unit'\n  Unit.prototype.isUnit = true\n\n  // private variables and functions for the Unit parser\n  let 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    let number = ''\n    const 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    }\n\n    // get number, can have a single dot\n    if (c === '.') {\n      number += c\n      next()\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      if (c === '.') {\n        number += c\n        next()\n      }\n    }\n    while (isDigit(c)) {\n      number += c\n      next()\n    }\n\n    // check for exponential notation like \"2.3e-4\" or \"1.23e50\"\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\n      let tentativeNumber = ''\n      const tentativeIndex = index\n\n      tentativeNumber += c\n      next()\n\n      if (c === '+' || c === '-') {\n        tentativeNumber += c\n        next()\n      }\n\n      // Scientific notation MUST be followed by an exponent (otherwise we assume it is not scientific notation)\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      }\n\n      // We can now safely say that this is scientific notation.\n      number = number + tentativeNumber\n      while (isDigit(c)) {\n        number += c\n        next()\n      }\n    }\n\n    return number\n  }\n\n  function parseUnit () {\n    let unitName = ''\n\n    // Alphanumeric characters only; matches [a-zA-Z0-9]\n    while (isDigit(c) || Unit.isValidAlpha(c)) {\n      unitName += c\n      next()\n    }\n\n    // Must begin with [a-zA-Z]\n    const firstC = unitName.charAt(0)\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  /**\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  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    const unit = new Unit()\n    unit.units = []\n\n    let powerMultiplierCurrent = 1\n    let expectingUnit = false\n\n    // A unit should follow this pattern:\n    // [number] ...[ [*/] unit[^number] ]\n    // unit[^number] ... [ [*/] unit[^number] ]\n\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()\n\n    // Optional number at the start of the string\n    const valueStr = parseNumber()\n    let value = null\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 { // number\n        value = parseFloat(valueStr)\n      }\n\n      skipWhitespace() // Whitespace is not required here\n\n      // handle multiplication or division right after the value, like '1/s'\n      if (parseCharacter('*')) {\n        powerMultiplierCurrent = 1\n        expectingUnit = true\n      } else if (parseCharacter('/')) {\n        powerMultiplierCurrent = -1\n        expectingUnit = true\n      }\n    }\n\n    // Stack to keep track of powerMultipliers applied to each parentheses group\n    const powerMultiplierStack = []\n\n    // Running product of all elements in powerMultiplierStack\n    let powerMultiplierStackProduct = 1\n\n    while (true) {\n      skipWhitespace()\n\n      // Check for and consume opening parentheses, pushing powerMultiplierCurrent to the stack\n      // A '(' will always appear directly before a unit.\n      while (c === '(') {\n        powerMultiplierStack.push(powerMultiplierCurrent)\n        powerMultiplierStackProduct *= powerMultiplierCurrent\n        powerMultiplierCurrent = 1\n        next()\n        skipWhitespace()\n      }\n\n      // Is there something here?\n      let uStr\n      if (c) {\n        const oldC = c\n        uStr = parseUnit()\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      }\n\n      // Verify the unit exists and get the prefix (if any)\n      const res = _findUnit(uStr)\n      if (res === null) {\n        // Unit not found.\n        throw new SyntaxError('Unit \"' + uStr + '\" not found.')\n      }\n\n      let power = powerMultiplierCurrent * powerMultiplierStackProduct\n      // Is there a \"^ number\"?\n      skipWhitespace()\n      if (parseCharacter('^')) {\n        skipWhitespace()\n        const p = parseNumber()\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        power *= p\n      }\n\n      // Add the unit to the list\n      unit.units.push({\n        unit: res.unit,\n        prefix: res.prefix,\n        power\n      })\n      for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n        unit.dimensions[i] += (res.unit.dimensions[i] || 0) * power\n      }\n\n      // Check for and consume closing parentheses, popping from the stack.\n      // A ')' will always follow a unit.\n      skipWhitespace()\n      while (c === ')') {\n        if (powerMultiplierStack.length === 0) {\n          throw new SyntaxError('Unmatched \")\" in \"' + text + '\" at index ' + index.toString())\n        }\n        powerMultiplierStackProduct /= powerMultiplierStack.pop()\n        next()\n        skipWhitespace()\n      }\n\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      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      }\n\n      // Replace the unit into the auto unit system\n      if (res.unit.base) {\n        const baseDim = res.unit.base.key\n        UNIT_SYSTEMS.auto[baseDim] = {\n          unit: res.unit,\n          prefix: res.prefix\n        }\n      }\n    }\n\n    // Has the string been entirely consumed?\n    skipWhitespace()\n    if (c) {\n      throw new SyntaxError('Could not parse: \"' + str + '\"')\n    }\n\n    // Is there a trailing slash?\n    if (expectingUnit) {\n      throw new SyntaxError('Trailing characters: \"' + str + '\"')\n    }\n\n    // Is the parentheses stack empty?\n    if (powerMultiplierStack.length !== 0) {\n      throw new SyntaxError('Unmatched \"(\" in \"' + text + '\"')\n    }\n\n    // Are there any units at all?\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  /**\n   * create a copy of this unit\n   * @memberof Unit\n   * @return {Unit} Returns a cloned version of the unit\n   */\n  Unit.prototype.clone = function () {\n    const unit = new Unit()\n\n    unit.fixPrefix = this.fixPrefix\n    unit.skipAutomaticSimplification = this.skipAutomaticSimplification\n\n    unit.value = clone(this.value)\n    unit.dimensions = this.dimensions.slice(0)\n    unit.units = []\n    for (let i = 0; i < this.units.length; i++) {\n      unit.units[i] = { }\n      for (const p in this.units[i]) {\n        if (hasOwnProperty(this.units[i], p)) {\n          unit.units[i][p] = this.units[i][p]\n        }\n      }\n    }\n\n    return unit\n  }\n\n  /**\n   * Return the type of the value of this unit\n   *\n   * @memberof Unit\n   * @return {string} type of the value of the unit\n   */\n  Unit.prototype.valueType = function () {\n    return typeOf(this.value)\n  }\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   * @private\n   */\n  Unit.prototype._isDerived = function () {\n    if (this.units.length === 0) {\n      return false\n    }\n    return this.units.length > 1 || Math.abs(this.units[0].power - 1.0) > 1e-15\n  }\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  Unit.prototype._normalize = function (value) {\n    if (value === null || value === undefined || this.units.length === 0) {\n      return value\n    }\n    let res = value\n    const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n    for (let i = 0; i < this.units.length; i++) {\n      const unitValue = convert(this.units[i].unit.value)\n      const unitPrefixValue = convert(this.units[i].prefix.value)\n      const unitPower = convert(this.units[i].power)\n      res = multiplyScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower))\n    }\n\n    return res\n  }\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  Unit.prototype._denormalize = function (value, prefixValue) {\n    if (value === null || value === undefined || this.units.length === 0) {\n      return value\n    }\n    let res = value\n    const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n    for (let i = 0; i < this.units.length; i++) {\n      const unitValue = convert(this.units[i].unit.value)\n      const unitPrefixValue = convert(this.units[i].prefix.value)\n      const unitPower = convert(this.units[i].power)\n      res = divideScalar(res, pow(multiplyScalar(unitValue, unitPrefixValue), unitPower))\n    }\n\n    return res\n  }\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  const _findUnit = memoize((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 (hasOwnProperty(UNITS, str)) {\n      const unit = UNITS[str]\n      const prefix = unit.prefixes['']\n      return { unit, prefix }\n    }\n\n    for (const name in UNITS) {\n      if (hasOwnProperty(UNITS, name)) {\n        if (endsWith(str, name)) {\n          const unit = UNITS[name]\n          const prefixLen = (str.length - name.length)\n          const prefixName = str.substring(0, prefixLen)\n          const prefix = hasOwnProperty(unit.prefixes, prefixName)\n            ? unit.prefixes[prefixName]\n            : undefined\n          if (prefix !== undefined) {\n            // store unit, prefix, and value\n            return { unit, prefix }\n          }\n        }\n      }\n    }\n\n    return null\n  }, { hasher: (args) => args[0], 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  Unit.isValuelessUnit = function (name) {\n    return (_findUnit(name) !== null)\n  }\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_UNIT | string | undefined} base\n   */\n  Unit.prototype.hasBase = function (base) {\n    if (typeof (base) === 'string') {\n      base = BASE_UNITS[base]\n    }\n\n    if (!base) { return false }\n\n    // All dimensions must be the same\n    for (let 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    return true\n  }\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  Unit.prototype.equalBase = function (other) {\n    // All dimensions must be the same\n    for (let 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    return true\n  }\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  Unit.prototype.equals = function (other) {\n    return (this.equalBase(other) && equal(this.value, other.value))\n  }\n\n  /**\n   * Multiply this unit with another one or with a scalar\n   * @memberof Unit\n   * @param {Unit} other\n   * @return {Unit} product of this unit and the other unit\n   */\n  Unit.prototype.multiply = function (_other) {\n    const res = this.clone()\n    const other = isUnit(_other) ? _other : new Unit(_other)\n\n    for (let 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    }\n\n    // Append other's units list onto res\n    for (let i = 0; i < other.units.length; i++) {\n      // Make a shallow copy of every unit\n      const inverted = {\n        ...other.units[i]\n      }\n      res.units.push(inverted)\n    }\n\n    // If at least one operand has a value, then the result should also have a value\n    if (this.value !== null || other.value !== null) {\n      const valThis = this.value === null ? this._normalize(1) : this.value\n      const valOther = other.value === null ? other._normalize(1) : other.value\n      res.value = multiplyScalar(valThis, valOther)\n    } else {\n      res.value = null\n    }\n\n    if (isUnit(_other)) {\n      res.skipAutomaticSimplification = false\n    }\n\n    return getNumericIfUnitless(res)\n  }\n\n  /**\n   * Divide a number by this unit\n   *\n   * @memberof Unit\n   * @param {numeric} numerator\n   * @param {unit} result of dividing numerator by this unit\n   */\n  Unit.prototype.divideInto = function (numerator) {\n    return new Unit(numerator).divide(this)\n  }\n\n  /**\n   * Divide this unit by another one\n   * @memberof Unit\n   * @param {Unit | numeric} other\n   * @return {Unit} result of dividing this unit by the other unit\n   */\n  Unit.prototype.divide = function (_other) {\n    const res = this.clone()\n    const other = isUnit(_other) ? _other : new Unit(_other)\n\n    for (let 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    }\n\n    // Invert and append other's units list onto res\n    for (let i = 0; i < other.units.length; i++) {\n      // Make a shallow copy of every unit\n      const inverted = {\n        ...other.units[i],\n        power: -other.units[i].power\n      }\n      res.units.push(inverted)\n    }\n\n    // If at least one operand has a value, the result should have a value\n    if (this.value !== null || other.value !== null) {\n      const valThis = this.value === null ? this._normalize(1) : this.value\n      const valOther = other.value === null ? other._normalize(1) : other.value\n      res.value = divideScalar(valThis, valOther)\n    } else {\n      res.value = null\n    }\n\n    if (isUnit(_other)) {\n      res.skipAutomaticSimplification = false\n    }\n\n    return getNumericIfUnitless(res)\n  }\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  Unit.prototype.pow = function (p) {\n    const res = this.clone()\n\n    for (let 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    }\n\n    // Adjust the power of each unit in the list\n    for (let i = 0; i < res.units.length; i++) {\n      res.units[i].power *= p\n    }\n\n    if (res.value !== null) {\n      res.value = pow(res.value, p)\n\n      // 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\n    return getNumericIfUnitless(res)\n  }\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  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  /**\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  Unit.prototype.abs = function () {\n    const ret = this.clone()\n    if (ret.value !== null) {\n      if (ret._isDerived() || ret.units.length === 0 || 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        const convert = ret._numberConverter() // convert to Fraction or BigNumber if needed\n        const unitValue = convert(ret.units[0].unit.value)\n        const nominalOffset = convert(ret.units[0].unit.offset)\n        const unitOffset = multiplyScalar(unitValue, nominalOffset)\n        ret.value = subtractScalar(abs(addScalar(ret.value, unitOffset)), unitOffset)\n      }\n    }\n\n    for (const 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  /**\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  Unit.prototype.to = function (valuelessUnit) {\n    const value = this.value === null ? this._normalize(1) : this.value\n    let other\n    if (typeof valuelessUnit === 'string') {\n      other = Unit.parse(valuelessUnit)\n    } else if (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 ('${other.toString()}' != '${this.toString()}')`)\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() ||\n        this.units.length === 0 || other.units.length === 0 ||\n        this.units[0].unit.offset === other.units[0].unit.offset) {\n      other.value = clone(value)\n    } else {\n      /* Need to adjust value by difference in offset to convert */\n      const convert = Unit._getNumberConverter(typeOf(value)) // convert to Fraction or BigNumber if needed\n\n      const thisUnitValue = this.units[0].unit.value\n      const thisNominalOffset = this.units[0].unit.offset\n      const thisUnitOffset = multiplyScalar(thisUnitValue, thisNominalOffset)\n\n      const otherUnitValue = other.units[0].unit.value\n      const otherNominalOffset = other.units[0].unit.offset\n      const otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset)\n\n      other.value = addScalar(value, convert(subtractScalar(thisUnitOffset, otherUnitOffset)))\n    }\n    other.fixPrefix = true\n    other.skipAutomaticSimplification = true\n    return other\n  }\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  Unit.prototype.toNumber = function (valuelessUnit) {\n    return toNumber(this.toNumeric(valuelessUnit))\n  }\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  Unit.prototype.toNumeric = function (valuelessUnit) {\n    let other\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  /**\n   * Get a string representation of the unit.\n   * @memberof Unit\n   * @return {string}\n   */\n  Unit.prototype.toString = function () {\n    return this.format()\n  }\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  Unit.prototype.toJSON = function () {\n    return {\n      mathjs: 'Unit',\n      value: this._denormalize(this.value),\n      unit: this.units.length > 0 ? this.formatUnits() : null,\n      fixPrefix: this.fixPrefix\n    }\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  Unit.fromJSON = function (json) {\n    const unit = new Unit(json.value, json.unit ?? undefined)\n    unit.fixPrefix = json.fixPrefix || false\n    return unit\n  }\n\n  /**\n   * Returns the string representation of the unit.\n   * @memberof Unit\n   * @return {string}\n   */\n  Unit.prototype.valueOf = Unit.prototype.toString\n\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  Unit.prototype.simplify = function () {\n    const ret = this.clone()\n\n    const proposedUnitList = []\n\n    // Search for a matching base\n    let matchingBase\n    for (const key in currentUnitSystem) {\n      if (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      let matchingUnit\n      if (matchingBase) {\n        // Does the unit system have a matching unit?\n        if (hasOwnProperty(currentUnitSystem, matchingBase)) {\n          matchingUnit = currentUnitSystem[matchingBase]\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        let missingBaseDim = false\n        for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n          const baseDim = BASE_DIMENSIONS[i]\n          if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n            if (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        }\n\n        // Is the proposed unit list \"simpler\" than the existing one?\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  /**\n   * Returns a new Unit in the SI system with the same value as this one\n   */\n  Unit.prototype.toSI = function () {\n    const ret = this.clone()\n\n    const proposedUnitList = []\n\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 SI unit system\n    for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n      const baseDim = BASE_DIMENSIONS[i]\n      if (Math.abs(ret.dimensions[i] || 0) > 1e-12) {\n        if (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    }\n\n    // Replace this unit list with the proposed list\n    ret.units = proposedUnitList\n\n    ret.fixPrefix = true\n    ret.skipAutomaticSimplification = true\n\n    if (this.value !== null) {\n      ret.value = null\n      return this.to(ret)\n    }\n    return ret\n  }\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  Unit.prototype.formatUnits = function () {\n    let strNum = ''\n    let strDen = ''\n    let nNum = 0\n    let nDen = 0\n\n    for (let 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        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 (let i = 0; i < this.units.length; i++) {\n        if (this.units[i].power < 0) {\n          if (nNum > 0) {\n            strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name\n            if (Math.abs(this.units[i].power + 1.0) > 1e-15) {\n              strDen += '^' + (-this.units[i].power)\n            }\n          } else {\n            strDen += ' ' + this.units[i].prefix.name + this.units[i].unit.name\n            strDen += '^' + (this.units[i].power)\n          }\n        }\n      }\n    }\n    // Remove leading \" \"\n    strNum = strNum.substr(1)\n    strDen = strDen.substr(1)\n\n    // Add parans for better copy/paste back into evaluate, for example, or for better pretty print formatting\n    if (nNum > 1 && nDen > 0) {\n      strNum = '(' + strNum + ')'\n    }\n    if (nDen > 1 && nNum > 0) {\n      strDen = '(' + strDen + ')'\n    }\n\n    let str = strNum\n    if (nNum > 0 && nDen > 0) {\n      str += ' / '\n    }\n    str += strDen\n\n    return str\n  }\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  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    const simp = this.skipAutomaticSimplification || this.value === null\n      ? this.clone()\n      : this.simplify()\n\n    // 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    let isImaginary = false\n    if (typeof (simp.value) !== 'undefined' && simp.value !== null && 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 (const i in simp.units) {\n      if (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    }\n\n    // Now apply the best prefix\n    // Units must have only one unit and not have the fixPrefix flag set\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    const value = simp._denormalize(simp.value)\n    let str = (simp.value !== null) ? format(value, options || {}) : ''\n    const unitStr = simp.formatUnits()\n    if (simp.value && isComplex(simp.value)) {\n      str = '(' + str + ')' // Surround complex values with ( ) to enable better parsing\n    }\n    if (unitStr.length > 0 && str.length > 0) {\n      str += ' '\n    }\n    str += unitStr\n\n    return str\n  }\n\n  /**\n   * Calculate the best prefix using current value.\n   * @memberof Unit\n   * @returns {Object} prefix\n   * @private\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    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    }\n\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\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    const absValue = this.value !== null ? abs(this.value) : 0\n    const absUnitValue = abs(this.units[0].unit.value)\n    let bestPrefix = this.units[0].prefix\n    if (absValue === 0) {\n      return bestPrefix\n    }\n    const power = this.units[0].power\n    let 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    bestDiff = Math.abs(bestDiff)\n    const prefixes = this.units[0].unit.prefixes\n    for (const p in prefixes) {\n      if (hasOwnProperty(prefixes, p)) {\n        const prefix = prefixes[p]\n        if (prefix.scientific) {\n          const diff = Math.abs(\n            Math.log(absValue / Math.pow(prefix.value * absUnitValue, power)) / Math.LN10 - 1.2)\n\n          if (diff < bestDiff ||\n            (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  /**\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  Unit.prototype.splitUnit = function (parts) {\n    let x = this.clone()\n    const ret = []\n    for (let 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\n\n      // Get the numeric value of this unit\n      const xNumeric = x.toNumeric()\n\n      // 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      const xRounded = round(xNumeric)\n      let xFixed\n      const isNearlyEqual = equal(xRounded, xNumeric)\n      if (isNearlyEqual) {\n        xFixed = xRounded\n      } else {\n        xFixed = fix(x.toNumeric())\n      }\n\n      const y = new Unit(xFixed, parts[i].toString())\n      ret.push(y)\n      x = subtractScalar(x, y)\n    }\n\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    let testSum = 0\n    for (let i = 0; i < ret.length; i++) {\n      testSum = addScalar(testSum, ret[i].value)\n    }\n    if (equal(testSum, this.value)) {\n      x.value = 0\n    }\n\n    ret.push(x)\n\n    return ret\n  }\n\n  const PREFIXES = {\n    NONE: {\n      '': { name: '', value: 1, scientific: true }\n    },\n    SHORT: {\n      '': { name: '', value: 1, scientific: true },\n\n      da: { name: 'da', value: 1e1, scientific: false },\n      h: { name: 'h', value: 1e2, scientific: false },\n      k: { name: 'k', value: 1e3, scientific: true },\n      M: { name: 'M', value: 1e6, scientific: true },\n      G: { name: 'G', value: 1e9, scientific: true },\n      T: { name: 'T', value: 1e12, scientific: true },\n      P: { name: 'P', value: 1e15, scientific: true },\n      E: { name: 'E', value: 1e18, scientific: true },\n      Z: { name: 'Z', value: 1e21, scientific: true },\n      Y: { name: 'Y', value: 1e24, scientific: true },\n      R: { name: 'R', value: 1e27, scientific: true },\n      Q: { name: 'Q', value: 1e30, scientific: true },\n\n      d: { name: 'd', value: 1e-1, scientific: false },\n      c: { name: 'c', value: 1e-2, scientific: false },\n      m: { name: 'm', value: 1e-3, scientific: true },\n      u: { name: 'u', value: 1e-6, scientific: true },\n      n: { name: 'n', value: 1e-9, scientific: true },\n      p: { name: 'p', value: 1e-12, scientific: true },\n      f: { name: 'f', value: 1e-15, scientific: true },\n      a: { name: 'a', value: 1e-18, scientific: true },\n      z: { name: 'z', value: 1e-21, scientific: true },\n      y: { name: 'y', value: 1e-24, scientific: true },\n      r: { name: 'r', value: 1e-27, scientific: true },\n      q: { name: 'q', value: 1e-30, scientific: true }\n    },\n    LONG: {\n      '': { name: '', value: 1, scientific: true },\n\n      deca: { name: 'deca', value: 1e1, scientific: false },\n      hecto: { name: 'hecto', value: 1e2, scientific: false },\n      kilo: { name: 'kilo', value: 1e3, scientific: true },\n      mega: { name: 'mega', value: 1e6, scientific: true },\n      giga: { name: 'giga', value: 1e9, scientific: true },\n      tera: { name: 'tera', value: 1e12, scientific: true },\n      peta: { name: 'peta', value: 1e15, scientific: true },\n      exa: { name: 'exa', value: 1e18, scientific: true },\n      zetta: { name: 'zetta', value: 1e21, scientific: true },\n      yotta: { name: 'yotta', value: 1e24, scientific: true },\n      ronna: { name: 'ronna', value: 1e27, scientific: true },\n      quetta: { name: 'quetta', value: 1e30, scientific: true },\n\n      deci: { name: 'deci', value: 1e-1, scientific: false },\n      centi: { name: 'centi', value: 1e-2, scientific: false },\n      milli: { name: 'milli', value: 1e-3, scientific: true },\n      micro: { name: 'micro', value: 1e-6, scientific: true },\n      nano: { name: 'nano', value: 1e-9, scientific: true },\n      pico: { name: 'pico', value: 1e-12, scientific: true },\n      femto: { name: 'femto', value: 1e-15, scientific: true },\n      atto: { name: 'atto', value: 1e-18, scientific: true },\n      zepto: { name: 'zepto', value: 1e-21, scientific: true },\n      yocto: { name: 'yocto', value: 1e-24, scientific: true },\n      ronto: { name: 'ronto', value: 1e-27, scientific: true },\n      quecto: { name: 'quecto', value: 1e-30, scientific: true }\n    },\n    SQUARED: {\n      '': { name: '', value: 1, scientific: true },\n\n      da: { name: 'da', value: 1e2, scientific: false },\n      h: { name: 'h', value: 1e4, scientific: false },\n      k: { name: 'k', value: 1e6, scientific: true },\n      M: { name: 'M', value: 1e12, scientific: true },\n      G: { name: 'G', value: 1e18, scientific: true },\n      T: { name: 'T', value: 1e24, scientific: true },\n      P: { name: 'P', value: 1e30, scientific: true },\n      E: { name: 'E', value: 1e36, scientific: true },\n      Z: { name: 'Z', value: 1e42, scientific: true },\n      Y: { name: 'Y', value: 1e48, scientific: true },\n      R: { name: 'R', value: 1e54, scientific: true },\n      Q: { name: 'Q', value: 1e60, scientific: true },\n\n      d: { name: 'd', value: 1e-2, scientific: false },\n      c: { name: 'c', value: 1e-4, scientific: false },\n      m: { name: 'm', value: 1e-6, scientific: true },\n      u: { name: 'u', value: 1e-12, scientific: true },\n      n: { name: 'n', value: 1e-18, scientific: true },\n      p: { name: 'p', value: 1e-24, scientific: true },\n      f: { name: 'f', value: 1e-30, scientific: true },\n      a: { name: 'a', value: 1e-36, scientific: true },\n      z: { name: 'z', value: 1e-42, scientific: true },\n      y: { name: 'y', value: 1e-48, scientific: true },\n      r: { name: 'r', value: 1e-54, scientific: true },\n      q: { name: 'q', value: 1e-60, scientific: true }\n    },\n    CUBIC: {\n      '': { name: '', value: 1, scientific: true },\n\n      da: { name: 'da', value: 1e3, scientific: false },\n      h: { name: 'h', value: 1e6, scientific: false },\n      k: { name: 'k', value: 1e9, scientific: true },\n      M: { name: 'M', value: 1e18, scientific: true },\n      G: { name: 'G', value: 1e27, scientific: true },\n      T: { name: 'T', value: 1e36, scientific: true },\n      P: { name: 'P', value: 1e45, scientific: true },\n      E: { name: 'E', value: 1e54, scientific: true },\n      Z: { name: 'Z', value: 1e63, scientific: true },\n      Y: { name: 'Y', value: 1e72, scientific: true },\n      R: { name: 'R', value: 1e81, scientific: true },\n      Q: { name: 'Q', value: 1e90, scientific: true },\n\n      d: { name: 'd', value: 1e-3, scientific: false },\n      c: { name: 'c', value: 1e-6, scientific: false },\n      m: { name: 'm', value: 1e-9, scientific: true },\n      u: { name: 'u', value: 1e-18, scientific: true },\n      n: { name: 'n', value: 1e-27, scientific: true },\n      p: { name: 'p', value: 1e-36, scientific: true },\n      f: { name: 'f', value: 1e-45, scientific: true },\n      a: { name: 'a', value: 1e-54, scientific: true },\n      z: { name: 'z', value: 1e-63, scientific: true },\n      y: { name: 'y', value: 1e-72, scientific: true },\n      r: { name: 'r', value: 1e-81, scientific: true },\n      q: { name: 'q', value: 1e-90, scientific: true }\n    },\n    BINARY_SHORT_SI: {\n      '': { name: '', value: 1, scientific: true },\n      k: { name: 'k', value: 1e3, scientific: true },\n      M: { name: 'M', value: 1e6, scientific: true },\n      G: { name: 'G', value: 1e9, scientific: true },\n      T: { name: 'T', value: 1e12, scientific: true },\n      P: { name: 'P', value: 1e15, scientific: true },\n      E: { name: 'E', value: 1e18, scientific: true },\n      Z: { name: 'Z', value: 1e21, scientific: true },\n      Y: { name: 'Y', value: 1e24, scientific: true }\n    },\n    BINARY_SHORT_IEC: {\n      '': { name: '', value: 1, scientific: true },\n      Ki: { name: 'Ki', value: 1024, scientific: true },\n      Mi: { name: 'Mi', value: Math.pow(1024, 2), scientific: true },\n      Gi: { name: 'Gi', value: Math.pow(1024, 3), scientific: true },\n      Ti: { name: 'Ti', value: Math.pow(1024, 4), scientific: true },\n      Pi: { name: 'Pi', value: Math.pow(1024, 5), scientific: true },\n      Ei: { name: 'Ei', value: Math.pow(1024, 6), scientific: true },\n      Zi: { name: 'Zi', value: Math.pow(1024, 7), scientific: true },\n      Yi: { name: 'Yi', value: Math.pow(1024, 8), scientific: true }\n    },\n    BINARY_LONG_SI: {\n      '': { name: '', value: 1, scientific: true },\n      kilo: { name: 'kilo', value: 1e3, scientific: true },\n      mega: { name: 'mega', value: 1e6, scientific: true },\n      giga: { name: 'giga', value: 1e9, scientific: true },\n      tera: { name: 'tera', value: 1e12, scientific: true },\n      peta: { name: 'peta', value: 1e15, scientific: true },\n      exa: { name: 'exa', value: 1e18, scientific: true },\n      zetta: { name: 'zetta', value: 1e21, scientific: true },\n      yotta: { name: 'yotta', value: 1e24, scientific: true }\n    },\n    BINARY_LONG_IEC: {\n      '': { name: '', value: 1, scientific: true },\n      kibi: { name: 'kibi', value: 1024, scientific: true },\n      mebi: { name: 'mebi', value: Math.pow(1024, 2), scientific: true },\n      gibi: { name: 'gibi', value: Math.pow(1024, 3), scientific: true },\n      tebi: { name: 'tebi', value: Math.pow(1024, 4), scientific: true },\n      pebi: { name: 'pebi', value: Math.pow(1024, 5), scientific: true },\n      exi: { name: 'exi', value: Math.pow(1024, 6), scientific: true },\n      zebi: { name: 'zebi', value: Math.pow(1024, 7), scientific: true },\n      yobi: { name: 'yobi', value: Math.pow(1024, 8), scientific: true }\n    },\n    BTU: {\n      '': { name: '', value: 1, scientific: true },\n      MM: { name: 'MM', value: 1e6, scientific: true }\n    }\n  }\n\n  PREFIXES.SHORTLONG = Object.assign({}, PREFIXES.SHORT, PREFIXES.LONG)\n  PREFIXES.BINARY_SHORT = Object.assign({}, PREFIXES.BINARY_SHORT_SI, PREFIXES.BINARY_SHORT_IEC)\n  PREFIXES.BINARY_LONG = Object.assign({}, PREFIXES.BINARY_LONG_SI, PREFIXES.BINARY_LONG_IEC)\n\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  const BASE_DIMENSIONS = ['MASS', 'LENGTH', 'TIME', 'CURRENT', 'TEMPERATURE', 'LUMINOUS_INTENSITY', 'AMOUNT_OF_SUBSTANCE', 'ANGLE', 'BIT']\n\n  const 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\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\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\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 (const key in BASE_UNITS) {\n    if (hasOwnProperty(BASE_UNITS, key)) {\n      BASE_UNITS[key].key = key\n    }\n  }\n\n  const BASE_UNIT_NONE = {}\n\n  const UNIT_NONE = { name: '', base: BASE_UNIT_NONE, value: 1, offset: 0, dimensions: BASE_DIMENSIONS.map(x => 0) }\n\n  const 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\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    }, // 1/1000 inch\n\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    }, // 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    }, // 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    }, // 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    }, // 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    }, // 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    }, // 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    }, // 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    }, // 4046.86 m2\n    hectare: {\n      name: 'hectare',\n      base: BASE_UNITS.SURFACE,\n      prefixes: PREFIXES.NONE,\n      value: 10000,\n      offset: 0\n    }, // 10000 m2\n\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    }, // litre\n    l: {\n      name: 'l',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.SHORT,\n      value: 0.001,\n      offset: 0\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    }, // 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    }, // 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    }, // 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    }, // 5 mL\n    tablespoon: {\n      name: 'tablespoon',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.000015,\n      offset: 0\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    }, // 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    }, // 0.05 mL = 5e-8 m3\n\n    // Liquid volume\n    minim: {\n      name: 'minim',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.000000061611519921875,\n      offset: 0\n    }, // 1/61440 gallons\n    fluiddram: {\n      name: 'fluiddram',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.0000036966911953125,\n      offset: 0\n    }, // 1/1024 gallons\n    fluidounce: {\n      name: 'fluidounce',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.0000295735295625,\n      offset: 0\n    }, // 1/128 gallons\n    gill: {\n      name: 'gill',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.00011829411825,\n      offset: 0\n    }, // 1/32 gallons\n    cc: {\n      name: 'cc',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 1e-6,\n      offset: 0\n    }, // 1e-6 L\n    cup: {\n      name: 'cup',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.0002365882365,\n      offset: 0\n    }, // 1/16 gallons\n    pint: {\n      name: 'pint',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.000473176473,\n      offset: 0\n    }, // 1/8 gallons\n    quart: {\n      name: 'quart',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.000946352946,\n      offset: 0\n    }, // 1/4 gallons\n    gallon: {\n      name: 'gallon',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.003785411784,\n      offset: 0\n    }, // 3.785411784 L\n    beerbarrel: {\n      name: 'beerbarrel',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.117347765304,\n      offset: 0\n    }, // 31 gallons\n    oilbarrel: {\n      name: 'oilbarrel',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.158987294928,\n      offset: 0\n    }, // 42 gallons\n    hogshead: {\n      name: 'hogshead',\n      base: BASE_UNITS.VOLUME,\n      prefixes: PREFIXES.NONE,\n      value: 0.238480942392,\n      offset: 0\n    }, // 63 gallons\n\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\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\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\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\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, // 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, // Julian year\n      offset: 0\n    },\n    decade: {\n      name: 'decade',\n      base: BASE_UNITS.TIME,\n      prefixes: PREFIXES.NONE,\n      value: 315576000, // Julian decade\n      offset: 0\n    },\n    century: {\n      name: 'century',\n      base: BASE_UNITS.TIME,\n      prefixes: PREFIXES.NONE,\n      value: 3155760000, // Julian century\n      offset: 0\n    },\n    millennium: {\n      name: 'millennium',\n      base: BASE_UNITS.TIME,\n      prefixes: PREFIXES.NONE,\n      value: 31557600000, // Julian millennium\n      offset: 0\n    },\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\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, // 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, // 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, // 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, // 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, // 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, // 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, // will be filled in by calculateAngleValues()\n      offset: 0\n    },\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\n    // Temperature\n    // K(C) = °C + 273.15\n    // K(F) = (°F + 459.67) * (5 / 9)\n    // K(R) = °R * (5 / 9)\n    K: {\n      name: 'K',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.SHORT,\n      value: 1,\n      offset: 0\n    },\n    degC: {\n      name: 'degC',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.SHORT,\n      value: 1,\n      offset: 273.15\n    },\n    degF: {\n      name: 'degF',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.SHORT,\n      value: new Fraction(5, 9),\n      offset: 459.67\n    },\n    degR: {\n      name: 'degR',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.SHORT,\n      value: new Fraction(5, 9),\n      offset: 0\n    },\n    kelvin: {\n      name: 'kelvin',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.LONG,\n      value: 1,\n      offset: 0\n    },\n    celsius: {\n      name: 'celsius',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.LONG,\n      value: 1,\n      offset: 273.15\n    },\n    fahrenheit: {\n      name: 'fahrenheit',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.LONG,\n      value: new Fraction(5, 9),\n      offset: 459.67\n    },\n    rankine: {\n      name: 'rankine',\n      base: BASE_UNITS.TEMPERATURE,\n      prefixes: PREFIXES.LONG,\n      value: new Fraction(5, 9),\n      offset: 0\n    },\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\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\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\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.LONG,\n      value: 1,\n      offset: 0\n    },\n    erg: {\n      name: 'erg',\n      base: BASE_UNITS.ENERGY,\n      prefixes: PREFIXES.SHORTLONG, // Both kiloerg and kerg are acceptable\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\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\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\n    VA: {\n      name: 'VA',\n      base: BASE_UNITS.POWER,\n      prefixes: PREFIXES.SHORT,\n      value: 1,\n      offset: 0\n    },\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\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, // Both Mohm and megaohm are acceptable\n      value: 1,\n      offset: 0\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\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  }\n\n  // aliases (formerly plurals)\n  // note that ALIASES is only used at creation to create more entries in UNITS by copying the aliased units\n  const 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\n    lt: 'l',\n    litres: 'litre',\n    liter: 'litre',\n    liters: 'litre',\n    teaspoons: 'teaspoon',\n    tablespoons: 'tablespoon',\n    minims: 'minim',\n    fldr: 'fluiddram',\n    fluiddrams: 'fluiddram',\n    floz: 'fluidounce',\n    fluidounces: 'fluidounce',\n    gi: 'gill',\n    gills: 'gill',\n    cp: 'cup',\n    cups: 'cup',\n    pt: 'pint',\n    pints: 'pint',\n    qt: 'quart',\n    quarts: 'quart',\n    gal: 'gallon',\n    gallons: 'gallon',\n    bbl: 'beerbarrel',\n    beerbarrels: 'beerbarrel',\n    obl: 'oilbarrel',\n    oilbarrels: 'oilbarrel',\n    hogsheads: 'hogshead',\n    gtts: 'gtt',\n\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\n    kips: 'kip',\n    kgf: 'kilogramforce',\n\n    acres: 'acre',\n    hectares: 'hectare',\n    sqfeet: 'sqft',\n    sqyard: 'sqyd',\n    sqmile: 'sqmi',\n    sqmiles: 'sqmi',\n\n    mmhg: 'mmHg',\n    mmh2o: 'mmH2O',\n    cmh2o: 'cmH2O',\n\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\n    hertz: 'hertz',\n\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\n    BTUs: 'BTU',\n    watts: 'watt',\n    joules: 'joule',\n\n    amperes: 'ampere',\n    amps: 'ampere',\n    amp: '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\n    bit: 'bits',\n    byte: 'bytes'\n  }\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  function calculateAngleValues (config) {\n    if (config.number === 'BigNumber') {\n      const pi = createPi(BigNumber)\n      UNITS.rad.value = new BigNumber(1)\n      UNITS.deg.value = pi.div(180) // 2 * pi / 360\n      UNITS.grad.value = pi.div(200) // 2 * pi / 400\n      UNITS.cycle.value = pi.times(2) // 2 * pi\n      UNITS.arcsec.value = pi.div(648000) // 2 * pi / 360 / 3600\n      UNITS.arcmin.value = pi.div(10800) // 2 * pi / 360 / 60\n    } else { // number\n      UNITS.rad.value = 1\n      UNITS.deg.value = Math.PI / 180 // 2 * pi / 360\n      UNITS.grad.value = Math.PI / 200 // 2 * pi / 400\n      UNITS.cycle.value = Math.PI * 2 // 2 * pi\n      UNITS.arcsec.value = Math.PI / 648000 // 2 * pi / 360 / 3600\n      UNITS.arcmin.value = Math.PI / 10800 // 2 * pi / 360 / 60\n    }\n\n    // copy to the full names of the angles\n    UNITS.radian.value = UNITS.rad.value\n    UNITS.degree.value = UNITS.deg.value\n    UNITS.gradian.value = UNITS.grad.value\n  }\n\n  // apply the angle values now\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  /**\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  const UNIT_SYSTEMS = {\n    si: {\n      // Base units\n      NONE: { unit: UNIT_NONE, prefix: PREFIXES.NONE[''] },\n      LENGTH: { unit: UNITS.m, prefix: PREFIXES.SHORT[''] },\n      MASS: { unit: UNITS.g, prefix: PREFIXES.SHORT.k },\n      TIME: { unit: UNITS.s, prefix: PREFIXES.SHORT[''] },\n      CURRENT: { unit: UNITS.A, prefix: PREFIXES.SHORT[''] },\n      TEMPERATURE: { unit: UNITS.K, prefix: PREFIXES.SHORT[''] },\n      LUMINOUS_INTENSITY: { unit: UNITS.cd, prefix: PREFIXES.SHORT[''] },\n      AMOUNT_OF_SUBSTANCE: { unit: UNITS.mol, prefix: PREFIXES.SHORT[''] },\n      ANGLE: { unit: UNITS.rad, prefix: PREFIXES.SHORT[''] },\n      BIT: { unit: UNITS.bits, prefix: PREFIXES.SHORT[''] },\n\n      // Derived units\n      FORCE: { unit: UNITS.N, prefix: PREFIXES.SHORT[''] },\n      ENERGY: { unit: UNITS.J, prefix: PREFIXES.SHORT[''] },\n      POWER: { unit: UNITS.W, prefix: PREFIXES.SHORT[''] },\n      PRESSURE: { unit: UNITS.Pa, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_CHARGE: { unit: UNITS.C, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_CAPACITANCE: { unit: UNITS.F, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_POTENTIAL: { unit: UNITS.V, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_RESISTANCE: { unit: UNITS.ohm, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_INDUCTANCE: { unit: UNITS.H, prefix: PREFIXES.SHORT[''] },\n      ELECTRIC_CONDUCTANCE: { unit: UNITS.S, prefix: PREFIXES.SHORT[''] },\n      MAGNETIC_FLUX: { unit: UNITS.Wb, prefix: PREFIXES.SHORT[''] },\n      MAGNETIC_FLUX_DENSITY: { unit: UNITS.T, prefix: PREFIXES.SHORT[''] },\n      FREQUENCY: { unit: UNITS.Hz, prefix: PREFIXES.SHORT[''] }\n    }\n  }\n\n  // Clone to create the other unit systems\n  UNIT_SYSTEMS.cgs = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si))\n  UNIT_SYSTEMS.cgs.LENGTH = { unit: UNITS.m, prefix: PREFIXES.SHORT.c }\n  UNIT_SYSTEMS.cgs.MASS = { unit: UNITS.g, prefix: PREFIXES.SHORT[''] }\n  UNIT_SYSTEMS.cgs.FORCE = { unit: UNITS.dyn, prefix: PREFIXES.SHORT[''] }\n  UNIT_SYSTEMS.cgs.ENERGY = { unit: UNITS.erg, 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 = { unit: UNITS.ft, prefix: PREFIXES.NONE[''] }\n  UNIT_SYSTEMS.us.MASS = { unit: UNITS.lbm, prefix: PREFIXES.NONE[''] }\n  UNIT_SYSTEMS.us.TEMPERATURE = { unit: UNITS.degF, prefix: PREFIXES.NONE[''] }\n  UNIT_SYSTEMS.us.FORCE = { unit: UNITS.lbf, prefix: PREFIXES.NONE[''] }\n  UNIT_SYSTEMS.us.ENERGY = { unit: UNITS.BTU, prefix: PREFIXES.BTU[''] }\n  UNIT_SYSTEMS.us.POWER = { unit: UNITS.hp, prefix: PREFIXES.NONE[''] }\n  UNIT_SYSTEMS.us.PRESSURE = { unit: UNITS.psi, prefix: PREFIXES.NONE[''] }\n\n  // Add additional unit systems here.\n\n  // Choose a unit system to seed the auto unit system.\n  UNIT_SYSTEMS.auto = JSON.parse(JSON.stringify(UNIT_SYSTEMS.si))\n\n  // Set the current unit system\n  let currentUnitSystem = UNIT_SYSTEMS.auto\n\n  /**\n   * Set a unit system for formatting derived units.\n   * @memberof Unit\n   * @param {string} [name] The name of the unit system.\n   */\n  Unit.setUnitSystem = function (name) {\n    if (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  /**\n   * Return the current unit system.\n   * @memberof Unit\n   * @return {string} The current unit system.\n   */\n  Unit.getUnitSystem = function () {\n    for (const key in UNIT_SYSTEMS) {\n      if (hasOwnProperty(UNIT_SYSTEMS, key)) {\n        if (UNIT_SYSTEMS[key] === currentUnitSystem) {\n          return key\n        }\n      }\n    }\n  }\n\n  /**\n   * Converters to convert from number to an other numeric type like BigNumber\n   * or Fraction\n   */\n  Unit.typeConverters = {\n    BigNumber: function (x) {\n      if (x?.isFraction) return new BigNumber(x.n).div(x.d).times(x.s)\n      return new BigNumber(x + '') // stringify to prevent constructor error\n    },\n\n    Fraction: function (x) {\n      return new Fraction(x)\n    },\n\n    Complex: function (x) {\n      return x\n    },\n\n    number: function (x) {\n      if (x?.isFraction) return number(x)\n      return x\n    }\n  }\n\n  /**\n   * Retrieve the right converter function corresponding with this unit's\n   * value\n   *\n   * @memberof Unit\n   * @return {Function}\n   */\n  Unit.prototype._numberConverter = function () {\n    const convert = Unit.typeConverters[this.valueType()]\n    if (convert) {\n      return convert\n    }\n    throw new TypeError('Unsupported Unit value type \"' + this.valueType() + '\"')\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  Unit._getNumberConverter = function (type) {\n    if (!Unit.typeConverters[type]) {\n      throw new TypeError('Unsupported type \"' + type + '\"')\n    }\n\n    return Unit.typeConverters[type]\n  }\n\n  // Add dimensions to each built-in unit\n  for (const key in UNITS) {\n    if (hasOwnProperty(UNITS, key)) {\n      const unit = UNITS[key]\n      unit.dimensions = unit.base.dimensions\n    }\n  }\n\n  // Create aliases\n  for (const name in ALIASES) {\n    if (hasOwnProperty(ALIASES, name)) {\n      const unit = UNITS[ALIASES[name]]\n      const alias = {}\n      for (const key in unit) {\n        if (hasOwnProperty(unit, key)) {\n          alias[key] = unit[key]\n        }\n      }\n      alias.name = name\n      UNITS[name] = alias\n    }\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   * @memberof Unit\n   * @param {string} c Tested character\n   * @return {boolean} true if the character is a latin letter\n   */\n  Unit.isValidAlpha = function isValidAlpha (c) {\n    return /^[a-zA-Z]$/.test(c)\n  }\n\n  function assertUnitNameIsValid (name) {\n    for (let i = 0; i < name.length; i++) {\n      c = name.charAt(i)\n\n      if (i === 0 && !Unit.isValidAlpha(c)) { throw new Error('Invalid unit name (must begin with alpha character): \"' + name + '\"') }\n\n      if (i > 0 && !(Unit.isValidAlpha(c) ||\n        isDigit(c))) { 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   *       prefixes: 'long',\n   *       baseName: 'essence-of-foo'\n   *     },\n   *     bar: '40 foo',\n   *     baz: {\n   *       definition: '1 bar/hour',\n   *       prefixes: 'long'\n   *     }\n   *   },\n   *   {\n   *     override: true\n   *   })\n   * @memberof Unit\n   * @param {object} obj      Object map. Each key becomes a unit which is defined by its value.\n   * @param {object} options\n   * @return {Unit} the last created unit\n   */\n  Unit.createUnit = function (obj, options) {\n    if (typeof (obj) !== 'object') {\n      throw new TypeError(\"createUnit expects first parameter to be of type 'Object'\")\n    }\n\n    // Remove all units and aliases we are overriding\n    if (options && options.override) {\n      for (const key in obj) {\n        if (hasOwnProperty(obj, key)) {\n          Unit.deleteUnit(key)\n        }\n        if (obj[key].aliases) {\n          for (let i = 0; i < obj[key].aliases.length; i++) {\n            Unit.deleteUnit(obj[key].aliases[i])\n          }\n        }\n      }\n    }\n\n    // TODO: traverse multiple times until all units have been added\n    let lastUnit\n    for (const key in obj) {\n      if (hasOwnProperty(obj, key)) {\n        lastUnit = Unit.createUnitSingle(key, obj[key])\n      }\n    }\n    return lastUnit\n  }\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   *\n   * @memberof Unit\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   * @return {Unit}\n   */\n  Unit.createUnitSingle = function (name, obj) {\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    }\n\n    // Check collisions with existing units\n    if (hasOwnProperty(UNITS, name)) {\n      throw new Error('Cannot create unit \"' + name + '\": a unit with that name already exists')\n    }\n\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    assertUnitNameIsValid(name)\n\n    let defUnit = null // The Unit from which the new unit will be created.\n    let aliases = []\n    let offset = 0\n    let definition\n    let prefixes\n    let baseName\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 (typeof (obj) === 'object') {\n      definition = obj.definition\n      prefixes = obj.prefixes\n      offset = obj.offset\n      baseName = obj.baseName\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 (let i = 0; i < aliases.length; i++) {\n        if (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, { allowNoUnits: true })\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    if (prefixes && prefixes.toUpperCase) { prefixes = PREFIXES[prefixes.toUpperCase()] || PREFIXES.NONE } else { prefixes = PREFIXES.NONE }\n\n    // If defUnit is null, it is because the user did not\n    // specify a defintion. So create a new base dimension.\n    let newUnit = {}\n    if (!defUnit) {\n      // Add a new base dimension\n      baseName = baseName || name + '_STUFF' // foo --> foo_STUFF, or the essence of foo\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      BASE_DIMENSIONS.push(baseName)\n\n      // Push 0 onto existing base units\n      for (const b in BASE_UNITS) {\n        if (hasOwnProperty(BASE_UNITS, b)) {\n          BASE_UNITS[b].dimensions[BASE_DIMENSIONS.length - 1] = 0\n        }\n      }\n\n      // Add the new base unit\n      const newBaseUnit = { dimensions: [] }\n      for (let i = 0; i < BASE_DIMENSIONS.length; i++) {\n        newBaseUnit.dimensions[i] = 0\n      }\n      newBaseUnit.dimensions[BASE_DIMENSIONS.length - 1] = 1\n      newBaseUnit.key = baseName\n      BASE_UNITS[baseName] = newBaseUnit\n\n      newUnit = {\n        name,\n        value: 1,\n        dimensions: BASE_UNITS[baseName].dimensions.slice(0),\n        prefixes,\n        offset,\n        base: BASE_UNITS[baseName]\n      }\n\n      currentUnitSystem[baseName] = {\n        unit: newUnit,\n        prefix: PREFIXES.NONE['']\n      }\n    } else {\n      newUnit = {\n        name,\n        value: defUnit.value,\n        dimensions: defUnit.dimensions.slice(0),\n        prefixes,\n        offset\n      }\n\n      // Create a new base if no matching base exists\n      let anyMatch = false\n      for (const i in BASE_UNITS) {\n        if (hasOwnProperty(BASE_UNITS, i)) {\n          let match = true\n          for (let j = 0; j < BASE_DIMENSIONS.length; j++) {\n            if (Math.abs((newUnit.dimensions[j] || 0) - (BASE_UNITS[i].dimensions[j] || 0)) > 1e-12) {\n              match = false\n              break\n            }\n          }\n          if (match) {\n            anyMatch = true\n            newUnit.base = BASE_UNITS[i]\n            break\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        const newBaseUnit = { dimensions: defUnit.dimensions.slice(0) }\n        newBaseUnit.key = baseName\n        BASE_UNITS[baseName] = newBaseUnit\n\n        currentUnitSystem[baseName] = {\n          unit: newUnit,\n          prefix: PREFIXES.NONE['']\n        }\n\n        newUnit.base = BASE_UNITS[baseName]\n      }\n    }\n\n    Unit.UNITS[name] = newUnit\n\n    for (let i = 0; i < aliases.length; i++) {\n      const aliasName = aliases[i]\n      const alias = {}\n      for (const key in newUnit) {\n        if (hasOwnProperty(newUnit, key)) {\n          alias[key] = newUnit[key]\n        }\n      }\n      alias.name = aliasName\n      Unit.UNITS[aliasName] = alias\n    }\n\n    // delete the memoization cache because we created a new unit\n    delete _findUnit.cache\n\n    return new Unit(null, name)\n  }\n\n  Unit.deleteUnit = function (name) {\n    delete Unit.UNITS[name]\n\n    // delete the memoization cache because we deleted a unit\n    delete _findUnit.cache\n  }\n\n  // expose arrays with prefixes, dimensions, units, systems\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\n  return Unit\n}, { isClass: true })\n","import { factory } from '../../../utils/factory.js'\nimport { deepMap } from '../../../utils/collection.js'\n\nconst name = 'unit'\nconst dependencies = ['typed', 'Unit']\n\n// This function is named createUnitFunction to prevent a naming conflict with createUnit\nexport const createUnitFunction = /* #__PURE__ */ factory(name, dependencies, ({ typed, Unit }) => {\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, valuelessUnit : Unit)\n   *     math.unit(value : number, valuelessUnit : string)\n   *\n   * Examples:\n   *\n   *    const kph = math.unit('km/h')   // returns Unit km/h (valueless)\n   *    const v = math.unit(25, kph)    // returns Unit 25 km/h\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\n  return typed(name, {\n    Unit: function (x) {\n      return x.clone()\n    },\n\n    string: function (x) {\n      if (Unit.isValuelessUnit(x)) {\n        return new Unit(null, x) // a pure unit\n      }\n\n      return Unit.parse(x, { allowNoUnits: true }) // a unit with value, like '5cm'\n    },\n\n    'number | BigNumber | Fraction | Complex, string | Unit': function (value, unit) {\n      return new Unit(value, unit)\n    },\n\n    'number | BigNumber | Fraction': function (value) {\n      // dimensionless\n      return new Unit(value)\n    },\n\n    'Array | Matrix': typed.referToSelf(self => x => deepMap(x, self))\n  })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'sparse'\nconst dependencies = ['typed', 'SparseMatrix']\n\nexport const createSparse = /* #__PURE__ */ factory(name, dependencies, ({ typed, SparseMatrix }) => {\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\n    string: function (datatype) {\n      return new SparseMatrix([], datatype)\n    },\n\n    'Array | Matrix': function (data) {\n      return new SparseMatrix(data)\n    },\n\n    'Array | Matrix, string': function (data, datatype) {\n      return new SparseMatrix(data, datatype)\n    }\n  })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'createUnit'\nconst dependencies = ['typed', 'Unit']\n\nexport const createCreateUnit = /* #__PURE__ */ factory(name, dependencies, ({ typed, Unit }) => {\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   *     math.createUnit('km', math.unit(1000, 'm'))\n   *\n   * @param {string} name      The name of the new unit. Must be unique. Example: 'knot'\n   * @param {string, UnitDefinition, 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\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 (obj, options) {\n      return Unit.createUnit(obj, options)\n    },\n\n    // Same as above but without the options.\n    Object: function (obj) {\n      return Unit.createUnit(obj, {})\n    },\n\n    // Shortcut method for creating one unit.\n    'string, Unit | string | Object, Object': function (name, def, options) {\n      const obj = {}\n      obj[name] = def\n      return Unit.createUnit(obj, options)\n    },\n\n    // Same as above but without the options.\n    'string, Unit | string | Object': function (name, def) {\n      const obj = {}\n      obj[name] = def\n      return Unit.createUnit(obj, {})\n    },\n\n    // Without a definition, creates a base unit.\n    string: function (name) {\n      const obj = {}\n      obj[name] = {}\n      return Unit.createUnit(obj, {})\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'acos'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAcos = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n  /**\n   * Calculate the inverse cosine of a value.\n   *\n   * To avoid confusion with the matrix arccosine, this function does not\n   * apply to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} The arc cosine of x\n   */\n  return typed(name, {\n    number: function (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\n    Complex: function (x) {\n      return x.acos()\n    },\n\n    BigNumber: function (x) {\n      return x.acos()\n    }\n  })\n})\n","import { acosh, asinh, atanh, cosh, sign, sinh, tanh } from '../../utils/number.js'\n\nconst n1 = 'number'\nconst n2 = 'number, number'\n\nexport function acosNumber (x) {\n  return Math.acos(x)\n}\nacosNumber.signature = n1\n\nexport function acoshNumber (x) {\n  return acosh(x)\n}\nacoshNumber.signature = n1\n\nexport function acotNumber (x) {\n  return Math.atan(1 / x)\n}\nacotNumber.signature = n1\n\nexport function acothNumber (x) {\n  return isFinite(x)\n    ? (Math.log((x + 1) / x) + Math.log(x / (x - 1))) / 2\n    : 0\n}\nacothNumber.signature = n1\n\nexport function acscNumber (x) {\n  return Math.asin(1 / x)\n}\nacscNumber.signature = n1\n\nexport function acschNumber (x) {\n  const xInv = 1 / x\n  return Math.log(xInv + Math.sqrt(xInv * xInv + 1))\n}\nacschNumber.signature = n1\n\nexport function asecNumber (x) {\n  return Math.acos(1 / x)\n}\nasecNumber.signature = n1\n\nexport function asechNumber (x) {\n  const xInv = 1 / x\n  const ret = Math.sqrt(xInv * xInv - 1)\n  return Math.log(ret + xInv)\n}\nasechNumber.signature = n1\n\nexport function asinNumber (x) {\n  return Math.asin(x)\n}\nasinNumber.signature = n1\n\nexport function asinhNumber (x) {\n  return asinh(x)\n}\nasinhNumber.signature = n1\n\nexport function atanNumber (x) {\n  return Math.atan(x)\n}\natanNumber.signature = n1\n\nexport function atan2Number (y, x) {\n  return Math.atan2(y, x)\n}\natan2Number.signature = n2\n\nexport function atanhNumber (x) {\n  return atanh(x)\n}\natanhNumber.signature = n1\n\nexport function cosNumber (x) {\n  return Math.cos(x)\n}\ncosNumber.signature = n1\n\nexport function coshNumber (x) {\n  return cosh(x)\n}\ncoshNumber.signature = n1\n\nexport function cotNumber (x) {\n  return 1 / Math.tan(x)\n}\ncotNumber.signature = n1\n\nexport function cothNumber (x) {\n  const e = Math.exp(2 * x)\n  return (e + 1) / (e - 1)\n}\ncothNumber.signature = n1\n\nexport function cscNumber (x) {\n  return 1 / Math.sin(x)\n}\ncscNumber.signature = n1\n\nexport function 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))) * sign(x)\n  }\n}\ncschNumber.signature = n1\n\nexport function secNumber (x) {\n  return 1 / Math.cos(x)\n}\nsecNumber.signature = n1\n\nexport function sechNumber (x) {\n  return 2 / (Math.exp(x) + Math.exp(-x))\n}\nsechNumber.signature = n1\n\nexport function sinNumber (x) {\n  return Math.sin(x)\n}\nsinNumber.signature = n1\n\nexport function sinhNumber (x) {\n  return sinh(x)\n}\nsinhNumber.signature = n1\n\nexport function tanNumber (x) {\n  return Math.tan(x)\n}\ntanNumber.signature = n1\n\nexport function tanhNumber (x) {\n  return tanh(x)\n}\ntanhNumber.signature = n1\n","import { factory } from '../../utils/factory.js'\nimport { acoshNumber } from '../../plain/number/index.js'\n\nconst name = 'acosh'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAcosh = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arccosine of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if (x >= 1 || config.predictable) {\n        return acoshNumber(x)\n      }\n      if (x <= -1) {\n        return new Complex(Math.log(Math.sqrt(x * x - 1) - x), Math.PI)\n      }\n      return new Complex(x, 0).acosh()\n    },\n\n    Complex: function (x) {\n      return x.acosh()\n    },\n\n    BigNumber: function (x) {\n      return x.acosh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acotNumber } from '../../plain/number/index.js'\n\nconst name = 'acot'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createAcot = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  /**\n   * Calculate the inverse cotangent of a value, defined as `acot(x) = atan(1/x)`.\n   *\n   * To avoid confusion with the matrix arccotanget, this function does not\n   * apply to matrices.\n   *\n   * Syntax:\n   *\n   *    math.acot(x)\n   *\n   * Examples:\n   *\n   *    math.acot(0.5)           // returns number 1.1071487177940904\n   *    math.acot(2)             // returns number 0.4636476090008061\n   *    math.acot(math.cot(1.5)) // returns number 1.5\n   *\n   * See also:\n   *\n   *    cot, atan\n   *\n   * @param {number | BigNumber| Complex} x   Function input\n   * @return {number | BigNumber| Complex} The arc cotangent of x\n   */\n  return typed(name, {\n    number: acotNumber,\n\n    Complex: function (x) {\n      return x.acot()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).atan()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acothNumber } from '../../plain/number/index.js'\n\nconst name = 'acoth'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAcoth = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\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   * To avoid confusion with the matrix hyperbolic arccotangent, this\n   * function does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arccotangent of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if (x >= 1 || x <= -1 || config.predictable) {\n        return acothNumber(x)\n      }\n      return new Complex(x, 0).acoth()\n    },\n\n    Complex: function (x) {\n      return x.acoth()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).atanh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acscNumber } from '../../plain/number/index.js'\n\nconst name = 'acsc'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAcsc = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n  /**\n   * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`.\n   *\n   * To avoid confusion with the matrix arccosecant, this function does not\n   * apply to matrices.\n   *\n   * Syntax:\n   *\n   *    math.acsc(x)\n   *\n   * Examples:\n   *\n   *    math.acsc(2)             // returns 0.5235987755982989\n   *    math.acsc(0.5)           // returns Complex 1.5707963267948966 -1.3169578969248166i\n   *    math.acsc(math.csc(1.5)) // returns number ~1.5\n   *\n   * See also:\n   *\n   *    csc, asin, asec\n   *\n   * @param {number | BigNumber | Complex} x   Function input\n   * @return {number | BigNumber | Complex} The arc cosecant of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if (x <= -1 || x >= 1 || config.predictable) {\n        return acscNumber(x)\n      }\n      return new Complex(x, 0).acsc()\n    },\n\n    Complex: function (x) {\n      return x.acsc()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).asin()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { acschNumber } from '../../plain/number/index.js'\n\nconst name = 'acsch'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createAcsch = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\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   * To avoid confusion with the matrix hyperbolic arccosecant, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arccosecant of x\n   */\n  return typed(name, {\n    number: acschNumber,\n\n    Complex: function (x) {\n      return x.acsch()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).asinh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asecNumber } from '../../plain/number/index.js'\n\nconst name = 'asec'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAsec = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\n  /**\n   * Calculate the inverse secant of a value. Defined as `asec(x) = acos(1/x)`.\n   *\n   * To avoid confusion with the matrix arcsecant, this function does not\n   * apply to matrices.\n   *\n   * Syntax:\n   *\n   *    math.asec(x)\n   *\n   * Examples:\n   *\n   *    math.asec(2)             // returns 1.0471975511965979\n   *    math.asec(math.sec(1.5)) // returns 1.5\n   *\n   *    math.asec(0.5)           // returns Complex 0 + 1.3169578969248166i\n   *\n   * See also:\n   *\n   *    acos, acot, acsc\n   *\n   * @param {number | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} The arc secant of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if (x <= -1 || x >= 1 || config.predictable) {\n        return asecNumber(x)\n      }\n      return new Complex(x, 0).asec()\n    },\n\n    Complex: function (x) {\n      return x.asec()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).acos()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asechNumber } from '../../plain/number/index.js'\n\nconst name = 'asech'\nconst dependencies = ['typed', 'config', 'Complex', 'BigNumber']\n\nexport const createAsech = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex, BigNumber }) => {\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   * To avoid confusion with the matrix hyperbolic arcsecant, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arcsecant of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if ((x <= 1 && x >= -1) || config.predictable) {\n        const xInv = 1 / x\n        if (xInv > 0 || config.predictable) {\n          return asechNumber(x)\n        }\n\n        const 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\n    Complex: function (x) {\n      return x.asech()\n    },\n\n    BigNumber: function (x) {\n      return new BigNumber(1).div(x).acosh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'asin'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAsin = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n  /**\n   * Calculate the inverse sine of a value.\n   *\n   * To avoid confusion with the matric arcsine, this function does not apply\n   * to matrices.\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.3169578969248166i\n   *\n   * See also:\n   *\n   *    sin, atan, acos\n   *\n   * @param {number | BigNumber | Complex} x   Function input\n   * @return {number | BigNumber | Complex} The arc sine of x\n   */\n  return typed(name, {\n    number: function (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\n    Complex: function (x) {\n      return x.asin()\n    },\n\n    BigNumber: function (x) {\n      return x.asin()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { asinhNumber } from '../../plain/number/index.js'\n\nconst name = 'asinh'\nconst dependencies = ['typed']\n\nexport const createAsinh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the hyperbolic arcsine of a value,\n   * defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.\n   *\n   * To avoid confusion with the matrix hyperbolic arcsine, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arcsine of x\n   */\n  return typed('asinh', {\n    number: asinhNumber,\n\n    Complex: function (x) {\n      return x.asinh()\n    },\n\n    BigNumber: function (x) {\n      return x.asinh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'atan'\nconst dependencies = ['typed']\n\nexport const createAtan = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the inverse tangent of a value.\n   *\n   * To avoid confusion with matrix arctangent, this function does not apply\n   * to matrices.\n   *\n   * Syntax:\n   *\n   *    math.atan(x)\n   *\n   * Examples:\n   *\n   *    math.atan(0.5)           // returns number 0.4636476090008061\n   *    math.atan(2)             // returns number 1.1071487177940904\n   *    math.atan(math.tan(1.5)) // returns number 1.5\n   *\n   * See also:\n   *\n   *    tan, asin, acos\n   *\n   * @param {number | BigNumber | Complex} x   Function input\n   * @return {number | BigNumber | Complex} The arc tangent of x\n   */\n  return typed('atan', {\n    number: function (x) {\n      return Math.atan(x)\n    },\n\n    Complex: function (x) {\n      return x.atan()\n    },\n\n    BigNumber: function (x) {\n      return x.atan()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo02xDS0 } from '../../type/matrix/utils/matAlgo02xDS0.js'\nimport { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js'\nimport { createMatAlgo09xS0Sf } from '../../type/matrix/utils/matAlgo09xS0Sf.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'atan2'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'equalScalar',\n  'BigNumber',\n  'DenseMatrix',\n  'concat'\n]\n\nexport const createAtan2 = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, BigNumber, DenseMatrix, concat }) => {\n  const matAlgo02xDS0 = createMatAlgo02xDS0({ typed, equalScalar })\n  const matAlgo03xDSf = createMatAlgo03xDSf({ typed })\n  const matAlgo09xS0Sf = createMatAlgo09xS0Sf({ typed, equalScalar })\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo12xSfs = createMatAlgo12xSfs({ typed, DenseMatrix })\n  const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 number 1.1071487177940904\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  return typed(\n    name,\n    {\n      'number, number': Math.atan2,\n\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\n      // the imaginary.\n\n      'BigNumber, BigNumber': (y, x) => BigNumber.atan2(y, x)\n    },\n    matrixAlgorithmSuite({\n      scalar: 'number | BigNumber',\n      SS: matAlgo09xS0Sf,\n      DS: matAlgo03xDSf,\n      SD: matAlgo02xDS0,\n      Ss: matAlgo11xS0s,\n      sS: matAlgo12xSfs\n    })\n  )\n})\n","import { factory } from '../../utils/factory.js'\nimport { atanhNumber } from '../../plain/number/index.js'\n\nconst name = 'atanh'\nconst dependencies = ['typed', 'config', 'Complex']\n\nexport const createAtanh = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, Complex }) => {\n  /**\n   * Calculate the hyperbolic arctangent of a value,\n   * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.\n   *\n   * To avoid confusion with the matrix hyperbolic arctangent, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic arctangent of x\n   */\n  return typed(name, {\n    number: function (x) {\n      if ((x <= 1 && x >= -1) || config.predictable) {\n        return atanhNumber(x)\n      }\n      return new Complex(x, 0).atanh()\n    },\n\n    Complex: function (x) {\n      return x.atanh()\n    },\n\n    BigNumber: function (x) {\n      return x.atanh()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nexport const createTrigUnit = /* #__PURE__ */ factory(\n  'trigUnit', ['typed'], ({ typed }) => ({\n    Unit: typed.referToSelf(self => x => {\n      if (!x.hasBase(x.constructor.BASE_UNITS.ANGLE)) {\n        throw new TypeError('Unit in function cot is no angle')\n      }\n      return typed.find(self, x.valueType())(x.value)\n    })\n  })\n)\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'cos'\nconst dependencies = ['typed']\n\nexport const createCos = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the cosine of a value.\n   *\n   * To avoid confusion with the matrix cosine, this function does not\n   * apply to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Cosine of x\n   */\n  return typed(name, {\n    number: Math.cos,\n    'Complex | BigNumber': x => x.cos()\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cosh as coshNumber } from '../../utils/number.js'\n\nconst name = 'cosh'\nconst dependencies = ['typed']\n\nexport const createCosh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the hyperbolic cosine of a value,\n   * defined as `cosh(x) = 1/2 * (exp(x) + exp(-x))`.\n   *\n   * To avoid confusion with the matrix hyperbolic cosine, this function does\n   * not apply to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic cosine of x\n   */\n  return typed(name, {\n    number: coshNumber,\n    'Complex | BigNumber': x => x.cosh()\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cotNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'cot'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCot = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the cotangent of a value. Defined as `cot(x) = 1 / tan(x)`.\n   *\n   * To avoid confusion with the matrix cotangent, this function does not\n   * apply to matrices.\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: cotNumber,\n    Complex: x => x.cot(),\n    BigNumber: x => new BigNumber(1).div(x.tan())\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cothNumber } from '../../plain/number/index.js'\n\nconst name = 'coth'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCoth = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  /**\n   * Calculate the hyperbolic cotangent of a value,\n   * defined as `coth(x) = 1 / tanh(x)`.\n   *\n   * To avoid confusion with the matrix hyperbolic cotangent, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic cotangent of x\n   */\n  return typed(name, {\n    number: cothNumber,\n    Complex: x => x.coth(),\n    BigNumber: x => new BigNumber(1).div(x.tanh())\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { cscNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'csc'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCsc = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the cosecant of a value, defined as `csc(x) = 1/sin(x)`.\n   *\n   * To avoid confusion with the matrix cosecant, this function does not\n   * apply to matrices.\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 | BigNumber | Complex | Unit} x  Function input\n   * @return {number | BigNumber | Complex} Cosecant of x\n   */\n  return typed(name, {\n    number: cscNumber,\n    Complex: x => x.csc(),\n    BigNumber: x => new BigNumber(1).div(x.sin())\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { cschNumber } from '../../plain/number/index.js'\n\nconst name = 'csch'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createCsch = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  /**\n   * Calculate the hyperbolic cosecant of a value,\n   * defined as `csch(x) = 1 / sinh(x)`.\n   *\n   * To avoid confusion with the matrix hyperbolic cosecant, this function\n   * does not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic cosecant of x\n   */\n  return typed(name, {\n    number: cschNumber,\n    Complex: x => x.csch(),\n    BigNumber: x => new BigNumber(1).div(x.sinh())\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { secNumber } from '../../plain/number/index.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'sec'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createSec = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the secant of a value, defined as `sec(x) = 1/cos(x)`.\n   *\n   * To avoid confusion with the matrix secant, this function does not\n   * apply to matrices.\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 | BigNumber | Complex | Unit} x  Function input\n   * @return {number | BigNumber | Complex} Secant of x\n   */\n  return typed(name, {\n    number: secNumber,\n    Complex: x => x.sec(),\n    BigNumber: x => new BigNumber(1).div(x.cos())\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { sechNumber } from '../../plain/number/index.js'\n\nconst name = 'sech'\nconst dependencies = ['typed', 'BigNumber']\n\nexport const createSech = /* #__PURE__ */ factory(name, dependencies, ({ typed, BigNumber }) => {\n  /**\n   * Calculate the hyperbolic secant of a value,\n   * defined as `sech(x) = 1 / cosh(x)`.\n   *\n   * To avoid confusion with the matrix hyperbolic secant, this function does\n   * not apply to matrices.\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 | BigNumber | Complex} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic secant of x\n   */\n  return typed(name, {\n    number: sechNumber,\n    Complex: x => x.sech(),\n    BigNumber: x => new BigNumber(1).div(x.cosh())\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'sin'\nconst dependencies = ['typed']\n\nexport const createSin = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the sine of a value.\n   *\n   * To avoid confusion with the matrix sine, this function does not apply\n   * to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Sine of x\n   */\n  return typed(name, {\n    number: Math.sin,\n    'Complex | BigNumber': x => x.sin()\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { sinhNumber } from '../../plain/number/index.js'\n\nconst name = 'sinh'\nconst dependencies = ['typed']\n\nexport const createSinh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the hyperbolic sine of a value,\n   * defined as `sinh(x) = 1/2 * (exp(x) - exp(-x))`.\n   *\n   * To avoid confusion with the matrix hyperbolic sine, this function does\n   * not apply to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic sine of x\n   */\n  return typed(name, {\n    number: sinhNumber,\n    'Complex | BigNumber': x => x.sinh()\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createTrigUnit } from './trigUnit.js'\n\nconst name = 'tan'\nconst dependencies = ['typed']\n\nexport const createTan = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  const trigUnit = createTrigUnit({ typed })\n\n  /**\n   * Calculate the tangent of a value. `tan(x)` is equal to `sin(x) / cos(x)`.\n   *\n   * To avoid confusion with the matrix tangent, this function does not apply\n   * to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Tangent of x\n   */\n  return typed(name, {\n    number: Math.tan,\n    'Complex | BigNumber': x => x.tan()\n  }, trigUnit)\n})\n","import { factory } from '../../utils/factory.js'\nimport { tanh as _tanh } from '../../utils/number.js'\n\nconst name = 'tanh'\nconst dependencies = ['typed']\n\nexport const createTanh = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\n  /**\n   * Calculate the hyperbolic tangent of a value,\n   * defined as `tanh(x) = (exp(2 * x) - 1) / (exp(2 * x) + 1)`.\n   *\n   * To avoid confusion with matrix hyperbolic tangent, this function does\n   * not apply to matrices.\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} x  Function input\n   * @return {number | BigNumber | Complex} Hyperbolic tangent of x\n   */\n  return typed('tanh', {\n    number: _tanh,\n    'Complex | BigNumber': x => x.tanh()\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setCartesian'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetCartesian = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\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 (a1, a2) {\n      let result = []\n\n      if (subset(size(a1), new Index(0)) !== 0 && subset(size(a2), new Index(0)) !== 0) { // if any of them is empty, return empty\n        const b1 = flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural)\n        const b2 = flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural)\n        result = []\n        for (let i = 0; i < b1.length; i++) {\n          for (let j = 0; j < b2.length; j++) {\n            result.push([b1[i], b2[j]])\n          }\n        }\n      }\n      // return an array, if both inputs were arrays\n      if (Array.isArray(a1) && Array.isArray(a2)) {\n        return result\n      }\n      // return a matrix otherwise\n      return new DenseMatrix(result)\n    }\n  })\n})\n","import { flatten, generalize, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setDifference'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetDifference = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\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 (a1, a2) {\n      let result\n      if (subset(size(a1), new Index(0)) === 0) { // empty-anything=empty\n        result = []\n      } else if (subset(size(a2), new Index(0)) === 0) { // anything-empty=anything\n        return flatten(a1.toArray())\n      } else {\n        const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n        const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n        result = []\n        let inb2\n        for (let i = 0; i < b1.length; i++) {\n          inb2 = false\n          for (let j = 0; j < b2.length; j++) {\n            if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n              inb2 = true\n              break\n            }\n          }\n          if (!inb2) {\n            result.push(b1[i])\n          }\n        }\n      }\n      // return an array, if both inputs were arrays\n      if (Array.isArray(a1) && Array.isArray(a2)) {\n        return generalize(result)\n      }\n      // return a matrix otherwise\n      return new DenseMatrix(generalize(result))\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setDistinct'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetDistinct = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\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 (a) {\n      let result\n      if (subset(size(a), new Index(0)) === 0) { // if empty, return empty\n        result = []\n      } else {\n        const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n        result = []\n        result.push(b[0])\n        for (let i = 1; i < b.length; i++) {\n          if (compareNatural(b[i], b[i - 1]) !== 0) {\n            result.push(b[i])\n          }\n        }\n      }\n      // return an array, if the input was an array\n      if (Array.isArray(a)) {\n        return result\n      }\n      // return a matrix otherwise\n      return new DenseMatrix(result)\n    }\n  })\n})\n","import { flatten, generalize, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setIntersect'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index', 'DenseMatrix']\n\nexport const createSetIntersect = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index, DenseMatrix }) => {\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 (a1, a2) {\n      let result\n      if (subset(size(a1), new Index(0)) === 0 || subset(size(a2), new Index(0)) === 0) { // of any of them is empty, return empty\n        result = []\n      } else {\n        const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n        const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n        result = []\n        for (let i = 0; i < b1.length; i++) {\n          for (let j = 0; j < b2.length; j++) {\n            if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n              result.push(b1[i])\n              break\n            }\n          }\n        }\n      }\n      // return an array, if both inputs were arrays\n      if (Array.isArray(a1) && Array.isArray(a2)) {\n        return generalize(result)\n      }\n      // return a matrix otherwise\n      return new DenseMatrix(generalize(result))\n    }\n  })\n})\n","import { flatten, identify } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setIsSubset'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetIsSubset = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\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} Returns true when a1 is a subset of a2, returns false otherwise\n   */\n  return typed(name, {\n    'Array | Matrix, Array | Matrix': function (a1, a2) {\n      if (subset(size(a1), new Index(0)) === 0) { // empty is a subset of anything\n        return true\n      } else if (subset(size(a2), new Index(0)) === 0) { // anything is not a subset of empty\n        return false\n      }\n      const b1 = identify(flatten(Array.isArray(a1) ? a1 : a1.toArray()).sort(compareNatural))\n      const b2 = identify(flatten(Array.isArray(a2) ? a2 : a2.toArray()).sort(compareNatural))\n      let inb2\n      for (let i = 0; i < b1.length; i++) {\n        inb2 = false\n        for (let j = 0; j < b2.length; j++) {\n          if (compareNatural(b1[i].value, b2[j].value) === 0 && b1[i].identifier === b2[j].identifier) { // the identifier is always a decimal int\n            inb2 = true\n            break\n          }\n        }\n        if (inb2 === false) {\n          return false\n        }\n      }\n      return true\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setMultiplicity'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetMultiplicity = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\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 (e, a) {\n      if (subset(size(a), new Index(0)) === 0) { // if empty, return 0\n        return 0\n      }\n      const b = flatten(Array.isArray(a) ? a : a.toArray())\n      let count = 0\n      for (let i = 0; i < b.length; i++) {\n        if (compareNatural(b[i], e) === 0) {\n          count++\n        }\n      }\n      return count\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setPowerset'\nconst dependencies = ['typed', 'size', 'subset', 'compareNatural', 'Index']\n\nexport const createSetPowerset = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, subset, compareNatural, Index }) => {\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 (a) {\n      if (subset(size(a), new Index(0)) === 0) { // if empty, return empty\n        return []\n      }\n      const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n      const result = []\n      let number = 0\n      while (number.toString(2).length <= b.length) {\n        result.push(_subset(b, number.toString(2).split('').reverse()))\n        number++\n      }\n      // can not return a matrix, because of the different size of the subarrays\n      return _sort(result)\n    }\n  })\n\n  // create subset\n  function _subset (array, bitarray) {\n    const result = []\n    for (let i = 0; i < bitarray.length; i++) {\n      if (bitarray[i] === '1') {\n        result.push(array[i])\n      }\n    }\n    return result\n  }\n\n  // sort subsests by length\n  function _sort (array) {\n    let temp = []\n    for (let i = array.length - 1; i > 0; i--) {\n      for (let 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    return array\n  }\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setSize'\nconst dependencies = ['typed', 'compareNatural']\n\nexport const createSetSize = /* #__PURE__ */ factory(name, dependencies, ({ typed, compareNatural }) => {\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   * @param {boolean} [unique]  If true, only the unique values are counted. False by default\n   * @return {number}           The number of elements of the (multi)set\n   */\n  return typed(name, {\n    'Array | Matrix': function (a) {\n      return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length\n    },\n    'Array | Matrix, boolean': function (a, unique) {\n      if (unique === false || a.length === 0) {\n        return Array.isArray(a) ? flatten(a).length : flatten(a.toArray()).length\n      } else {\n        const b = flatten(Array.isArray(a) ? a : a.toArray()).sort(compareNatural)\n        let count = 1\n        for (let i = 1; i < b.length; i++) {\n          if (compareNatural(b[i], b[i - 1]) !== 0) {\n            count++\n          }\n        }\n        return count\n      }\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setSymDifference'\nconst dependencies = ['typed', 'size', 'concat', 'subset', 'setDifference', 'Index']\n\nexport const createSetSymDifference = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, concat, subset, setDifference, Index }) => {\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 (a1, a2) {\n      if (subset(size(a1), new Index(0)) === 0) { // if any of them is empty, return the other one\n        return flatten(a2)\n      } else if (subset(size(a2), new Index(0)) === 0) {\n        return flatten(a1)\n      }\n      const b1 = flatten(a1)\n      const b2 = flatten(a2)\n      return concat(setDifference(b1, b2), setDifference(b2, b1))\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'setUnion'\nconst dependencies = ['typed', 'size', 'concat', 'subset', 'setIntersect', 'setSymDifference', 'Index']\n\nexport const createSetUnion = /* #__PURE__ */ factory(name, dependencies, ({ typed, size, concat, subset, setIntersect, setSymDifference, Index }) => {\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 (a1, a2) {\n      if (subset(size(a1), new Index(0)) === 0) { // if any of them is empty, return the other one\n        return flatten(a2)\n      } else if (subset(size(a2), new Index(0)) === 0) {\n        return flatten(a1)\n      }\n      const b1 = flatten(a1)\n      const b2 = flatten(a2)\n      return concat(setSymDifference(b1, b2), setIntersect(b1, b2))\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { createMatAlgo01xDSid } from '../../type/matrix/utils/matAlgo01xDSid.js'\nimport { createMatAlgo04xSidSid } from '../../type/matrix/utils/matAlgo04xSidSid.js'\nimport { createMatAlgo10xSids } from '../../type/matrix/utils/matAlgo10xSids.js'\nimport { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js'\n\nconst name = 'add'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'addScalar',\n  'equalScalar',\n  'DenseMatrix',\n  'SparseMatrix',\n  'concat'\n]\n\nexport const createAdd = /* #__PURE__ */ factory(\n  name,\n  dependencies,\n  ({ typed, matrix, addScalar, equalScalar, DenseMatrix, SparseMatrix, concat }) => {\n    const matAlgo01xDSid = createMatAlgo01xDSid({ typed })\n    const matAlgo04xSidSid = createMatAlgo04xSidSid({ typed, equalScalar })\n    const matAlgo10xSids = createMatAlgo10xSids({ typed, DenseMatrix })\n    const matrixAlgorithmSuite = createMatrixAlgorithmSuite({ typed, matrix, concat })\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 | bigint | Fraction | Complex | Unit | Array | Matrix} x First value to add\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} y Second value to add\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix} Sum of `x` and `y`\n   */\n    return typed(\n      name,\n      {\n        'any, any': addScalar,\n\n        'any, any, ...any': typed.referToSelf(self => (x, y, rest) => {\n          let result = self(x, y)\n\n          for (let i = 0; i < rest.length; i++) {\n            result = self(result, rest[i])\n          }\n\n          return result\n        })\n      },\n      matrixAlgorithmSuite({\n        elop: addScalar,\n        DS: matAlgo01xDSid,\n        SS: matAlgo04xSidSid,\n        Ss: matAlgo10xSids\n      })\n    )\n  })\n","import { factory } from '../../utils/factory.js'\nimport { flatten } from '../../utils/array.js'\nimport { isComplex } from '../../utils/is.js'\n\nconst name = 'hypot'\nconst dependencies = [\n  'typed',\n  'abs',\n  'addScalar',\n  'divideScalar',\n  'multiplyScalar',\n  'sqrt',\n  'smaller',\n  'isPositive'\n]\n\nexport const createHypot = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, addScalar, divideScalar, multiplyScalar, sqrt, smaller, isPositive }) => {\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\n    Array: _hypot,\n\n    Matrix: M => _hypot(flatten(M.toArray()))\n  })\n\n  /**\n   * Calculate the hypotenusa for an Array with values\n   * @param {Array.<number | BigNumber>} args\n   * @return {number | BigNumber} Returns the result\n   * @private\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    let result = 0\n    let largest = 0\n\n    for (let i = 0; i < args.length; i++) {\n      if (isComplex(args[i])) {\n        throw new TypeError('Unexpected type of argument to hypot')\n      }\n      const value = abs(args[i])\n      if (smaller(largest, value)) {\n        result = multiplyScalar(result,\n          multiplyScalar(divideScalar(largest, value), divideScalar(largest, value)))\n        result = addScalar(result, 1)\n        largest = value\n      } else {\n        result = addScalar(result, isPositive(value)\n          ? multiplyScalar(divideScalar(value, largest), divideScalar(value, largest))\n          : value)\n      }\n    }\n\n    return multiplyScalar(largest, sqrt(result))\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'norm'\nconst dependencies = [\n  'typed',\n  'abs',\n  'add',\n  'pow',\n  'conj',\n  'sqrt',\n  'multiply',\n  'equalScalar',\n  'larger',\n  'smaller',\n  'matrix',\n  'ctranspose',\n  'eigs'\n]\n\nexport const createNorm = /* #__PURE__ */ factory(\n  name,\n  dependencies,\n  ({\n    typed,\n    abs,\n    add,\n    pow,\n    conj,\n    sqrt,\n    multiply,\n    equalScalar,\n    larger,\n    smaller,\n    matrix,\n    ctranspose,\n    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\n      Complex: function (x) {\n        return x.abs()\n      },\n\n      BigNumber: function (x) {\n        // norm(x) = abs(x)\n        return x.abs()\n      },\n\n      boolean: function (x) {\n        // norm(x) = abs(x)\n        return Math.abs(x)\n      },\n\n      Array: function (x) {\n        return _norm(matrix(x), 2)\n      },\n\n      Matrix: function (x) {\n        return _norm(x, 2)\n      },\n\n      'Array, number | BigNumber | string': function (x, p) {\n        return _norm(matrix(x), p)\n      },\n\n      'Matrix, number | BigNumber | string': function (x, p) {\n        return _norm(x, p)\n      }\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    function _vectorNormPlusInfinity (x) {\n      // norm(x, Infinity) = max(abs(x))\n      let pinf = 0\n      // skip zeros since abs(0) === 0\n      x.forEach(function (value) {\n        const v = abs(value)\n        if (larger(v, pinf)) {\n          pinf = v\n        }\n      }, true)\n      return pinf\n    }\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    function _vectorNormMinusInfinity (x) {\n      // norm(x, -Infinity) = min(abs(x))\n      let ninf\n      // skip zeros since abs(0) === 0\n      x.forEach(function (value) {\n        const v = abs(value)\n        if (!ninf || smaller(v, ninf)) {\n          ninf = v\n        }\n      }, true)\n      return ninf || 0\n    }\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    function _vectorNorm (x, p) {\n      // check p\n      if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n        return _vectorNormPlusInfinity(x)\n      }\n      if (p === Number.NEGATIVE_INFINITY || p === '-inf') {\n        return _vectorNormMinusInfinity(x)\n      }\n      if (p === 'fro') {\n        return _norm(x, 2)\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          let n = 0\n          // skip zeros since abs(0) === 0\n          x.forEach(function (value) {\n            n = add(pow(abs(value), p), n)\n          }, true)\n          return pow(n, 1 / p)\n        }\n        return Number.POSITIVE_INFINITY\n      }\n      // invalid parameter value\n      throw new Error('Unsupported parameter value')\n    }\n\n    /**\n     * Calculate the Frobenius norm for a matrix\n     * @param {Matrix} x\n     * @returns {number} Returns the norm\n     * @private\n     */\n    function _matrixNormFrobenius (x) {\n      // norm(x) = sqrt(sum(diag(x'x)))\n      let 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    /**\n     * Calculate the norm L1 for a matrix\n     * @param {Matrix} x\n     * @returns {number} Returns the norm\n     * @private\n     */\n    function _matrixNormOne (x) {\n      // norm(x) = the largest column sum\n      const c = []\n      // result\n      let maxc = 0\n      // skip zeros since abs(0) == 0\n      x.forEach(function (value, index) {\n        const j = index[1]\n        const cj = add(c[j] || 0, abs(value))\n        if (larger(cj, maxc)) {\n          maxc = cj\n        }\n        c[j] = cj\n      }, true)\n      return maxc\n    }\n\n    /**\n     * Calculate the norm L2 for a matrix\n     * @param {Matrix} x\n     * @returns {number} Returns the norm\n     * @private\n     */\n    function _matrixNormTwo (x) {\n      // norm(x) = sqrt( max eigenvalue of A*.A)\n      const sizeX = x.size()\n      if (sizeX[0] !== sizeX[1]) {\n        throw new RangeError('Invalid matrix dimensions')\n      }\n      const tx = ctranspose(x)\n      const squaredX = multiply(tx, x)\n      const eigenVals = eigs(squaredX).values.toArray()\n      const rho = eigenVals[eigenVals.length - 1]\n      return abs(sqrt(rho))\n    }\n\n    /**\n     * Calculate the infinity norm for a matrix\n     * @param {Matrix} x\n     * @returns {number} Returns the norm\n     * @private\n     */\n    function _matrixNormInfinity (x) {\n      // norm(x) = the largest row sum\n      const r = []\n      // result\n      let maxr = 0\n      // skip zeros since abs(0) == 0\n      x.forEach(function (value, index) {\n        const i = index[0]\n        const ri = add(r[i] || 0, abs(value))\n        if (larger(ri, maxr)) {\n          maxr = ri\n        }\n        r[i] = ri\n      }, true)\n      return maxr\n    }\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    function _matrixNorm (x, p) {\n      // check p\n      if (p === 1) {\n        return _matrixNormOne(x)\n      }\n      if (p === Number.POSITIVE_INFINITY || p === 'inf') {\n        return _matrixNormInfinity(x)\n      }\n      if (p === 'fro') {\n        return _matrixNormFrobenius(x)\n      }\n      if (p === 2) {\n        return _matrixNormTwo(x)\n      } // invalid parameter value\n\n      throw new Error('Unsupported parameter value ' + p)\n    }\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    function _norm (x, p) {\n      // size\n      const sizeX = x.size()\n\n      // check if it is a vector\n      if (sizeX.length === 1) {\n        return _vectorNorm(x, p)\n      }\n      // MxN matrix\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  }\n)\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'dot'\nconst dependencies = ['typed', 'addScalar', 'multiplyScalar', 'conj', 'size']\n\nexport const createDot = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, multiplyScalar, conj, size }) => {\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    const xSize = _size(x)\n    const ySize = _size(y)\n    let 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\n    return xLen\n  }\n\n  function _denseDot (a, b) {\n    const N = _validateDim(a, b)\n\n    const adata = isMatrix(a) ? a._data : a\n    const adt = isMatrix(a) ? a._datatype || a.getDataType() : undefined\n\n    const bdata = isMatrix(b) ? b._data : b\n    const bdt = isMatrix(b) ? b._datatype || b.getDataType() : undefined\n\n    // are these 2-dimensional column vectors? (as opposed to 1-dimensional vectors)\n    const aIsColumn = _size(a).length === 2\n    const bIsColumn = _size(b).length === 2\n\n    let add = addScalar\n    let mul = multiplyScalar\n\n    // process data types\n    if (adt && bdt && adt === bdt && typeof adt === 'string' && adt !== 'mixed') {\n      const dt = adt\n      // find signatures that matches (dt, dt)\n      add = typed.find(addScalar, [dt, dt])\n      mul = typed.find(multiplyScalar, [dt, dt])\n    }\n\n    // both vectors 1-dimensional\n    if (!aIsColumn && !bIsColumn) {\n      let c = mul(conj(adata[0]), bdata[0])\n      for (let i = 1; i < N; i++) {\n        c = add(c, mul(conj(adata[i]), bdata[i]))\n      }\n      return c\n    }\n\n    // a is 1-dim, b is column\n    if (!aIsColumn && bIsColumn) {\n      let c = mul(conj(adata[0]), bdata[0][0])\n      for (let i = 1; i < N; i++) {\n        c = add(c, mul(conj(adata[i]), bdata[i][0]))\n      }\n      return c\n    }\n\n    // a is column, b is 1-dim\n    if (aIsColumn && !bIsColumn) {\n      let c = mul(conj(adata[0][0]), bdata[0])\n      for (let i = 1; i < N; i++) {\n        c = add(c, mul(conj(adata[i][0]), bdata[i]))\n      }\n      return c\n    }\n\n    // both vectors are column\n    if (aIsColumn && bIsColumn) {\n      let c = mul(conj(adata[0][0]), bdata[0][0])\n      for (let i = 1; i < N; i++) {\n        c = add(c, mul(conj(adata[i][0]), bdata[i][0]))\n      }\n      return c\n    }\n  }\n\n  function _sparseDot (x, y) {\n    _validateDim(x, y)\n\n    const xindex = x._index\n    const xvalues = x._values\n\n    const yindex = y._index\n    const yvalues = y._values\n\n    // TODO optimize add & mul using datatype\n    let c = 0\n    const add = addScalar\n    const mul = multiplyScalar\n\n    let i = 0\n    let j = 0\n    while (i < xindex.length && j < yindex.length) {\n      const I = xindex[i]\n      const J = yindex[j]\n\n      if (I < J) {\n        i++\n        continue\n      }\n      if (I > J) {\n        j++\n        continue\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  }\n\n  // TODO remove this once #1771 is fixed\n  function _size (x) {\n    return isMatrix(x) ? x.size() : size(x)\n  }\n})\n","import { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'trace'\nconst dependencies = ['typed', 'matrix', 'add']\n\nexport const createTrace = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, add }) => {\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\n    SparseMatrix: _sparseTrace,\n\n    DenseMatrix: _denseTrace,\n\n    any: clone\n  })\n\n  function _denseTrace (m) {\n    // matrix size & data\n    const size = m._size\n    const data = m._data\n\n    // process dimensions\n    switch (size.length) {\n      case 1:\n        // vector\n        if (size[0] === 1) {\n          // return data[0]\n          return clone(data[0])\n        }\n        throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n      case 2:\n      {\n        // two dimensional\n        const rows = size[0]\n        const cols = size[1]\n        if (rows === cols) {\n          // calulate sum\n          let sum = 0\n          // loop diagonal\n          for (let i = 0; i < rows; i++) { sum = add(sum, data[i][i]) }\n          // return trace\n          return sum\n        } else {\n          throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n        }\n      }\n      default:\n        // multi dimensional\n        throw new RangeError('Matrix must be two dimensional (size: ' + format(size) + ')')\n    }\n  }\n\n  function _sparseTrace (m) {\n    // matrix arrays\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n    const size = m._size\n    // check dimensions\n    const rows = size[0]\n    const columns = size[1]\n    // matrix must be square\n    if (rows === columns) {\n      // calulate sum\n      let sum = 0\n      // check we have data (avoid looping columns)\n      if (values.length > 0) {\n        // loop columns\n        for (let j = 0; j < columns; j++) {\n          // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n          const k0 = ptr[j]\n          const k1 = ptr[j + 1]\n          // loop k within [k0, k1[\n          for (let k = k0; k < k1; k++) {\n            // row index\n            const i = index[k]\n            // check row\n            if (i === j) {\n              // accumulate value\n              sum = add(sum, values[k])\n              // exit loop\n              break\n            }\n            if (i > j) {\n              // exit loop, no value on the diagonal for column j\n              break\n            }\n          }\n        }\n      }\n      // return trace\n      return sum\n    }\n    throw new RangeError('Matrix must be square (size: ' + format(size) + ')')\n  }\n})\n","import { isBigNumber, isMatrix, isArray } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'index'\nconst dependencies = ['typed', 'Index']\n\nexport const createIndex = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index }) => {\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 or booleans\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   *    math.subset(b, math.index([false, true, true, true, false]))  // returns [2, 3, 4]\n   *\n   *    const a = math.matrix([[1, 2], [3, 4]])\n   *    a.subset(math.index(0, 1))             // returns 2\n   *    a.subset(math.index(0, [false, true])) // 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 (args) {\n      const ranges = args.map(function (arg) {\n        if (isBigNumber(arg)) {\n          return arg.toNumber() // convert BigNumber to Number\n        } else if (isArray(arg) || isMatrix(arg)) {\n          return arg.map(function (elem) {\n            // convert BigNumber to Number\n            return isBigNumber(elem) ? elem.toNumber() : elem\n          })\n        } else {\n          return arg\n        }\n      })\n\n      const res = new Index()\n      Index.apply(res, ranges)\n      return res\n    }\n  })\n})\n","// Reserved keywords not allowed to use in the parser\nexport const keywords = new Set([\n  'end'\n])\n","import { isNode } from '../../utils/is.js'\n\nimport { keywords } from '../keywords.js'\nimport { deepStrictEqual } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\nimport { createMap } from '../../utils/map.js'\n\nconst name = 'Node'\nconst dependencies = ['mathWithTransform']\n\nexport const createNode = /* #__PURE__ */ factory(name, dependencies, ({ mathWithTransform }) => {\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  function _validateScope (scope) {\n    for (const symbol of [...keywords]) {\n      if (scope.has(symbol)) {\n        throw new Error('Scope contains an illegal symbol, \"' + symbol + '\" is a reserved keyword')\n      }\n    }\n  }\n\n  class Node {\n    get type () { return 'Node' }\n    get isNode () { return true }\n\n    /**\n     * Evaluate the node\n     * @param {Object} [scope]  Scope to read/write variables\n     * @return {*}              Returns the result\n     */\n    evaluate (scope) {\n      return this.compile().evaluate(scope)\n    }\n\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    compile () {\n      const expr = this._compile(mathWithTransform, {})\n      const args = {}\n      const context = null\n\n      function evaluate (scope) {\n        const s = createMap(scope)\n        _validateScope(s)\n        return expr(s, args, context)\n      }\n\n      return {\n        evaluate\n      }\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    _compile (math, argNames) {\n      throw new Error('Method _compile must be implemented by type ' + this.type)\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    forEach (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    /**\n     * Create a new Node whose children are the results of calling the\n     * provided callback function for each child 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    map (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    /**\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    _ifNode (node) {\n      if (!isNode(node)) {\n        throw new TypeError('Callback function must return a Node')\n      }\n      return node\n    }\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    traverse (callback) {\n      // execute callback for itself\n      // eslint-disable-next-line\n      callback(this, null, null)\n\n      // recursively traverse over all children of a node\n      function _traverse (node, callback) {\n        node.forEach(function (child, path, parent) {\n          callback(child, path, parent)\n          _traverse(child, callback)\n        })\n      }\n\n      _traverse(this, callback)\n    }\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\n     * a 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. The \"signature\"\n     *          of the callback must be:\n     *          callback(node: Node, index: string, parent: Node) : Node\n     * @return {Node} Returns the original node or its replacement\n     */\n    transform (callback) {\n      function _transform (child, path, parent) {\n        const 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    /**\n     * Find any node in the node tree matching given filter function. For\n     * example, to 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\n     *            An array with nodes matching given filter criteria\n     */\n    filter (callback) {\n      const nodes = []\n\n      this.traverse(function (node, path, parent) {\n        if (callback(node, path, parent)) {\n          nodes.push(node)\n        }\n      })\n\n      return nodes\n    }\n\n    /**\n     * Create a shallow clone of this node\n     * @return {Node}\n     */\n    clone () {\n      // must be implemented by each of the Node implementations\n      throw new Error('Cannot clone a Node interface')\n    }\n\n    /**\n     * Create a deep clone of this node\n     * @return {Node}\n     */\n    cloneDeep () {\n      return this.map(function (node) {\n        return node.cloneDeep()\n      })\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    equals (other) {\n      return other\n        ? this.type === other.type && deepStrictEqual(this, other)\n        : false\n    }\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    toString (options) {\n      const customString = this._getCustomString(options)\n\n      if (typeof customString !== 'undefined') {\n        return customString\n      }\n\n      return this._toString(options)\n    }\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    _toString () {\n      // must be implemented by each of the Node implementations\n      throw new Error('_toString not implemented for ' + this.type)\n    }\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    toJSON () {\n      throw new Error(\n        'Cannot serialize object: toJSON not implemented by ' + this.type)\n    }\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    toHTML (options) {\n      const customString = this._getCustomString(options)\n\n      if (typeof customString !== 'undefined') {\n        return customString\n      }\n\n      return this._toHTML(options)\n    }\n\n    /**\n     * Internal function to generate the HTML output.\n     * This has to be implemented by every Node\n     *\n     * @throws {Error}\n     */\n    _toHTML () {\n      // must be implemented by each of the Node implementations\n      throw new Error('_toHTML not implemented for ' + this.type)\n    }\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    toTex (options) {\n      const customString = this._getCustomString(options)\n\n      if (typeof customString !== 'undefined') {\n        return customString\n      }\n\n      return this._toTex(options)\n    }\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    _toTex (options) {\n      // must be implemented by each of the Node implementations\n      throw new Error('_toTex not implemented for ' + this.type)\n    }\n\n    /**\n     * Helper used by `to...` functions.\n     */\n    _getCustomString (options) {\n      if (options && typeof options === 'object') {\n        switch (typeof options.handler) {\n          case 'object':\n          case 'undefined':\n            return\n          case 'function':\n            return options.handler(this, options)\n          default:\n            throw new TypeError('Object or function expected as callback')\n        }\n      }\n    }\n\n    /**\n     * Get identifier.\n     * @return {string}\n     */\n    getIdentifier () {\n      return this.type\n    }\n\n    /**\n     * Get the content of the current Node.\n     * @return {Node} node\n     **/\n    getContent () {\n      return this\n    }\n  }\n\n  return Node\n}, { isClass: true, isNode: true })\n","function _typeof(o) {\n  \"@babel/helpers - typeof\";\n\n  return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n    return typeof o;\n  } : function (o) {\n    return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n  }, _typeof(o);\n}\nexport { _typeof as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n  return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n    value: t,\n    enumerable: !0,\n    configurable: !0,\n    writable: !0\n  }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n  var i = toPrimitive(t, \"string\");\n  return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n  if (\"object\" != _typeof(t) || !t) return t;\n  var e = t[Symbol.toPrimitive];\n  if (void 0 !== e) {\n    var i = e.call(t, r || \"default\");\n    if (\"object\" != _typeof(i)) return i;\n    throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n  }\n  return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import { IndexError } from '../../../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 */\nexport function errorTransform (err) {\n  if (err && err.isIndexError) {\n    return new IndexError(\n      err.index + 1,\n      err.min + 1,\n      err.max !== undefined ? err.max + 1 : undefined)\n  }\n\n  return err\n}\n","import { errorTransform } from '../../transform/utils/errorTransform.js'\nimport { getSafeProperty } from '../../../utils/customs.js'\n\nexport function accessFactory ({ subset }) {\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') { // 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 (typeof object === 'object') {\n        if (!index.isObjectProperty()) {\n          throw new TypeError('Cannot apply a numeric index as object property')\n        }\n\n        return getSafeProperty(object, index.getObjectProperty())\n      } else {\n        throw new TypeError('Cannot apply index: unsupported type of object')\n      }\n    } catch (err) {\n      throw errorTransform(err)\n    }\n  }\n}\n","import {\n  isAccessorNode,\n  isArrayNode,\n  isConstantNode,\n  isFunctionNode,\n  isIndexNode,\n  isNode,\n  isObjectNode,\n  isParenthesisNode,\n  isSymbolNode\n} from '../../utils/is.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { accessFactory } from './utils/access.js'\n\nconst name = 'AccessorNode'\nconst dependencies = [\n  'subset',\n  'Node'\n]\n\nexport const createAccessorNode = /* #__PURE__ */ factory(name, dependencies, ({ subset, Node }) => {\n  const access = accessFactory({ subset })\n\n  /**\n   * Are parenthesis needed?\n   * @private\n   */\n  function needParenthesis (node) {\n    // TODO: maybe make a method on the nodes which tells whether they need parenthesis?\n    return !(\n      isAccessorNode(node) ||\n        isArrayNode(node) ||\n        isConstantNode(node) ||\n        isFunctionNode(node) ||\n        isObjectNode(node) ||\n        isParenthesisNode(node) ||\n        isSymbolNode(node))\n  }\n\n  class AccessorNode extends Node {\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    constructor (object, index) {\n      super()\n      if (!isNode(object)) {\n        throw new TypeError('Node expected for parameter \"object\"')\n      }\n      if (!isIndexNode(index)) {\n        throw new TypeError('IndexNode expected for parameter \"index\"')\n      }\n\n      this.object = object\n      this.index = index\n    }\n\n    // readonly property name\n    get name () {\n      if (this.index) {\n        return (this.index.isObjectProperty())\n          ? this.index.getObjectProperty()\n          : ''\n      } else {\n        return this.object.name || ''\n      }\n    }\n\n    static name = name\n    get type () { return name }\n    get isAccessorNode () { return true }\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    _compile (math, argNames) {\n      const evalObject = this.object._compile(math, argNames)\n      const evalIndex = this.index._compile(math, argNames)\n\n      if (this.index.isObjectProperty()) {\n        const prop = this.index.getObjectProperty()\n        return function evalAccessorNode (scope, args, context) {\n          // get a property from an object evaluated using the scope.\n          return getSafeProperty(evalObject(scope, args, context), prop)\n        }\n      } else {\n        return function evalAccessorNode (scope, args, context) {\n          const object = evalObject(scope, args, context)\n          // we pass just object here instead of context:\n          const index = evalIndex(scope, args, object)\n          return access(object, index)\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    forEach (callback) {\n      callback(this.object, 'object', this)\n      callback(this.index, 'index', this)\n    }\n\n    /**\n     * Create a new AccessorNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      return new AccessorNode(\n        this._ifNode(callback(this.object, 'object', this)),\n        this._ifNode(callback(this.index, 'index', this))\n      )\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {AccessorNode}\n     */\n    clone () {\n      return new AccessorNode(this.object, this.index)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toString (options) {\n      let object = this.object.toString(options)\n      if (needParenthesis(this.object)) {\n        object = '(' + object + ')'\n      }\n\n      return object + this.index.toString(options)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toHTML (options) {\n      let object = this.object.toHTML(options)\n      if (needParenthesis(this.object)) {\n        object =\n          '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          object +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n\n      return object + this.index.toHTML(options)\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toTex (options) {\n      let object = this.object.toTex(options)\n      if (needParenthesis(this.object)) {\n        object = '\\\\left(\\' + object + \\'\\\\right)'\n      }\n\n      return object + this.index.toTex(options)\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        object: this.object,\n        index: this.index\n      }\n    }\n\n    /**\n     * Instantiate an AccessorNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"AccessorNode\", object: ..., index: ...}`,\n     *     where mathjs is optional\n     * @returns {AccessorNode}\n     */\n    static fromJSON (json) {\n      return new AccessorNode(json.object, json.index)\n    }\n  }\n\n  return AccessorNode\n}, { isClass: true, isNode: true })\n","import { isArrayNode, isNode } from '../../utils/is.js'\nimport { map } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ArrayNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createArrayNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  class ArrayNode extends Node {\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    constructor (items) {\n      super()\n      this.items = items || []\n\n      // validate input\n      if (!Array.isArray(this.items) || !this.items.every(isNode)) {\n        throw new TypeError('Array containing Nodes expected')\n      }\n    }\n\n    static name = name\n    get type () { return name }\n    get isArrayNode () { return true }\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    _compile (math, argNames) {\n      const evalItems = map(this.items, function (item) {\n        return item._compile(math, argNames)\n      })\n\n      const asMatrix = (math.config.matrix !== 'Array')\n      if (asMatrix) {\n        const matrix = math.matrix\n        return function evalArrayNode (scope, args, context) {\n          return matrix(map(evalItems, function (evalItem) {\n            return evalItem(scope, args, context)\n          }))\n        }\n      } else {\n        return function evalArrayNode (scope, args, context) {\n          return map(evalItems, function (evalItem) {\n            return evalItem(scope, args, context)\n          })\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    forEach (callback) {\n      for (let i = 0; i < this.items.length; i++) {\n        const node = this.items[i]\n        callback(node, 'items[' + i + ']', this)\n      }\n    }\n\n    /**\n     * Create a new ArrayNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const items = []\n      for (let i = 0; i < this.items.length; i++) {\n        items[i] = this._ifNode(callback(this.items[i], 'items[' + i + ']', this))\n      }\n      return new ArrayNode(items)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {ArrayNode}\n     */\n    clone () {\n      return new ArrayNode(this.items.slice(0))\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toString (options) {\n      const items = this.items.map(function (node) {\n        return node.toString(options)\n      })\n      return '[' + items.join(', ') + ']'\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        items: this.items\n      }\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    static fromJSON (json) {\n      return new ArrayNode(json.items)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toHTML (options) {\n      const items = this.items.map(function (node) {\n        return node.toHTML(options)\n      })\n      return '<span class=\"math-parenthesis math-square-parenthesis\">[</span>' +\n        items.join('<span class=\"math-separator\">,</span>') +\n        '<span class=\"math-parenthesis math-square-parenthesis\">]</span>'\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      function itemsToTex (items, nested) {\n        const mixedItems = items.some(isArrayNode) && !items.every(isArrayNode)\n        const itemsFormRow = nested || mixedItems\n        const itemSep = itemsFormRow ? '&' : '\\\\\\\\'\n        const itemsTex = items\n          .map(function (node) {\n            if (node.items) {\n              return itemsToTex(node.items, !nested)\n            } else {\n              return node.toTex(options)\n            }\n          })\n          .join(itemSep)\n        return mixedItems || !itemsFormRow || (itemsFormRow && !nested)\n          ? '\\\\begin{bmatrix}' + itemsTex + '\\\\end{bmatrix}'\n          : itemsTex\n      }\n      return itemsToTex(this.items, false)\n    }\n  }\n\n  return ArrayNode\n}, { isClass: true, isNode: true })\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\nimport { hasOwnProperty } from '../utils/object.js'\nimport { isConstantNode, isParenthesisNode, rule2Node } from '../utils/is.js'\n\nexport const properties = [\n  { // assignment\n    AssignmentNode: {},\n    FunctionAssignmentNode: {}\n  },\n  { // conditional expression\n    ConditionalNode: {\n      latexLeftParens: false,\n      latexRightParens: false,\n      latexParens: false\n      // conditionals don't need parentheses in LaTeX because\n      // they are 2 dimensional\n    }\n  },\n  { // logical or\n    'OperatorNode:or': {\n      op: 'or',\n      associativity: 'left',\n      associativeWith: []\n    }\n\n  },\n  { // logical xor\n    'OperatorNode:xor': {\n      op: 'xor',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // logical and\n    'OperatorNode:and': {\n      op: 'and',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // bitwise or\n    'OperatorNode:bitOr': {\n      op: '|',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // bitwise xor\n    'OperatorNode:bitXor': {\n      op: '^|',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // bitwise and\n    'OperatorNode:bitAnd': {\n      op: '&',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // relational operators\n    'OperatorNode:equal': {\n      op: '==',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:unequal': {\n      op: '!=',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:smaller': {\n      op: '<',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:larger': {\n      op: '>',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:smallerEq': {\n      op: '<=',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:largerEq': {\n      op: '>=',\n      associativity: 'left',\n      associativeWith: []\n    },\n    RelationalNode: {\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // bitshift operators\n    'OperatorNode:leftShift': {\n      op: '<<',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:rightArithShift': {\n      op: '>>',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:rightLogShift': {\n      op: '>>>',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // unit conversion\n    'OperatorNode:to': {\n      op: 'to',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // range\n    RangeNode: {}\n  },\n  { // addition, subtraction\n    'OperatorNode:add': {\n      op: '+',\n      associativity: 'left',\n      associativeWith: ['OperatorNode:add', 'OperatorNode:subtract']\n    },\n    'OperatorNode:subtract': {\n      op: '-',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // multiply, divide, modulus\n    'OperatorNode:multiply': {\n      op: '*',\n      associativity: 'left',\n      associativeWith: [\n        'OperatorNode:multiply',\n        'OperatorNode:divide',\n        'Operator:dotMultiply',\n        'Operator:dotDivide'\n      ]\n    },\n    'OperatorNode:divide': {\n      op: '/',\n      associativity: 'left',\n      associativeWith: [],\n      latexLeftParens: false,\n      latexRightParens: false,\n      latexParens: false\n      // fractions don't require parentheses because\n      // they're 2 dimensional, so parens aren't needed\n      // in LaTeX\n    },\n    'OperatorNode:dotMultiply': {\n      op: '.*',\n      associativity: 'left',\n      associativeWith: [\n        'OperatorNode:multiply',\n        'OperatorNode:divide',\n        'OperatorNode:dotMultiply',\n        'OperatorNode:doDivide'\n      ]\n    },\n    'OperatorNode:dotDivide': {\n      op: './',\n      associativity: 'left',\n      associativeWith: []\n    },\n    'OperatorNode:mod': {\n      op: 'mod',\n      associativity: 'left',\n      associativeWith: []\n    }\n  },\n  { // Repeat multiplication for implicit multiplication\n    'OperatorNode:multiply': {\n      associativity: 'left',\n      associativeWith: [\n        'OperatorNode:multiply',\n        'OperatorNode:divide',\n        'Operator:dotMultiply',\n        'Operator:dotDivide'\n      ]\n    }\n  },\n  { // unary prefix operators\n    'OperatorNode:unaryPlus': {\n      op: '+',\n      associativity: 'right'\n    },\n    'OperatorNode:unaryMinus': {\n      op: '-',\n      associativity: 'right'\n    },\n    'OperatorNode:bitNot': {\n      op: '~',\n      associativity: 'right'\n    },\n    'OperatorNode:not': {\n      op: 'not',\n      associativity: 'right'\n    }\n  },\n  { // exponentiation\n    'OperatorNode:pow': {\n      op: '^',\n      associativity: 'right',\n      associativeWith: [],\n      latexRightParens: false\n      // the exponent doesn't need parentheses in\n      // LaTeX because it's 2 dimensional\n      // (it's on top)\n    },\n    'OperatorNode:dotPow': {\n      op: '.^',\n      associativity: 'right',\n      associativeWith: []\n    }\n  },\n  { // factorial\n    'OperatorNode:factorial': {\n      op: '!',\n      associativity: 'left'\n    }\n  },\n  { // matrix transpose\n    'OperatorNode:ctranspose': {\n      op: \"'\",\n      associativity: 'left'\n    }\n  }\n]\n\n/**\n * Returns the first non-parenthesis internal node, but only\n * when the 'parenthesis' option is unset or auto.\n * @param {Node} _node\n * @param {string} parenthesis\n * @return {Node}\n */\nfunction unwrapParen (_node, parenthesis) {\n  if (!parenthesis || parenthesis !== 'auto') return _node\n  let node = _node\n  while (isParenthesisNode(node)) node = node.content\n  return node\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 * @param {string} implicit\n * @param {Node} parent (for determining context for implicit multiplication)\n * @return {number | null}\n */\nexport function getPrecedence (_node, parenthesis, implicit, parent) {\n  let node = _node\n  if (parenthesis !== 'keep') {\n    // ParenthesisNodes are only ignored when not in 'keep' mode\n    node = _node.getContent()\n  }\n  const identifier = node.getIdentifier()\n  let precedence = null\n  for (let i = 0; i < properties.length; i++) {\n    if (identifier in properties[i]) {\n      precedence = i\n      break\n    }\n  }\n  // Bump up precedence of implicit multiplication, except when preceded\n  // by a \"Rule 2\" fraction ( [unaryOp]constant / constant )\n  if (identifier === 'OperatorNode:multiply' && node.implicit &&\n      implicit !== 'show') {\n    const leftArg = unwrapParen(node.args[0], parenthesis)\n    if (!(isConstantNode(leftArg) && parent &&\n          parent.getIdentifier() === 'OperatorNode:divide' &&\n          rule2Node(unwrapParen(parent.args[0], parenthesis))) &&\n        !(leftArg.getIdentifier() === 'OperatorNode:divide' &&\n          rule2Node(unwrapParen(leftArg.args[0], parenthesis)) &&\n          isConstantNode(unwrapParen(leftArg.args[1])))\n    ) {\n      precedence += 1\n    }\n  }\n  return precedence\n}\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 */\nexport function getAssociativity (_node, parenthesis) {\n  let node = _node\n  if (parenthesis !== 'keep') {\n    // ParenthesisNodes are only ignored when not in 'keep' mode\n    node = _node.getContent()\n  }\n  const identifier = node.getIdentifier()\n  const index = getPrecedence(node, parenthesis)\n  if (index === null) {\n    // node isn't in the list\n    return null\n  }\n  const property = properties[index][identifier]\n\n  if (hasOwnProperty(property, 'associativity')) {\n    if (property.associativity === 'left') {\n      return 'left'\n    }\n    if (property.associativity === 'right') {\n      return 'right'\n    }\n    // associativity is invalid\n    throw Error('\\'' + identifier + '\\' has the invalid associativity \\'' +\n                property.associativity + '\\'.')\n  }\n\n  // associativity is undefined\n  return null\n}\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 */\nexport function isAssociativeWith (nodeA, nodeB, parenthesis) {\n  // ParenthesisNodes are only ignored when not in 'keep' mode\n  const a = (parenthesis !== 'keep') ? nodeA.getContent() : nodeA\n  const b = (parenthesis !== 'keep') ? nodeA.getContent() : nodeB\n  const identifierA = a.getIdentifier()\n  const identifierB = b.getIdentifier()\n  const index = getPrecedence(a, parenthesis)\n  if (index === null) {\n    // node isn't in the list\n    return null\n  }\n  const property = properties[index][identifierA]\n\n  if (hasOwnProperty(property, 'associativeWith') &&\n      (property.associativeWith instanceof Array)) {\n    for (let i = 0; i < property.associativeWith.length; i++) {\n      if (property.associativeWith[i] === identifierB) {\n        return true\n      }\n    }\n    return false\n  }\n\n  // associativeWith is not defined\n  return null\n}\n\n/**\n * Get the operator associated with a function name.\n * Returns a string with the operator symbol, or null if the\n * input is not the name of a function associated with an\n * operator.\n *\n * @param {string} Function name\n * @return {string | null} Associated operator symbol, if any\n */\nexport function getOperator (fn) {\n  const identifier = 'OperatorNode:' + fn\n  for (const group of properties) {\n    if (identifier in group) {\n      return group[identifier].op\n    }\n  }\n  return null\n}\n","import { isAccessorNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'\nimport { getSafeProperty, setSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { accessFactory } from './utils/access.js'\nimport { assignFactory } from './utils/assign.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'AssignmentNode'\nconst dependencies = [\n  'subset',\n  '?matrix', // FIXME: should not be needed at all, should be handled by subset\n  'Node'\n]\n\nexport const createAssignmentNode = /* #__PURE__ */ factory(name, dependencies, ({ subset, matrix, Node }) => {\n  const access = accessFactory({ subset })\n  const assign = assignFactory({ subset, matrix })\n\n  /*\n   * Is parenthesis needed?\n   * @param {node} node\n   * @param {string} [parenthesis='keep']\n   * @param {string} implicit\n   * @private\n   */\n  function needParenthesis (node, parenthesis, implicit) {\n    if (!parenthesis) {\n      parenthesis = 'keep'\n    }\n\n    const precedence = getPrecedence(node, parenthesis, implicit)\n    const exprPrecedence = getPrecedence(node.value, parenthesis, implicit)\n    return (parenthesis === 'all') ||\n      ((exprPrecedence !== null) && (exprPrecedence <= precedence))\n  }\n\n  class AssignmentNode extends Node {\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'),\n     *                       new IndexNode('b'),\n     *                       new ConstantNode(2))   // a.b=2\n     *    new AssignmentNode(new SymbolNode('a'),\n     *                       new IndexNode(1, 2),\n     *                       new ConstantNode(3))  // a[1,2]=3\n     *\n     * @param {SymbolNode | AccessorNode} object\n     *     Object on which to assign a value\n     * @param {IndexNode} [index=null]\n     *     Index, property name or matrix index. Optional. If not provided\n     *     and `object` is a SymbolNode, the property is assigned to the\n     *     global scope.\n     * @param {Node} value\n     *     The value to be assigned\n     */\n    constructor (object, index, value) {\n      super()\n      this.object = object\n      this.index = value ? index : null\n      this.value = value || index\n\n      // validate input\n      if (!isSymbolNode(object) && !isAccessorNode(object)) {\n        throw new TypeError('SymbolNode or AccessorNode expected as \"object\"')\n      }\n      if (isSymbolNode(object) && object.name === 'end') {\n        throw new Error('Cannot assign to symbol \"end\"')\n      }\n      if (this.index && !isIndexNode(this.index)) { // index is optional\n        throw new TypeError('IndexNode expected as \"index\"')\n      }\n      if (!isNode(this.value)) {\n        throw new TypeError('Node expected as \"value\"')\n      }\n    }\n\n    // class name for typing purposes:\n    static name = name\n\n    // readonly property name\n    get name () {\n      if (this.index) {\n        return (this.index.isObjectProperty())\n          ? this.index.getObjectProperty()\n          : ''\n      } else {\n        return this.object.name || ''\n      }\n    }\n\n    get type () { return name }\n    get isAssignmentNode () { return true }\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    _compile (math, argNames) {\n      const evalObject = this.object._compile(math, argNames)\n      const evalIndex = this.index ? this.index._compile(math, argNames) : null\n      const evalValue = this.value._compile(math, argNames)\n      const name = this.object.name\n\n      if (!this.index) {\n        // apply a variable to the scope, for example `a=2`\n        if (!isSymbolNode(this.object)) {\n          throw new TypeError('SymbolNode expected as object')\n        }\n\n        return function evalAssignmentNode (scope, args, context) {\n          const 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        const prop = this.index.getObjectProperty()\n\n        return function evalAssignmentNode (scope, args, context) {\n          const object = evalObject(scope, args, context)\n          const value = evalValue(scope, args, context)\n          setSafeProperty(object, prop, value)\n          return value\n        }\n      } else if (isSymbolNode(this.object)) {\n        // update a matrix subset, for example `a[2]=3`\n        return function evalAssignmentNode (scope, args, context) {\n          const childObject = evalObject(scope, args, context)\n          const value = evalValue(scope, args, context)\n          // Important:  we pass childObject instead of context:\n          const index = evalIndex(scope, args, childObject)\n          scope.set(name, assign(childObject, index, value))\n          return value\n        }\n      } else { // isAccessorNode(node.object) === true\n        // update a matrix subset, for example `a.b[2]=3`\n\n        // we will not use the compile function of the AccessorNode, but\n        // compile it ourselves here as we need the parent object of the\n        // AccessorNode:\n        // wee need to apply the updated object to parent object\n        const evalParentObject = this.object.object._compile(math, argNames)\n\n        if (this.object.index.isObjectProperty()) {\n          const parentProp = this.object.index.getObjectProperty()\n\n          return function evalAssignmentNode (scope, args, context) {\n            const parent = evalParentObject(scope, args, context)\n            const childObject = getSafeProperty(parent, parentProp)\n            // Important: we pass childObject instead of context:\n            const index = evalIndex(scope, args, childObject)\n            const value = evalValue(scope, args, context)\n            setSafeProperty(\n              parent, parentProp, assign(childObject, index, value))\n            return value\n          }\n        } else {\n          // if some parameters use the 'end' parameter, we need to calculate\n          // the size\n          const evalParentIndex = this.object.index._compile(math, argNames)\n\n          return function evalAssignmentNode (scope, args, context) {\n            const parent = evalParentObject(scope, args, context)\n            // Important: we pass parent instead of context:\n            const parentIndex = evalParentIndex(scope, args, parent)\n            const childObject = access(parent, parentIndex)\n            // Important:  we pass childObject instead of context\n            const index = evalIndex(scope, args, childObject)\n            const value = evalValue(scope, args, context)\n\n            assign(parent, parentIndex, assign(childObject, index, value))\n\n            return value\n          }\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    forEach (callback) {\n      callback(this.object, 'object', this)\n      if (this.index) {\n        callback(this.index, 'index', this)\n      }\n      callback(this.value, 'value', this)\n    }\n\n    /**\n     * Create a new AssignmentNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const object = this._ifNode(callback(this.object, 'object', this))\n      const index = this.index\n        ? this._ifNode(callback(this.index, 'index', this))\n        : null\n      const value = this._ifNode(callback(this.value, 'value', this))\n\n      return new AssignmentNode(object, index, value)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {AssignmentNode}\n     */\n    clone () {\n      return new AssignmentNode(this.object, this.index, this.value)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toString (options) {\n      const object = this.object.toString(options)\n      const index = this.index ? this.index.toString(options) : ''\n      let value = this.value.toString(options)\n      if (needParenthesis(\n        this, options && options.parenthesis, options && options.implicit)) {\n        value = '(' + value + ')'\n      }\n\n      return object + index + ' = ' + value\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        object: this.object,\n        index: this.index,\n        value: this.value\n      }\n    }\n\n    /**\n     * Instantiate an AssignmentNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"AssignmentNode\", object: ..., index: ..., value: ...}`,\n     *     where mathjs is optional\n     * @returns {AssignmentNode}\n     */\n    static fromJSON (json) {\n      return new AssignmentNode(json.object, json.index, json.value)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toHTML (options) {\n      const object = this.object.toHTML(options)\n      const index = this.index ? this.index.toHTML(options) : ''\n      let value = this.value.toHTML(options)\n      if (needParenthesis(\n        this, options && options.parenthesis, options && options.implicit)) {\n        value = '<span class=\"math-paranthesis math-round-parenthesis\">(</span>' +\n          value +\n          '<span class=\"math-paranthesis math-round-parenthesis\">)</span>'\n      }\n\n      return object + index +\n        '<span class=\"math-operator math-assignment-operator ' +\n        'math-variable-assignment-operator math-binary-operator\">=</span>' +\n        value\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string}\n     */\n    _toTex (options) {\n      const object = this.object.toTex(options)\n      const index = this.index ? this.index.toTex(options) : ''\n      let value = this.value.toTex(options)\n      if (needParenthesis(\n        this, options && options.parenthesis, options && options.implicit)) {\n        value = `\\\\left(${value}\\\\right)`\n      }\n\n      return object + index + '=' + value\n    }\n  }\n\n  return AssignmentNode\n}, { isClass: true, isNode: true })\n","import { errorTransform } from '../../transform/utils/errorTransform.js'\nimport { setSafeProperty } from '../../../utils/customs.js'\n\nexport function assignFactory ({ subset, matrix }) {\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        const result = matrix(object).subset(index, value).valueOf()\n\n        // shallow copy all (updated) items into the original array\n        result.forEach((item, index) => {\n          object[index] = item\n        })\n\n        return object\n      } else if (object && typeof object.subset === 'function') { // 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 (typeof object === 'object') {\n        if (!index.isObjectProperty()) {\n          throw TypeError('Cannot apply a numeric index as object property')\n        }\n        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 errorTransform(err)\n    }\n  }\n}\n","import { isNode } from '../../utils/is.js'\nimport { forEach, map } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'BlockNode'\nconst dependencies = [\n  'ResultSet',\n  'Node'\n]\n\nexport const createBlockNode = /* #__PURE__ */ factory(name, dependencies, ({ ResultSet, Node }) => {\n  class BlockNode extends Node {\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\n     *            Object with properties block, which is a Node, and visible,\n     *            which is a boolean. The property visible is optional and\n     *            is true by default\n     */\n    constructor (blocks) {\n      super()\n      // validate input, copy blocks\n      if (!Array.isArray(blocks)) throw new Error('Array expected')\n      this.blocks = blocks.map(function (block) {\n        const node = block && block.node\n        const visible = block &&\n              block.visible !== undefined\n          ? block.visible\n          : true\n\n        if (!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\n        return { node, visible }\n      })\n    }\n\n    static name = name\n    get type () { return name }\n    get isBlockNode () { return true }\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    _compile (math, argNames) {\n      const evalBlocks = map(this.blocks, function (block) {\n        return {\n          evaluate: block.node._compile(math, argNames),\n          visible: block.visible\n        }\n      })\n\n      return function evalBlockNodes (scope, args, context) {\n        const results = []\n\n        forEach(evalBlocks, function evalBlockNode (block) {\n          const result = block.evaluate(scope, args, context)\n          if (block.visible) {\n            results.push(result)\n          }\n        })\n\n        return new ResultSet(results)\n      }\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    forEach (callback) {\n      for (let i = 0; i < this.blocks.length; i++) {\n        callback(this.blocks[i].node, 'blocks[' + i + '].node', this)\n      }\n    }\n\n    /**\n     * Create a new BlockNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const blocks = []\n      for (let i = 0; i < this.blocks.length; i++) {\n        const block = this.blocks[i]\n        const node = this._ifNode(\n          callback(block.node, 'blocks[' + i + '].node', this))\n        blocks[i] = {\n          node,\n          visible: block.visible\n        }\n      }\n      return new BlockNode(blocks)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {BlockNode}\n     */\n    clone () {\n      const blocks = this.blocks.map(function (block) {\n        return {\n          node: block.node,\n          visible: block.visible\n        }\n      })\n\n      return new BlockNode(blocks)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toString (options) {\n      return this.blocks.map(function (param) {\n        return param.node.toString(options) + (param.visible ? '' : ';')\n      }).join('\\n')\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        blocks: this.blocks\n      }\n    }\n\n    /**\n     * Instantiate an BlockNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"BlockNode\", blocks: [{node: ..., visible: false}, ...]}`,\n     *     where mathjs is optional\n     * @returns {BlockNode}\n     */\n    static fromJSON (json) {\n      return new BlockNode(json.blocks)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toHTML (options) {\n      return this.blocks.map(function (param) {\n        return param.node.toHTML(options) +\n          (param.visible ? '' : '<span class=\"math-separator\">;</span>')\n      }).join('<span class=\"math-separator\"><br /></span>')\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      return this.blocks.map(function (param) {\n        return param.node.toTex(options) + (param.visible ? '' : ';')\n      }).join('\\\\;\\\\;\\n')\n    }\n  }\n\n  return BlockNode\n}, { isClass: true, isNode: true })\n","import { isBigNumber, isComplex, isNode, isUnit, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'ConditionalNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createConditionalNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\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  function testCondition (condition) {\n    if (typeof condition === 'number' ||\n        typeof condition === 'boolean' ||\n        typeof condition === 'string') {\n      return !!condition\n    }\n\n    if (condition) {\n      if (isBigNumber(condition)) {\n        return !condition.isZero()\n      }\n\n      if (isComplex(condition)) {\n        return !!((condition.re || condition.im))\n      }\n\n      if (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 \"' + typeOf(condition) + '\"')\n  }\n\n  class ConditionalNode extends Node {\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    constructor (condition, trueExpr, falseExpr) {\n      super()\n      if (!isNode(condition)) { throw new TypeError('Parameter condition must be a Node') }\n      if (!isNode(trueExpr)) { throw new TypeError('Parameter trueExpr must be a Node') }\n      if (!isNode(falseExpr)) { throw new TypeError('Parameter falseExpr must be a Node') }\n\n      this.condition = condition\n      this.trueExpr = trueExpr\n      this.falseExpr = falseExpr\n    }\n\n    static name = name\n    get type () { return name }\n    get isConditionalNode () { return true }\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    _compile (math, argNames) {\n      const evalCondition = this.condition._compile(math, argNames)\n      const evalTrueExpr = this.trueExpr._compile(math, argNames)\n      const evalFalseExpr = this.falseExpr._compile(math, argNames)\n\n      return function evalConditionalNode (scope, args, context) {\n        return testCondition(evalCondition(scope, args, context))\n          ? evalTrueExpr(scope, args, context)\n          : evalFalseExpr(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    forEach (callback) {\n      callback(this.condition, 'condition', this)\n      callback(this.trueExpr, 'trueExpr', this)\n      callback(this.falseExpr, 'falseExpr', this)\n    }\n\n    /**\n     * Create a new ConditionalNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      return new ConditionalNode(\n        this._ifNode(callback(this.condition, 'condition', this)),\n        this._ifNode(callback(this.trueExpr, 'trueExpr', this)),\n        this._ifNode(callback(this.falseExpr, 'falseExpr', this))\n      )\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {ConditionalNode}\n     */\n    clone () {\n      return new ConditionalNode(this.condition, this.trueExpr, this.falseExpr)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const precedence =\n          getPrecedence(this, parenthesis, options && options.implicit)\n\n      // 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      let condition = this.condition.toString(options)\n      const conditionPrecedence =\n          getPrecedence(this.condition, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.condition.type === 'OperatorNode') ||\n          ((conditionPrecedence !== null) &&\n              (conditionPrecedence <= precedence))) {\n        condition = '(' + condition + ')'\n      }\n\n      let trueExpr = this.trueExpr.toString(options)\n      const truePrecedence =\n          getPrecedence(this.trueExpr, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.trueExpr.type === 'OperatorNode') ||\n          ((truePrecedence !== null) && (truePrecedence <= precedence))) {\n        trueExpr = '(' + trueExpr + ')'\n      }\n\n      let falseExpr = this.falseExpr.toString(options)\n      const falsePrecedence =\n          getPrecedence(this.falseExpr, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.falseExpr.type === 'OperatorNode') ||\n          ((falsePrecedence !== null) && (falsePrecedence <= precedence))) {\n        falseExpr = '(' + falseExpr + ')'\n      }\n      return condition + ' ? ' + trueExpr + ' : ' + falseExpr\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        condition: this.condition,\n        trueExpr: this.trueExpr,\n        falseExpr: this.falseExpr\n      }\n    }\n\n    /**\n     * Instantiate an ConditionalNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     ```\n     *     {\"mathjs\": \"ConditionalNode\",\n     *      \"condition\": ...,\n     *      \"trueExpr\": ...,\n     *      \"falseExpr\": ...}\n     *     ```\n     *     where mathjs is optional\n     * @returns {ConditionalNode}\n     */\n    static fromJSON (json) {\n      return new ConditionalNode(json.condition, json.trueExpr, json.falseExpr)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const precedence =\n          getPrecedence(this, parenthesis, options && options.implicit)\n\n      // 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      let condition = this.condition.toHTML(options)\n      const conditionPrecedence =\n          getPrecedence(this.condition, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.condition.type === 'OperatorNode') ||\n          ((conditionPrecedence !== null) &&\n              (conditionPrecedence <= precedence))) {\n        condition =\n          '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          condition +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n\n      let trueExpr = this.trueExpr.toHTML(options)\n      const truePrecedence =\n          getPrecedence(this.trueExpr, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.trueExpr.type === 'OperatorNode') ||\n          ((truePrecedence !== null) && (truePrecedence <= precedence))) {\n        trueExpr =\n          '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          trueExpr +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n\n      let falseExpr = this.falseExpr.toHTML(options)\n      const falsePrecedence =\n          getPrecedence(this.falseExpr, parenthesis, options && options.implicit)\n      if ((parenthesis === 'all') ||\n          (this.falseExpr.type === 'OperatorNode') ||\n          ((falsePrecedence !== null) && (falsePrecedence <= precedence))) {\n        falseExpr =\n          '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          falseExpr +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n      return condition +\n        '<span class=\"math-operator math-conditional-operator\">?</span>' +\n        trueExpr +\n        '<span class=\"math-operator math-conditional-operator\">:</span>' +\n        falseExpr\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      return '\\\\begin{cases} {' +\n        this.trueExpr.toTex(options) + '}, &\\\\quad{\\\\text{if }\\\\;' +\n        this.condition.toTex(options) +\n        '}\\\\\\\\{' + this.falseExpr.toTex(options) +\n        '}, &\\\\quad{\\\\text{otherwise}}\\\\end{cases}'\n    }\n  }\n\n  return ConditionalNode\n}, { isClass: true, isNode: true })\n","/* eslint no-template-curly-in-string: \"off\" */\n\nimport escapeLatexLib from 'escape-latex'\nimport { hasOwnProperty } from './object.js'\n\nexport const 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', // 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}\n\nexport const latexOperators = {\n  transpose: '^\\\\top',\n  ctranspose: '^H',\n  factorial: '!',\n  pow: '^',\n  dotPow: '.^\\\\wedge', // TODO find ideal solution\n  unaryPlus: '+',\n  unaryMinus: '-',\n  bitNot: '\\\\~', // TODO find ideal solution\n  not: '\\\\neg',\n  multiply: '\\\\cdot',\n  divide: '\\\\frac', // TODO how to handle that properly?\n  dotMultiply: '.\\\\cdot', // TODO find ideal solution\n  dotDivide: '.:', // 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}\n\nexport const latexFunctions = {\n  // arithmetic\n  abs: { 1: '\\\\left|${args[0]}\\\\right|' },\n  add: { 2: `\\\\left(\\${args[0]}${latexOperators.add}\\${args[1]}\\\\right)` },\n  cbrt: { 1: '\\\\sqrt[3]{${args[0]}}' },\n  ceil: { 1: '\\\\left\\\\lceil${args[0]}\\\\right\\\\rceil' },\n  cube: { 1: '\\\\left(${args[0]}\\\\right)^3' },\n  divide: { 2: '\\\\frac{${args[0]}}{${args[1]}}' },\n  dotDivide: { 2: `\\\\left(\\${args[0]}${latexOperators.dotDivide}\\${args[1]}\\\\right)` },\n  dotMultiply: { 2: `\\\\left(\\${args[0]}${latexOperators.dotMultiply}\\${args[1]}\\\\right)` },\n  dotPow: { 2: `\\\\left(\\${args[0]}${latexOperators.dotPow}\\${args[1]}\\\\right)` },\n  exp: { 1: '\\\\exp\\\\left(${args[0]}\\\\right)' },\n  expm1: `\\\\left(e${latexOperators.pow}{\\${args[0]}}-1\\\\right)`,\n  fix: { 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)' },\n  floor: { 1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rfloor' },\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: { 1: '\\\\log_{10}\\\\left(${args[0]}\\\\right)' },\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: { 2: `\\\\left(\\${args[0]}${latexOperators.mod}\\${args[1]}\\\\right)` },\n  multiply: { 2: `\\\\left(\\${args[0]}${latexOperators.multiply}\\${args[1]}\\\\right)` },\n  norm: {\n    1: '\\\\left\\\\|${args[0]}\\\\right\\\\|',\n    2: undefined // use default template\n  },\n  nthRoot: { 2: '\\\\sqrt[${args[1]}]{${args[0]}}' },\n  nthRoots: { 2: '\\\\{y : $y^{args[1]} = {${args[0]}}\\\\}' },\n  pow: { 2: `\\\\left(\\${args[0]}\\\\right)${latexOperators.pow}{\\${args[1]}}` },\n  round: {\n    1: '\\\\left\\\\lfloor${args[0]}\\\\right\\\\rceil',\n    2: undefined // use default template\n  },\n  sign: { 1: '\\\\mathrm{${name}}\\\\left(${args[0]}\\\\right)' },\n  sqrt: { 1: '\\\\sqrt{${args[0]}}' },\n  square: { 1: '\\\\left(${args[0]}\\\\right)^2' },\n  subtract: { 2: `\\\\left(\\${args[0]}${latexOperators.subtract}\\${args[1]}\\\\right)` },\n  unaryMinus: { 1: `${latexOperators.unaryMinus}\\\\left(\\${args[0]}\\\\right)` },\n  unaryPlus: { 1: `${latexOperators.unaryPlus}\\\\left(\\${args[0]}\\\\right)` },\n\n  // bitwise\n  bitAnd: { 2: `\\\\left(\\${args[0]}${latexOperators.bitAnd}\\${args[1]}\\\\right)` },\n  bitNot: { 1: latexOperators.bitNot + '\\\\left(${args[0]}\\\\right)' },\n  bitOr: { 2: `\\\\left(\\${args[0]}${latexOperators.bitOr}\\${args[1]}\\\\right)` },\n  bitXor: { 2: `\\\\left(\\${args[0]}${latexOperators.bitXor}\\${args[1]}\\\\right)` },\n  leftShift: { 2: `\\\\left(\\${args[0]}${latexOperators.leftShift}\\${args[1]}\\\\right)` },\n  rightArithShift: { 2: `\\\\left(\\${args[0]}${latexOperators.rightArithShift}\\${args[1]}\\\\right)` },\n  rightLogShift: { 2: `\\\\left(\\${args[0]}${latexOperators.rightLogShift}\\${args[1]}\\\\right)` },\n\n  // combinatorics\n  bellNumbers: { 1: '\\\\mathrm{B}_{${args[0]}}' },\n  catalan: { 1: '\\\\mathrm{C}_{${args[0]}}' },\n  stirlingS2: { 2: '\\\\mathrm{S}\\\\left(${args}\\\\right)' },\n\n  // complex\n  arg: { 1: '\\\\arg\\\\left(${args[0]}\\\\right)' },\n  conj: { 1: '\\\\left(${args[0]}\\\\right)^*' },\n  im: { 1: '\\\\Im\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace' },\n  re: { 1: '\\\\Re\\\\left\\\\lbrace${args[0]}\\\\right\\\\rbrace' },\n\n  // logical\n  and: { 2: `\\\\left(\\${args[0]}${latexOperators.and}\\${args[1]}\\\\right)` },\n  not: { 1: latexOperators.not + '\\\\left(${args[0]}\\\\right)' },\n  or: { 2: `\\\\left(\\${args[0]}${latexOperators.or}\\${args[1]}\\\\right)` },\n  xor: { 2: `\\\\left(\\${args[0]}${latexOperators.xor}\\${args[1]}\\\\right)` },\n\n  // matrix\n  cross: { 2: '\\\\left(${args[0]}\\\\right)\\\\times\\\\left(${args[1]}\\\\right)' },\n  ctranspose: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.ctranspose}` },\n  det: { 1: '\\\\det\\\\left(${args[0]}\\\\right)' },\n  dot: { 2: '\\\\left(${args[0]}\\\\cdot${args[1]}\\\\right)' },\n  expm: { 1: '\\\\exp\\\\left(${args[0]}\\\\right)' },\n  inv: { 1: '\\\\left(${args[0]}\\\\right)^{-1}' },\n  pinv: { 1: '\\\\left(${args[0]}\\\\right)^{+}' },\n  sqrtm: { 1: `{\\${args[0]}}${latexOperators.pow}{\\\\frac{1}{2}}` },\n  trace: { 1: '\\\\mathrm{tr}\\\\left(${args[0]}\\\\right)' },\n  transpose: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.transpose}` },\n\n  // probability\n  combinations: { 2: '\\\\binom{${args[0]}}{${args[1]}}' },\n  combinationsWithRep: { 2: '\\\\left(\\\\!\\\\!{\\\\binom{${args[0]}}{${args[1]}}}\\\\!\\\\!\\\\right)' },\n  factorial: { 1: `\\\\left(\\${args[0]}\\\\right)${latexOperators.factorial}` },\n  gamma: { 1: '\\\\Gamma\\\\left(${args[0]}\\\\right)' },\n  lgamma: { 1: '\\\\ln\\\\Gamma\\\\left(${args[0]}\\\\right)' },\n\n  // relational\n  equal: { 2: `\\\\left(\\${args[0]}${latexOperators.equal}\\${args[1]}\\\\right)` },\n  larger: { 2: `\\\\left(\\${args[0]}${latexOperators.larger}\\${args[1]}\\\\right)` },\n  largerEq: { 2: `\\\\left(\\${args[0]}${latexOperators.largerEq}\\${args[1]}\\\\right)` },\n  smaller: { 2: `\\\\left(\\${args[0]}${latexOperators.smaller}\\${args[1]}\\\\right)` },\n  smallerEq: { 2: `\\\\left(\\${args[0]}${latexOperators.smallerEq}\\${args[1]}\\\\right)` },\n  unequal: { 2: `\\\\left(\\${args[0]}${latexOperators.unequal}\\${args[1]}\\\\right)` },\n\n  // special\n  erf: { 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\n  // trigonometry\n  acos: { 1: '\\\\cos^{-1}\\\\left(${args[0]}\\\\right)' },\n  acosh: { 1: '\\\\cosh^{-1}\\\\left(${args[0]}\\\\right)' },\n  acot: { 1: '\\\\cot^{-1}\\\\left(${args[0]}\\\\right)' },\n  acoth: { 1: '\\\\coth^{-1}\\\\left(${args[0]}\\\\right)' },\n  acsc: { 1: '\\\\csc^{-1}\\\\left(${args[0]}\\\\right)' },\n  acsch: { 1: '\\\\mathrm{csch}^{-1}\\\\left(${args[0]}\\\\right)' },\n  asec: { 1: '\\\\sec^{-1}\\\\left(${args[0]}\\\\right)' },\n  asech: { 1: '\\\\mathrm{sech}^{-1}\\\\left(${args[0]}\\\\right)' },\n  asin: { 1: '\\\\sin^{-1}\\\\left(${args[0]}\\\\right)' },\n  asinh: { 1: '\\\\sinh^{-1}\\\\left(${args[0]}\\\\right)' },\n  atan: { 1: '\\\\tan^{-1}\\\\left(${args[0]}\\\\right)' },\n  atan2: { 2: '\\\\mathrm{atan2}\\\\left(${args}\\\\right)' },\n  atanh: { 1: '\\\\tanh^{-1}\\\\left(${args[0]}\\\\right)' },\n  cos: { 1: '\\\\cos\\\\left(${args[0]}\\\\right)' },\n  cosh: { 1: '\\\\cosh\\\\left(${args[0]}\\\\right)' },\n  cot: { 1: '\\\\cot\\\\left(${args[0]}\\\\right)' },\n  coth: { 1: '\\\\coth\\\\left(${args[0]}\\\\right)' },\n  csc: { 1: '\\\\csc\\\\left(${args[0]}\\\\right)' },\n  csch: { 1: '\\\\mathrm{csch}\\\\left(${args[0]}\\\\right)' },\n  sec: { 1: '\\\\sec\\\\left(${args[0]}\\\\right)' },\n  sech: { 1: '\\\\mathrm{sech}\\\\left(${args[0]}\\\\right)' },\n  sin: { 1: '\\\\sin\\\\left(${args[0]}\\\\right)' },\n  sinh: { 1: '\\\\sinh\\\\left(${args[0]}\\\\right)' },\n  tan: { 1: '\\\\tan\\\\left(${args[0]}\\\\right)' },\n  tanh: { 1: '\\\\tanh\\\\left(${args[0]}\\\\right)' },\n\n  // unit\n  to: { 2: `\\\\left(\\${args[0]}${latexOperators.to}\\${args[1]}\\\\right)` },\n\n  // utils\n  numeric: function (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\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  bigint: {\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)+${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\n}\n\nexport const defaultTemplate = '\\\\mathrm{${name}}\\\\left(${args}\\\\right)'\n\nconst latexUnits = {\n  deg: '^\\\\circ'\n}\n\nexport function escapeLatex (string) {\n  return escapeLatexLib(string, { preserveFormatting: true })\n}\n\n// @param {string} name\n// @param {boolean} isUnit\nexport function toSymbol (name, isUnit) {\n  isUnit = typeof isUnit === 'undefined' ? false : isUnit\n  if (isUnit) {\n    if (hasOwnProperty(latexUnits, name)) {\n      return latexUnits[name]\n    }\n\n    return '\\\\mathrm{' + escapeLatex(name) + '}'\n  }\n\n  if (hasOwnProperty(latexSymbols, name)) {\n    return latexSymbols[name]\n  }\n\n  return escapeLatex(name)\n}\n","import { format } from '../../utils/string.js'\nimport { typeOf } from '../../utils/is.js'\nimport { escapeLatex } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ConstantNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createConstantNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  class ConstantNode extends Node {\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, bigint, string, ...)\n     * @constructor ConstantNode\n     * @extends {Node}\n     */\n    constructor (value) {\n      super()\n      this.value = value\n    }\n\n    static name = name\n    get type () { return name }\n    get isConstantNode () { return true }\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    _compile (math, argNames) {\n      const value = this.value\n\n      return function evalConstantNode () {\n        return value\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    forEach (callback) {\n      // nothing to do, we don't have any children\n    }\n\n    /**\n     * Create a new ConstantNode with children produced by the given callback.\n     * Trivial because there are no children.\n     * @param {function(child: Node, path: string, parent: Node) : Node} callback\n     * @returns {ConstantNode} Returns a clone of the node\n     */\n    map (callback) {\n      return this.clone()\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {ConstantNode}\n     */\n    clone () {\n      return new ConstantNode(this.value)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      return format(this.value, options)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const value = this._toString(options)\n\n      switch (typeOf(this.value)) {\n        case 'number':\n        case 'bigint':\n        case 'BigNumber':\n        case 'Fraction':\n          return '<span class=\"math-number\">' + value + '</span>'\n        case 'string':\n          return '<span class=\"math-string\">' + value + '</span>'\n        case 'boolean':\n          return '<span class=\"math-boolean\">' + value + '</span>'\n        case 'null':\n          return '<span class=\"math-null-symbol\">' + value + '</span>'\n        case 'undefined':\n          return '<span class=\"math-undefined\">' + value + '</span>'\n\n        default:\n          return '<span class=\"math-symbol\">' + value + '</span>'\n      }\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return { mathjs: name, 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    static fromJSON (json) {\n      return new ConstantNode(json.value)\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const value = this._toString(options)\n      const type = typeOf(this.value)\n\n      switch (type) {\n        case 'string':\n          return '\\\\mathtt{' + escapeLatex(value) + '}'\n\n        case 'number':\n        case 'BigNumber': {\n          const finite = type === 'BigNumber' ? this.value.isFinite() : isFinite(this.value)\n          if (!finite) {\n            return (this.value.valueOf() < 0)\n              ? '-\\\\infty'\n              : '\\\\infty'\n          }\n\n          const index = value.toLowerCase().indexOf('e')\n          if (index !== -1) {\n            return value.substring(0, index) + '\\\\cdot10^{' +\n              value.substring(index + 1) + '}'\n          }\n\n          return value\n        }\n\n        case 'bigint': {\n          return value.toString()\n        }\n\n        case 'Fraction':\n          return this.value.toLatex()\n\n        default:\n          return value\n      }\n    }\n  }\n\n  return ConstantNode\n}, { isClass: true, isNode: true })\n","import { isNode } from '../../utils/is.js'\n\nimport { keywords } from '../keywords.js'\nimport { escape } from '../../utils/string.js'\nimport { forEach, join } from '../../utils/array.js'\nimport { toSymbol } from '../../utils/latex.js'\nimport { getPrecedence } from '../operators.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'FunctionAssignmentNode'\nconst dependencies = [\n  'typed',\n  'Node'\n]\n\nexport const createFunctionAssignmentNode = /* #__PURE__ */ factory(name, dependencies, ({ typed, Node }) => {\n  /**\n   * Is parenthesis needed?\n   * @param {Node} node\n   * @param {Object} parenthesis\n   * @param {string} implicit\n   * @private\n   */\n  function needParenthesis (node, parenthesis, implicit) {\n    const precedence = getPrecedence(node, parenthesis, implicit)\n    const exprPrecedence = getPrecedence(node.expr, parenthesis, implicit)\n\n    return (parenthesis === 'all') ||\n      ((exprPrecedence !== null) && (exprPrecedence <= precedence))\n  }\n\n  class FunctionAssignmentNode extends Node {\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    constructor (name, params, expr) {\n      super()\n      // validate input\n      if (typeof name !== 'string') { throw new TypeError('String expected for parameter \"name\"') }\n      if (!Array.isArray(params)) {\n        throw new TypeError(\n          'Array containing strings or objects expected for parameter \"params\"')\n      }\n      if (!isNode(expr)) { throw new TypeError('Node expected for parameter \"expr\"') }\n      if (keywords.has(name)) { throw new Error('Illegal function name, \"' + name + '\" is a reserved keyword') }\n\n      const paramNames = new Set()\n      for (const param of params) {\n        const name = typeof param === 'string' ? param : param.name\n        if (paramNames.has(name)) {\n          throw new Error(`Duplicate parameter name \"${name}\"`)\n        } else {\n          paramNames.add(name)\n        }\n      }\n\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    static name = name\n    get type () { return name }\n    get isFunctionAssignmentNode () { return true }\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    _compile (math, argNames) {\n      const childArgNames = Object.create(argNames)\n      forEach(this.params, function (param) {\n        childArgNames[param] = true\n      })\n\n      // compile the function expression with the child args\n      const evalExpr = this.expr._compile(math, childArgNames)\n      const name = this.name\n      const params = this.params\n      const signature = join(this.types, ',')\n      const syntax = name + '(' + join(this.params, ', ') + ')'\n\n      return function evalFunctionAssignmentNode (scope, args, context) {\n        const signatures = {}\n        signatures[signature] = function () {\n          const childArgs = Object.create(args)\n\n          for (let i = 0; i < params.length; i++) {\n            childArgs[params[i]] = arguments[i]\n          }\n\n          return evalExpr(scope, childArgs, context)\n        }\n        const fn = typed(name, signatures)\n        fn.syntax = syntax\n\n        scope.set(name, fn)\n\n        return fn\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    forEach (callback) {\n      callback(this.expr, 'expr', this)\n    }\n\n    /**\n     * Create a new FunctionAssignmentNode whose children are the results of\n     * calling the provided callback function for each child of the original\n     * node.\n     * @param {function(child: Node, path: string, parent: Node): Node} callback\n     * @returns {FunctionAssignmentNode} Returns a transformed copy of the node\n     */\n    map (callback) {\n      const expr = this._ifNode(callback(this.expr, 'expr', this))\n\n      return new FunctionAssignmentNode(this.name, this.params.slice(0), expr)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {FunctionAssignmentNode}\n     */\n    clone () {\n      return new FunctionAssignmentNode(\n        this.name, this.params.slice(0), this.expr)\n    }\n\n    /**\n     * get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      let expr = this.expr.toString(options)\n      if (needParenthesis(this, parenthesis, options && options.implicit)) {\n        expr = '(' + expr + ')'\n      }\n      return this.name + '(' + this.params.join(', ') + ') = ' + expr\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      const types = this.types\n\n      return {\n        mathjs: name,\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    /**\n     * Instantiate an FunctionAssignmentNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     ```\n     *     {\"mathjs\": \"FunctionAssignmentNode\",\n     *      name: ..., params: ..., expr: ...}\n     *     ```\n     *     where mathjs is optional\n     * @returns {FunctionAssignmentNode}\n     */\n    static fromJSON (json) {\n      return new FunctionAssignmentNode(json.name, json.params, json.expr)\n    }\n\n    /**\n     * get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const parenthesis = (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const params = []\n      for (let i = 0; i < this.params.length; i++) {\n        params.push('<span class=\"math-symbol math-parameter\">' +\n                    escape(this.params[i]) + '</span>')\n      }\n      let expr = this.expr.toHTML(options)\n      if (needParenthesis(this, parenthesis, options && options.implicit)) {\n        expr = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          expr +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n      return '<span class=\"math-function\">' +\n        escape(this.name) + '</span>' +\n        '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n        params.join('<span class=\"math-separator\">,</span>') +\n        '<span class=\"math-parenthesis math-round-parenthesis\">)</span>' +\n        '<span class=\"math-operator math-assignment-operator ' +\n        'math-variable-assignment-operator math-binary-operator\">=</span>' +\n        expr\n    }\n\n    /**\n     * get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      let expr = this.expr.toTex(options)\n      if (needParenthesis(this, parenthesis, options && options.implicit)) {\n        expr = `\\\\left(${expr}\\\\right)`\n      }\n\n      return '\\\\mathrm{' + this.name +\n        '}\\\\left(' + this.params.map(toSymbol).join(',') + '\\\\right)=' + expr\n    }\n  }\n\n  return FunctionAssignmentNode\n}, { isClass: true, isNode: true })\n","import { map } from '../../utils/array.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { isArray, isConstantNode, isMatrix, isNode, isString, typeOf } from '../../utils/is.js'\nimport { escape } from '../../utils/string.js'\n\nconst name = 'IndexNode'\nconst dependencies = [\n  'Node',\n  'size'\n]\n\nexport const createIndexNode = /* #__PURE__ */ factory(name, dependencies, ({ Node, size }) => {\n  class IndexNode extends Node {\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]\n     *     Optional property describing whether this index was written using dot\n     *     notation like `a.b`, or using bracket notation like `a[\"b\"]`\n     *     (which is the default). This property is used for string conversion.\n     */\n    constructor (dimensions, dotNotation) {\n      super()\n      this.dimensions = dimensions\n      this.dotNotation = dotNotation || false\n\n      // validate input\n      if (!Array.isArray(dimensions) || !dimensions.every(isNode)) {\n        throw new TypeError(\n          'Array containing Nodes expected for parameter \"dimensions\"')\n      }\n      if (this.dotNotation && !this.isObjectProperty()) {\n        throw new Error('dotNotation only applicable for object properties')\n      }\n    }\n\n    static name = name\n    get type () { return name }\n    get isIndexNode () { return true }\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    _compile (math, argNames) {\n      // TODO: implement support for bignumber (currently bignumbers are silently\n      //       reduced to numbers when changing the value to zero-based)\n\n      // TODO: Optimization: when the range values are ConstantNodes,\n      //       we can beforehand resolve the zero-based value\n\n      // optimization for a simple object property\n      const evalDimensions = map(this.dimensions, function (dimension, i) {\n        const needsEnd = dimension\n          .filter(node => 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          const childArgNames = Object.create(argNames)\n          childArgNames.end = true\n\n          const _evalDimension = dimension._compile(math, childArgNames)\n\n          return function evalDimension (scope, args, context) {\n            if (!isMatrix(context) && !isArray(context) && !isString(context)) {\n              throw new TypeError(\n                'Cannot resolve \"end\": ' +\n                  'context must be a Matrix, Array, or string but is ' +\n                  typeOf(context))\n            }\n\n            const s = size(context).valueOf()\n            const childArgs = Object.create(args)\n            childArgs.end = s[i]\n\n            return _evalDimension(scope, childArgs, context)\n          }\n        } else {\n          // SymbolNode `end` not used\n          return dimension._compile(math, argNames)\n        }\n      })\n\n      const index = getSafeProperty(math, 'index')\n\n      return function evalIndexNode (scope, args, context) {\n        const dimensions = map(evalDimensions, function (evalDimension) {\n          return evalDimension(scope, args, context)\n        })\n\n        return index(...dimensions)\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    forEach (callback) {\n      for (let i = 0; i < this.dimensions.length; i++) {\n        callback(this.dimensions[i], 'dimensions[' + i + ']', this)\n      }\n    }\n\n    /**\n     * Create a new IndexNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const dimensions = []\n      for (let i = 0; i < this.dimensions.length; i++) {\n        dimensions[i] = this._ifNode(\n          callback(this.dimensions[i], 'dimensions[' + i + ']', this))\n      }\n\n      return new IndexNode(dimensions, this.dotNotation)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {IndexNode}\n     */\n    clone () {\n      return new IndexNode(this.dimensions.slice(0), this.dotNotation)\n    }\n\n    /**\n     * Test whether this IndexNode contains a single property name\n     * @return {boolean}\n     */\n    isObjectProperty () {\n      return this.dimensions.length === 1 &&\n        isConstantNode(this.dimensions[0]) &&\n        typeof this.dimensions[0].value === 'string'\n    }\n\n    /**\n     * Returns the property name if IndexNode contains a property.\n     * If not, returns null.\n     * @return {string | null}\n     */\n    getObjectProperty () {\n      return this.isObjectProperty() ? this.dimensions[0].value : null\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      // format the parameters like \"[1, 0:5]\"\n      return this.dotNotation\n        ? ('.' + this.getObjectProperty())\n        : ('[' + this.dimensions.join(', ') + ']')\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        dimensions: this.dimensions,\n        dotNotation: this.dotNotation\n      }\n    }\n\n    /**\n     * Instantiate an IndexNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"IndexNode\", dimensions: [...], dotNotation: false}`,\n     *     where mathjs is optional\n     * @returns {IndexNode}\n     */\n    static fromJSON (json) {\n      return new IndexNode(json.dimensions, json.dotNotation)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      // format the parameters like \"[1, 0:5]\"\n      const dimensions = []\n      for (let i = 0; i < this.dimensions.length; i++) {\n        dimensions[i] = this.dimensions[i].toHTML()\n      }\n      if (this.dotNotation) {\n        return '<span class=\"math-operator math-accessor-operator\">.</span>' +\n          '<span class=\"math-symbol math-property\">' +\n          escape(this.getObjectProperty()) + '</span>'\n      } else {\n        return '<span class=\"math-parenthesis math-square-parenthesis\">[</span>' +\n          dimensions.join('<span class=\"math-separator\">,</span>') +\n          '<span class=\"math-parenthesis math-square-parenthesis\">]</span>'\n      }\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const dimensions = this.dimensions.map(function (range) {\n        return range.toTex(options)\n      })\n\n      return this.dotNotation\n        ? ('.' + this.getObjectProperty() + '')\n        : ('_{' + dimensions.join(',') + '}')\n    }\n  }\n\n  return IndexNode\n}, { isClass: true, isNode: true })\n","import { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { isNode } from '../../utils/is.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { escape, stringify } from '../../utils/string.js'\n\nconst name = 'ObjectNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createObjectNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  class ObjectNode extends Node {\n    /**\n     * @constructor ObjectNode\n     * @extends {Node}\n     * Holds an object with keys/values\n     * @param {Object.<string, Node>} [properties]   object with key/value pairs\n     */\n    constructor (properties) {\n      super()\n      this.properties = properties || {}\n\n      // validate input\n      if (properties) {\n        if (!(typeof properties === 'object') ||\n            !Object.keys(properties).every(function (key) {\n              return isNode(properties[key])\n            })) {\n          throw new TypeError('Object containing Nodes expected')\n        }\n      }\n    }\n\n    static name = name\n    get type () { return name }\n    get isObjectNode () { return true }\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    _compile (math, argNames) {\n      const evalEntries = {}\n\n      for (const key in this.properties) {\n        if (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          const stringifiedKey = stringify(key)\n          const parsedKey = JSON.parse(stringifiedKey)\n          const prop = getSafeProperty(this.properties, key)\n\n          evalEntries[parsedKey] = prop._compile(math, argNames)\n        }\n      }\n\n      return function evalObjectNode (scope, args, context) {\n        const obj = {}\n\n        for (const key in evalEntries) {\n          if (hasOwnProperty(evalEntries, key)) {\n            obj[key] = evalEntries[key](scope, args, context)\n          }\n        }\n\n        return obj\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    forEach (callback) {\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          callback(\n            this.properties[key], 'properties[' + stringify(key) + ']', this)\n        }\n      }\n    }\n\n    /**\n     * Create a new ObjectNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const properties = {}\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          properties[key] = this._ifNode(\n            callback(\n              this.properties[key], 'properties[' + stringify(key) + ']', this))\n        }\n      }\n      return new ObjectNode(properties)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {ObjectNode}\n     */\n    clone () {\n      const properties = {}\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          properties[key] = this.properties[key]\n        }\n      }\n      return new ObjectNode(properties)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toString (options) {\n      const entries = []\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          entries.push(\n            stringify(key) + ': ' + this.properties[key].toString(options))\n        }\n      }\n      return '{' + entries.join(', ') + '}'\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        properties: this.properties\n      }\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    static fromJSON (json) {\n      return new ObjectNode(json.properties)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toHTML (options) {\n      const entries = []\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          entries.push(\n            '<span class=\"math-symbol math-property\">' + escape(key) + '</span>' +\n              '<span class=\"math-operator math-assignment-operator ' +\n              'math-property-assignment-operator math-binary-operator\">' +\n              ':</span>' + this.properties[key].toHTML(options))\n        }\n      }\n      return '<span class=\"math-parenthesis math-curly-parenthesis\">{</span>' +\n        entries.join('<span class=\"math-separator\">,</span>') +\n        '<span class=\"math-parenthesis math-curly-parenthesis\">}</span>'\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const entries = []\n      for (const key in this.properties) {\n        if (hasOwnProperty(this.properties, key)) {\n          entries.push(\n            '\\\\mathbf{' + key + ':} & ' +\n              this.properties[key].toTex(options) + '\\\\\\\\')\n        }\n      }\n      const tex = '\\\\left\\\\{\\\\begin{array}{ll}' + entries.join('\\n') +\n          '\\\\end{array}\\\\right\\\\}'\n      return tex\n    }\n  }\n\n  return ObjectNode\n}, { isClass: true, isNode: true })\n","import { ObjectWrappingMap, PartitionedMap } from './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  {Object} args\n * @returns {PartitionedMap}\n */\nexport function createSubScope (parentScope, args) {\n  return new PartitionedMap(\n    parentScope,\n    new ObjectWrappingMap(args),\n    new Set(Object.keys(args))\n  )\n}\n","import { isNode, isConstantNode, isOperatorNode, isParenthesisNode } from '../../utils/is.js'\nimport { map } from '../../utils/array.js'\nimport { createSubScope } from '../../utils/scope.js'\nimport { escape } from '../../utils/string.js'\nimport { getSafeProperty, isSafeMethod } from '../../utils/customs.js'\nimport { getAssociativity, getPrecedence, isAssociativeWith, properties } from '../operators.js'\nimport { latexOperators } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'OperatorNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createOperatorNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  /**\n   * Returns true if the expression starts with a constant, under\n   * the current parenthesization:\n   * @param {Node} expression\n   * @param {string} parenthesis\n   * @return {boolean}\n   */\n  function startsWithConstant (expr, parenthesis) {\n    let curNode = expr\n    if (parenthesis === 'auto') {\n      while (isParenthesisNode(curNode)) curNode = curNode.content\n    }\n    if (isConstantNode(curNode)) return true\n    if (isOperatorNode(curNode)) {\n      return startsWithConstant(curNode.args[0], parenthesis)\n    }\n    return false\n  }\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  function calculateNecessaryParentheses (root, parenthesis, implicit, args, latex) {\n    // precedence of the root OperatorNode\n    const precedence = getPrecedence(root, parenthesis, implicit)\n    const associativity = 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) { // Nodes that don't need extra parentheses\n          case 'ArrayNode':\n          case 'ConstantNode':\n          case 'SymbolNode':\n          case 'ParenthesisNode':\n            return false\n          default:\n            return true\n        }\n      })\n    }\n\n    let result\n    switch (args.length) {\n      case 0:\n        result = []\n        break\n\n      case 1: // unary operators\n        {\n          // precedence of the operand\n          const operandPrecedence = getPrecedence(args[0], parenthesis, implicit, root)\n\n          // handle special cases for LaTeX, where some of the parentheses aren't needed\n          if (latex && (operandPrecedence !== null)) {\n            let operandIdentifier\n            let rootIdentifier\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            if (properties[precedence][rootIdentifier].latexLeftParens === false) {\n              result = [false]\n              break\n            }\n\n            if (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          }\n\n          // otherwise, no parens needed\n          result = [false]\n        }\n        break\n      case 2: // binary operators\n        {\n          let lhsParens // left hand side needs parenthesis?\n          // precedence of the left hand side\n          const lhsPrecedence = getPrecedence(args[0], parenthesis, implicit, root)\n          // is the root node associative with the left hand side\n          const assocWithLhs = 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          let rhsParens // right hand side needs parenthesis?\n          // precedence of the right hand side\n          const rhsPrecedence = getPrecedence(args[1], parenthesis, implicit, root)\n          // is the root node associative with the right hand side?\n          const assocWithRhs = 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          }\n\n          // handle special cases for LaTeX, where some of the parentheses aren't needed\n          if (latex) {\n            let rootIdentifier\n            let lhsIdentifier\n            let rhsIdentifier\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 (properties[precedence][rootIdentifier].latexLeftParens === false) {\n                lhsParens = false\n              }\n\n              if (properties[lhsPrecedence][lhsIdentifier].latexParens === false) {\n                lhsParens = false\n              }\n            }\n\n            if (rhsPrecedence !== null) {\n              if (properties[precedence][rootIdentifier].latexRightParens === false) {\n                rhsParens = false\n              }\n\n              if (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            const argPrecedence = getPrecedence(arg, parenthesis, implicit, root)\n            const assocWithArg = isAssociativeWith(root, arg, parenthesis)\n            const argAssociativity = getAssociativity(arg, parenthesis)\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        break\n    }\n\n    // Handles an edge case of parentheses with implicit multiplication\n    // of ConstantNode.\n    // In that case, parenthesize ConstantNodes that follow an unparenthesized\n    // expression, even though they normally wouldn't be printed.\n    if (args.length >= 2 && root.getIdentifier() === 'OperatorNode:multiply' &&\n        root.implicit && parenthesis !== 'all' && implicit === 'hide') {\n      for (let i = 1; i < result.length; ++i) {\n        if (startsWithConstant(args[i], parenthesis) && !result[i - 1] &&\n            (parenthesis !== 'keep' || !isParenthesisNode(args[i - 1]))) {\n          result[i] = true\n        }\n      }\n    }\n\n    return result\n  }\n\n  class OperatorNode extends Node {\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    constructor (op, fn, args, implicit, isPercentage) {\n      super()\n      // validate input\n      if (typeof op !== 'string') {\n        throw new TypeError('string expected for parameter \"op\"')\n      }\n      if (typeof fn !== 'string') {\n        throw new TypeError('string expected for parameter \"fn\"')\n      }\n      if (!Array.isArray(args) || !args.every(isNode)) {\n        throw new TypeError(\n          '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    static name = name\n    get type () { return name }\n    get isOperatorNode () { return true }\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    _compile (math, argNames) {\n      // validate fn\n      if (typeof this.fn !== 'string' || !isSafeMethod(math, this.fn)) {\n        if (!math[this.fn]) {\n          throw new Error(\n            'Function ' + this.fn + ' missing in provided namespace \"math\"')\n        } else {\n          throw new Error('No access to function \"' + this.fn + '\"')\n        }\n      }\n\n      const fn = getSafeProperty(math, this.fn)\n      const evalArgs = map(this.args, function (arg) {\n        return arg._compile(math, argNames)\n      })\n\n      if (typeof fn === 'function' && fn.rawArgs === true) {\n        // pass unevaluated parameters (nodes) to the function\n        // \"raw\" evaluation\n        const rawArgs = this.args\n        return function evalOperatorNode (scope, args, context) {\n          return fn(rawArgs, math, createSubScope(scope, args))\n        }\n      } else if (evalArgs.length === 1) {\n        const 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        const evalArg0 = evalArgs[0]\n        const evalArg1 = evalArgs[1]\n        return function evalOperatorNode (scope, args, context) {\n          return fn(\n            evalArg0(scope, args, context),\n            evalArg1(scope, args, context))\n        }\n      } else {\n        return function evalOperatorNode (scope, args, context) {\n          return fn.apply(null, map(evalArgs, function (evalArg) {\n            return evalArg(scope, args, context)\n          }))\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    forEach (callback) {\n      for (let i = 0; i < this.args.length; i++) {\n        callback(this.args[i], 'args[' + i + ']', this)\n      }\n    }\n\n    /**\n     * Create a new OperatorNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const args = []\n      for (let i = 0; i < this.args.length; i++) {\n        args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this))\n      }\n      return new OperatorNode(\n        this.op, this.fn, args, this.implicit, this.isPercentage)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {OperatorNode}\n     */\n    clone () {\n      return new OperatorNode(\n        this.op, this.fn, this.args.slice(0), this.implicit, this.isPercentage)\n    }\n\n    /**\n     * Check whether this is an unary OperatorNode:\n     * has exactly one argument, like `-a`.\n     * @return {boolean}\n     *     Returns true when an unary operator node, false otherwise.\n     */\n    isUnary () {\n      return this.args.length === 1\n    }\n\n    /**\n     * Check whether this is a binary OperatorNode:\n     * has exactly two arguments, like `a + b`.\n     * @return {boolean}\n     *     Returns true when a binary operator node, false otherwise.\n     */\n    isBinary () {\n      return this.args.length === 2\n    }\n\n    /**\n     * Get string representation.\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const implicit = (options && options.implicit) ? options.implicit : 'hide'\n      const args = this.args\n      const parens =\n          calculateNecessaryParentheses(this, parenthesis, implicit, args, false)\n\n      if (args.length === 1) { // unary operators\n        const assoc = getAssociativity(this, parenthesis)\n\n        let operand = args[0].toString(options)\n        if (parens[0]) {\n          operand = '(' + operand + ')'\n        }\n\n        // for example for \"not\", we want a space between operand and argument\n        const opIsNamed = /[a-zA-Z]+/.test(this.op)\n\n        if (assoc === 'right') { // prefix operator\n          return this.op + (opIsNamed ? ' ' : '') + operand\n        } else if (assoc === 'left') { // postfix\n          return operand + (opIsNamed ? ' ' : '') + this.op\n        }\n\n        // fall back to postfix\n        return operand + this.op\n      } else if (args.length === 2) {\n        let lhs = args[0].toString(options) // left hand side\n        let rhs = args[1].toString(options) // right hand side\n        if (parens[0]) { // left hand side in parenthesis?\n          lhs = '(' + lhs + ')'\n        }\n        if (parens[1]) { // right hand side in parenthesis?\n          rhs = '(' + rhs + ')'\n        }\n\n        if (this.implicit &&\n            (this.getIdentifier() === 'OperatorNode:multiply') &&\n            (implicit === 'hide')) {\n          return lhs + ' ' + rhs\n        }\n\n        return lhs + ' ' + this.op + ' ' + rhs\n      } else if ((args.length > 2) &&\n                 ((this.getIdentifier() === 'OperatorNode:add') ||\n                     (this.getIdentifier() === 'OperatorNode:multiply'))) {\n        const stringifiedArgs = args.map(function (arg, index) {\n          arg = arg.toString(options)\n          if (parens[index]) { // put in parenthesis?\n            arg = '(' + arg + ')'\n          }\n\n          return arg\n        })\n\n        if (this.implicit &&\n            (this.getIdentifier() === 'OperatorNode:multiply') &&\n            (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    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        op: this.op,\n        fn: this.fn,\n        args: this.args,\n        implicit: this.implicit,\n        isPercentage: this.isPercentage\n      }\n    }\n\n    /**\n     * Instantiate an OperatorNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     ```\n     *     {\"mathjs\": \"OperatorNode\",\n     *      \"op\": \"+\", \"fn\": \"add\", \"args\": [...],\n     *      \"implicit\": false,\n     *      \"isPercentage\":false}\n     *     ```\n     *     where mathjs is optional\n     * @returns {OperatorNode}\n     */\n    static fromJSON (json) {\n      return new OperatorNode(\n        json.op, json.fn, json.args, json.implicit, json.isPercentage)\n    }\n\n    /**\n     * Get HTML representation.\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const implicit = (options && options.implicit) ? options.implicit : 'hide'\n      const args = this.args\n      const parens =\n          calculateNecessaryParentheses(this, parenthesis, implicit, args, false)\n\n      if (args.length === 1) { // unary operators\n        const assoc = getAssociativity(this, parenthesis)\n\n        let operand = args[0].toHTML(options)\n        if (parens[0]) {\n          operand =\n            '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n            operand +\n            '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n        }\n\n        if (assoc === 'right') { // prefix operator\n          return '<span class=\"math-operator math-unary-operator ' +\n            'math-lefthand-unary-operator\">' + escape(this.op) + '</span>' +\n            operand\n        } else { // postfix when assoc === 'left' or undefined\n          return operand +\n            '<span class=\"math-operator math-unary-operator ' +\n            'math-righthand-unary-operator\">' + escape(this.op) + '</span>'\n        }\n      } else if (args.length === 2) { // binary operatoes\n        let lhs = args[0].toHTML(options) // left hand side\n        let rhs = args[1].toHTML(options) // right hand side\n        if (parens[0]) { // left hand side in parenthesis?\n          lhs = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n            lhs +\n            '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n        }\n        if (parens[1]) { // right hand side in parenthesis?\n          rhs = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n            rhs +\n            '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n        }\n\n        if (this.implicit &&\n            (this.getIdentifier() === 'OperatorNode:multiply') &&\n            (implicit === 'hide')) {\n          return lhs +\n            '<span class=\"math-operator math-binary-operator ' +\n            'math-implicit-binary-operator\"></span>' + rhs\n        }\n\n        return lhs +\n          '<span class=\"math-operator math-binary-operator ' +\n          'math-explicit-binary-operator\">' + escape(this.op) + '</span>' +\n          rhs\n      } else {\n        const stringifiedArgs = args.map(function (arg, index) {\n          arg = arg.toHTML(options)\n          if (parens[index]) { // put in parenthesis?\n            arg =\n              '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n              arg +\n              '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n          }\n\n          return arg\n        })\n\n        if ((args.length > 2) &&\n            ((this.getIdentifier() === 'OperatorNode:add') ||\n                (this.getIdentifier() === 'OperatorNode:multiply'))) {\n          if (this.implicit &&\n              (this.getIdentifier() === 'OperatorNode:multiply') &&\n              (implicit === 'hide')) {\n            return stringifiedArgs.join(\n              '<span class=\"math-operator math-binary-operator ' +\n                'math-implicit-binary-operator\"></span>')\n          }\n\n          return stringifiedArgs.join(\n            '<span class=\"math-operator math-binary-operator ' +\n              'math-explicit-binary-operator\">' + escape(this.op) + '</span>')\n        } else {\n          // fallback to formatting as a function call\n          return '<span class=\"math-function\">' + escape(this.fn) +\n            '</span><span class=\"math-paranthesis math-round-parenthesis\">' +\n            '(</span>' +\n            stringifiedArgs.join('<span class=\"math-separator\">,</span>') +\n            '<span class=\"math-paranthesis math-round-parenthesis\">)</span>'\n        }\n      }\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const implicit = (options && options.implicit) ? options.implicit : 'hide'\n      const args = this.args\n      const parens =\n          calculateNecessaryParentheses(this, parenthesis, implicit, args, true)\n\n      let op = latexOperators[this.fn]\n      op = typeof op === 'undefined' ? this.op : op // fall back to using this.op\n\n      if (args.length === 1) { // unary operators\n        const assoc = getAssociativity(this, parenthesis)\n\n        let operand = args[0].toTex(options)\n        if (parens[0]) {\n          operand = `\\\\left(${operand}\\\\right)`\n        }\n\n        if (assoc === 'right') { // prefix operator\n          return op + operand\n        } else if (assoc === 'left') { // postfix operator\n          return operand + op\n        }\n\n        // fall back to postfix\n        return operand + op\n      } else if (args.length === 2) { // binary operators\n        const lhs = args[0] // left hand side\n        let lhsTex = lhs.toTex(options)\n        if (parens[0]) {\n          lhsTex = `\\\\left(${lhsTex}\\\\right)`\n        }\n\n        const rhs = args[1] // right hand side\n        let rhsTex = rhs.toTex(options)\n        if (parens[1]) {\n          rhsTex = `\\\\left(${rhsTex}\\\\right)`\n        }\n\n        // handle some exceptions (due to the way LaTeX works)\n        let lhsIdentifier\n        if (parenthesis === 'keep') {\n          lhsIdentifier = lhs.getIdentifier()\n        } else {\n          // Ignore ParenthesisNodes if in 'keep' mode\n          lhsIdentifier = lhs.getContent().getIdentifier()\n        }\n        switch (this.getIdentifier()) {\n          case 'OperatorNode:divide':\n            // op contains '\\\\frac' at this point\n            return op + '{' + lhsTex + '}' + '{' + rhsTex + '}'\n          case 'OperatorNode:pow':\n            lhsTex = '{' + lhsTex + '}'\n            rhsTex = '{' + rhsTex + '}'\n            switch (lhsIdentifier) {\n              case 'ConditionalNode': //\n              case 'OperatorNode:divide':\n                lhsTex = `\\\\left(${lhsTex}\\\\right)`\n            }\n            break\n          case 'OperatorNode:multiply':\n            if (this.implicit && (implicit === 'hide')) {\n              return lhsTex + '~' + rhsTex\n            }\n        }\n        return lhsTex + op + rhsTex\n      } else if ((args.length > 2) &&\n                 ((this.getIdentifier() === 'OperatorNode:add') ||\n                     (this.getIdentifier() === 'OperatorNode:multiply'))) {\n        const texifiedArgs = args.map(function (arg, index) {\n          arg = arg.toTex(options)\n          if (parens[index]) {\n            arg = `\\\\left(${arg}\\\\right)`\n          }\n          return arg\n        })\n\n        if ((this.getIdentifier() === 'OperatorNode:multiply') &&\n            this.implicit && implicit === 'hide') {\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(' +\n          args.map(function (arg) {\n            return arg.toTex(options)\n          }).join(',') + '\\\\right)'\n      }\n    }\n\n    /**\n     * Get identifier.\n     * @return {string}\n     */\n    getIdentifier () {\n      return this.type + ':' + this.fn\n    }\n  }\n\n  return OperatorNode\n}, { isClass: true, isNode: true })\n","import { isNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'ParenthesisNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createParenthesisNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  class ParenthesisNode extends Node {\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    constructor (content) {\n      super()\n      // validate input\n      if (!isNode(content)) {\n        throw new TypeError('Node expected for parameter \"content\"')\n      }\n\n      this.content = content\n    }\n\n    static name = name\n    get type () { return name }\n    get isParenthesisNode () { return true }\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    _compile (math, argNames) {\n      return this.content._compile(math, argNames)\n    }\n\n    /**\n     * Get the content of the current Node.\n     * @return {Node} content\n     * @override\n     **/\n    getContent () {\n      return this.content.getContent()\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    forEach (callback) {\n      callback(this.content, 'content', this)\n    }\n\n    /**\n     * Create a new ParenthesisNode whose child is the result of calling\n     * the provided callback function on the child of this node.\n     * @param {function(child: Node, path: string, parent: Node) : Node} callback\n     * @returns {ParenthesisNode} Returns a clone of the node\n     */\n    map (callback) {\n      const content = callback(this.content, 'content', this)\n      return new ParenthesisNode(content)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {ParenthesisNode}\n     */\n    clone () {\n      return new ParenthesisNode(this.content)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toString (options) {\n      if ((!options) ||\n          (options && !options.parenthesis) ||\n          (options && options.parenthesis === 'keep')) {\n        return '(' + this.content.toString(options) + ')'\n      }\n      return this.content.toString(options)\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return { mathjs: name, 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    static fromJSON (json) {\n      return new ParenthesisNode(json.content)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toHTML (options) {\n      if ((!options) ||\n          (options && !options.parenthesis) ||\n          (options && options.parenthesis === 'keep')) {\n        return '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          this.content.toHTML(options) +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n      return this.content.toHTML(options)\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toTex (options) {\n      if ((!options) ||\n          (options && !options.parenthesis) ||\n          (options && options.parenthesis === 'keep')) {\n        return `\\\\left(${this.content.toTex(options)}\\\\right)`\n      }\n      return this.content.toTex(options)\n    }\n  }\n\n  return ParenthesisNode\n}, { isClass: true, isNode: true })\n","import { isNode, isSymbolNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { getPrecedence } from '../operators.js'\n\nconst name = 'RangeNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createRangeNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  /**\n   * Calculate the necessary parentheses\n   * @param {Node} node\n   * @param {string} parenthesis\n   * @param {string} implicit\n   * @return {Object} parentheses\n   * @private\n   */\n  function calculateNecessaryParentheses (node, parenthesis, implicit) {\n    const precedence = getPrecedence(node, parenthesis, implicit)\n    const parens = {}\n\n    const startPrecedence = getPrecedence(node.start, parenthesis, implicit)\n    parens.start = ((startPrecedence !== null) && (startPrecedence <= precedence)) ||\n      (parenthesis === 'all')\n\n    if (node.step) {\n      const stepPrecedence = getPrecedence(node.step, parenthesis, implicit)\n      parens.step = ((stepPrecedence !== null) && (stepPrecedence <= precedence)) ||\n        (parenthesis === 'all')\n    }\n\n    const endPrecedence = getPrecedence(node.end, parenthesis, implicit)\n    parens.end = ((endPrecedence !== null) && (endPrecedence <= precedence)) ||\n      (parenthesis === 'all')\n\n    return parens\n  }\n\n  class RangeNode extends Node {\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    constructor (start, end, step) {\n      super()\n      // validate inputs\n      if (!isNode(start)) throw new TypeError('Node expected')\n      if (!isNode(end)) throw new TypeError('Node expected')\n      if (step && !isNode(step)) throw new TypeError('Node expected')\n      if (arguments.length > 3) throw new Error('Too many arguments')\n\n      this.start = start // included lower-bound\n      this.end = end // included upper-bound\n      this.step = step || null // optional step\n    }\n\n    static name = name\n    get type () { return name }\n    get isRangeNode () { return true }\n\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    needsEnd () {\n      // find all `end` symbols in this RangeNode\n      const endSymbols = this.filter(function (node) {\n        return isSymbolNode(node) && (node.name === 'end')\n      })\n\n      return endSymbols.length > 0\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    _compile (math, argNames) {\n      const range = math.range\n      const evalStart = this.start._compile(math, argNames)\n      const evalEnd = this.end._compile(math, argNames)\n\n      if (this.step) {\n        const evalStep = this.step._compile(math, argNames)\n\n        return function evalRangeNode (scope, args, context) {\n          return range(\n            evalStart(scope, args, context),\n            evalEnd(scope, args, context),\n            evalStep(scope, args, context)\n          )\n        }\n      } else {\n        return function evalRangeNode (scope, args, context) {\n          return range(\n            evalStart(scope, args, context),\n            evalEnd(scope, args, context)\n          )\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    forEach (callback) {\n      callback(this.start, 'start', this)\n      callback(this.end, 'end', this)\n      if (this.step) {\n        callback(this.step, 'step', this)\n      }\n    }\n\n    /**\n     * Create a new RangeNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      return new RangeNode(\n        this._ifNode(callback(this.start, 'start', this)),\n        this._ifNode(callback(this.end, 'end', this)),\n        this.step && this._ifNode(callback(this.step, 'step', this))\n      )\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {RangeNode}\n     */\n    clone () {\n      return new RangeNode(this.start, this.end, this.step && this.step)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const parens =\n          calculateNecessaryParentheses(\n            this, parenthesis, options && options.implicit)\n\n      // format string as start:step:stop\n      let str\n\n      let start = this.start.toString(options)\n      if (parens.start) {\n        start = '(' + start + ')'\n      }\n      str = start\n\n      if (this.step) {\n        let step = this.step.toString(options)\n        if (parens.step) {\n          step = '(' + step + ')'\n        }\n        str += ':' + step\n      }\n\n      let end = this.end.toString(options)\n      if (parens.end) {\n        end = '(' + end + ')'\n      }\n      str += ':' + end\n\n      return str\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        start: this.start,\n        end: this.end,\n        step: this.step\n      }\n    }\n\n    /**\n     * Instantiate an RangeNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"RangeNode\", \"start\": ..., \"end\": ..., \"step\": ...}`,\n     *     where mathjs is optional\n     * @returns {RangeNode}\n     */\n    static fromJSON (json) {\n      return new RangeNode(json.start, json.end, json.step)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const parens =\n          calculateNecessaryParentheses(\n            this, parenthesis, options && options.implicit)\n\n      // format string as start:step:stop\n      let str\n\n      let start = this.start.toHTML(options)\n      if (parens.start) {\n        start = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          start +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n      str = start\n\n      if (this.step) {\n        let step = this.step.toHTML(options)\n        if (parens.step) {\n          step = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n            step +\n            '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n        }\n        str += '<span class=\"math-operator math-range-operator\">:</span>' + step\n      }\n\n      let end = this.end.toHTML(options)\n      if (parens.end) {\n        end = '<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n          end +\n          '<span class=\"math-parenthesis math-round-parenthesis\">)</span>'\n      }\n      str += '<span class=\"math-operator math-range-operator\">:</span>' + end\n\n      return str\n    }\n\n    /**\n     * Get LaTeX representation\n     * @params {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const parens =\n          calculateNecessaryParentheses(\n            this, parenthesis, options && options.implicit)\n\n      let str = this.start.toTex(options)\n      if (parens.start) {\n        str = `\\\\left(${str}\\\\right)`\n      }\n\n      if (this.step) {\n        let step = this.step.toTex(options)\n        if (parens.step) {\n          step = `\\\\left(${step}\\\\right)`\n        }\n        str += ':' + step\n      }\n\n      let end = this.end.toTex(options)\n      if (parens.end) {\n        end = `\\\\left(${end}\\\\right)`\n      }\n      str += ':' + end\n\n      return str\n    }\n  }\n\n  return RangeNode\n}, { isClass: true, isNode: true })\n","import { getPrecedence } from '../operators.js'\nimport { escape } from '../../utils/string.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { latexOperators } from '../../utils/latex.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'RelationalNode'\nconst dependencies = [\n  'Node'\n]\n\nexport const createRelationalNode = /* #__PURE__ */ factory(name, dependencies, ({ Node }) => {\n  const operatorMap = {\n    equal: '==',\n    unequal: '!=',\n    smaller: '<',\n    larger: '>',\n    smallerEq: '<=',\n    largerEq: '>='\n  }\n\n  class RelationalNode extends Node {\n    /**\n     * A node representing a chained conditional expression, such as 'x > y > z'\n     *\n     * @param {String[]} conditionals\n     *     An array of conditional operators used to compare the parameters\n     * @param {Node[]} params\n     *     The parameters that will be compared\n     *\n     * @constructor RelationalNode\n     * @extends {Node}\n     */\n    constructor (conditionals, params) {\n      super()\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) {\n        throw new TypeError(\n          'Parameter params must contain exactly one more element ' +\n            'than parameter conditionals')\n      }\n\n      this.conditionals = conditionals\n      this.params = params\n    }\n\n    static name = name\n    get type () { return name }\n    get isRelationalNode () { return true }\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    _compile (math, argNames) {\n      const self = this\n\n      const compiled = this.params.map(p => p._compile(math, argNames))\n\n      return function evalRelationalNode (scope, args, context) {\n        let evalLhs\n        let evalRhs = compiled[0](scope, args, context)\n\n        for (let i = 0; i < self.conditionals.length; i++) {\n          evalLhs = evalRhs\n          evalRhs = compiled[i + 1](scope, args, context)\n          const condFn = getSafeProperty(math, self.conditionals[i])\n          if (!condFn(evalLhs, evalRhs)) {\n            return false\n          }\n        }\n        return true\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    forEach (callback) {\n      this.params.forEach((n, i) => callback(n, 'params[' + i + ']', this), this)\n    }\n\n    /**\n     * Create a new RelationalNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      return new RelationalNode(\n        this.conditionals.slice(),\n        this.params.map(\n          (n, i) => this._ifNode(callback(n, 'params[' + i + ']', this)), this))\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {RelationalNode}\n     */\n    clone () {\n      return new RelationalNode(this.conditionals, this.params)\n    }\n\n    /**\n     * Get string representation.\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const precedence =\n          getPrecedence(this, parenthesis, options && options.implicit)\n\n      const paramStrings = this.params.map(function (p, index) {\n        const paramPrecedence =\n            getPrecedence(p, parenthesis, options && options.implicit)\n        return (parenthesis === 'all' ||\n                (paramPrecedence !== null && paramPrecedence <= precedence))\n          ? '(' + p.toString(options) + ')'\n          : p.toString(options)\n      })\n\n      let ret = paramStrings[0]\n      for (let i = 0; i < this.conditionals.length; i++) {\n        ret += ' ' + operatorMap[this.conditionals[i]]\n        ret += ' ' + paramStrings[i + 1]\n      }\n\n      return ret\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        conditionals: this.conditionals,\n        params: this.params\n      }\n    }\n\n    /**\n     * Instantiate a RelationalNode from its JSON representation\n     * @param {Object} json\n     *     An object structured like\n     *     `{\"mathjs\": \"RelationalNode\", \"conditionals\": ..., \"params\": ...}`,\n     *     where mathjs is optional\n     * @returns {RelationalNode}\n     */\n    static fromJSON (json) {\n      return new RelationalNode(json.conditionals, json.params)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const precedence =\n          getPrecedence(this, parenthesis, options && options.implicit)\n\n      const paramStrings = this.params.map(function (p, index) {\n        const paramPrecedence =\n            getPrecedence(p, parenthesis, options && options.implicit)\n        return (parenthesis === 'all' ||\n                (paramPrecedence !== null && paramPrecedence <= precedence))\n          ? ('<span class=\"math-parenthesis math-round-parenthesis\">(</span>' +\n             p.toHTML(options) +\n             '<span class=\"math-parenthesis math-round-parenthesis\">)</span>')\n          : p.toHTML(options)\n      })\n\n      let ret = paramStrings[0]\n      for (let i = 0; i < this.conditionals.length; i++) {\n        ret += '<span class=\"math-operator math-binary-operator ' +\n          'math-explicit-binary-operator\">' +\n          escape(operatorMap[this.conditionals[i]]) + '</span>' +\n          paramStrings[i + 1]\n      }\n\n      return ret\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const parenthesis =\n          (options && options.parenthesis) ? options.parenthesis : 'keep'\n      const precedence =\n          getPrecedence(this, parenthesis, options && options.implicit)\n\n      const paramStrings = this.params.map(function (p, index) {\n        const paramPrecedence =\n            getPrecedence(p, parenthesis, options && options.implicit)\n        return (parenthesis === 'all' ||\n                (paramPrecedence !== null && paramPrecedence <= precedence))\n          ? '\\\\left(' + p.toTex(options) + '\\right)'\n          : p.toTex(options)\n      })\n\n      let ret = paramStrings[0]\n      for (let i = 0; i < this.conditionals.length; i++) {\n        ret += latexOperators[this.conditionals[i]] + paramStrings[i + 1]\n      }\n\n      return ret\n    }\n  }\n\n  return RelationalNode\n}, { isClass: true, isNode: true })\n","import { escape } from '../../utils/string.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { factory } from '../../utils/factory.js'\nimport { toSymbol } from '../../utils/latex.js'\n\nconst name = 'SymbolNode'\nconst dependencies = [\n  'math',\n  '?Unit',\n  'Node'\n]\n\nexport const createSymbolNode = /* #__PURE__ */ factory(name, dependencies, ({ math, Unit, Node }) => {\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  class SymbolNode extends Node {\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    constructor (name) {\n      super()\n      // validate input\n      if (typeof name !== 'string') {\n        throw new TypeError('String expected for parameter \"name\"')\n      }\n\n      this.name = name\n    }\n\n    get type () { return 'SymbolNode' }\n    get isSymbolNode () { return true }\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    _compile (math, argNames) {\n      const 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\n        // assignment `f(x) = ...`)\n        return function (scope, args, context) {\n          return getSafeProperty(args, name)\n        }\n      } else if (name in math) {\n        return function (scope, args, context) {\n          return scope.has(name)\n            ? scope.get(name)\n            : getSafeProperty(math, name)\n        }\n      } else {\n        const isUnit = isValuelessUnit(name)\n\n        return function (scope, args, context) {\n          return scope.has(name)\n            ? scope.get(name)\n            : isUnit\n              ? new Unit(null, name)\n              : SymbolNode.onUndefinedSymbol(name)\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    forEach (callback) {\n      // nothing to do, we don't have any children\n    }\n\n    /**\n     * Create a new SymbolNode with children produced by the given callback.\n     * Trivial since a SymbolNode has no children\n     * @param {function(child: Node, path: string, parent: Node) : Node} callback\n     * @returns {SymbolNode} Returns a clone of the node\n     */\n    map (callback) {\n      return this.clone()\n    }\n\n    /**\n     * Throws an error 'Undefined symbol {name}'\n     * @param {string} name\n     */\n    static onUndefinedSymbol (name) {\n      throw new Error('Undefined symbol ' + name)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {SymbolNode}\n     */\n    clone () {\n      return new SymbolNode(this.name)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toString (options) {\n      return this.name\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toHTML (options) {\n      const name = escape(this.name)\n\n      if (name === 'true' || name === 'false') {\n        return '<span class=\"math-symbol math-boolean\">' + name + '</span>'\n      } else if (name === 'i') {\n        return '<span class=\"math-symbol math-imaginary-symbol\">' +\n          name + '</span>'\n      } else if (name === 'Infinity') {\n        return '<span class=\"math-symbol math-infinity-symbol\">' +\n          name + '</span>'\n      } else if (name === 'NaN') {\n        return '<span class=\"math-symbol math-nan-symbol\">' + name + '</span>'\n      } else if (name === 'null') {\n        return '<span class=\"math-symbol math-null-symbol\">' + name + '</span>'\n      } else if (name === 'undefined') {\n        return '<span class=\"math-symbol math-undefined-symbol\">' +\n          name + '</span>'\n      }\n\n      return '<span class=\"math-symbol\">' + name + '</span>'\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: 'SymbolNode',\n        name: this.name\n      }\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    static fromJSON (json) {\n      return new SymbolNode(json.name)\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     * @override\n     */\n    _toTex (options) {\n      let isUnit = false\n      if ((typeof math[this.name] === 'undefined') &&\n          isValuelessUnit(this.name)) {\n        isUnit = true\n      }\n      const symbol = toSymbol(this.name, isUnit)\n      if (symbol[0] === '\\\\') {\n        // no space needed if the symbol starts with '\\'\n        return symbol\n      }\n      // the space prevents symbols from breaking stuff like '\\cdot'\n      // if it's written right before the symbol\n      return ' ' + symbol\n    }\n  }\n\n  return SymbolNode\n}, { isClass: true, isNode: true })\n","import { isAccessorNode, isFunctionAssignmentNode, isIndexNode, isNode, isSymbolNode } from '../../utils/is.js'\nimport { escape, format } from '../../utils/string.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { getSafeProperty, getSafeMethod } from '../../utils/customs.js'\nimport { createSubScope } from '../../utils/scope.js'\nimport { factory } from '../../utils/factory.js'\nimport { defaultTemplate, latexFunctions } from '../../utils/latex.js'\n\nconst name = 'FunctionNode'\nconst dependencies = [\n  'math',\n  'Node',\n  'SymbolNode'\n]\n\nexport const createFunctionNode = /* #__PURE__ */ factory(name, dependencies, ({ math, Node, SymbolNode }) => {\n  /* format to fixed length */\n  const strin = entity => format(entity, { truncate: 78 })\n\n  /*\n   * Expand a LaTeX template\n   *\n   * @param {string} template\n   * @param {Node} node\n   * @param {Object} options\n   * @private\n   **/\n  function expandTemplate (template, node, options) {\n    let latex = ''\n\n    // Match everything of the form ${identifier} or ${identifier[2]} or $$\n    // while submatching identifier and 2 (in the second case)\n    const regex = /\\$(?:\\{([a-z_][a-z_0-9]*)(?:\\[([0-9]+)\\])?\\}|\\$)/gi\n\n    let inputPos = 0 // position in the input string\n    let match\n    while ((match = regex.exec(template)) !== null) { // 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] === '$$') { // escaped dollar sign\n        latex += '$'\n        inputPos++\n      } else { // template parameter\n        inputPos += match[0].length\n        const property = node[match[1]]\n        if (!property) {\n          throw new ReferenceError('Template: Property ' + match[1] + ' does not exist.')\n        }\n        if (match[2] === undefined) { // no square brackets\n          switch (typeof property) {\n            case 'string':\n              latex += property\n              break\n            case 'object':\n              if (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 (isNode(arg)) {\n                    return arg.toTex(options)\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              break\n            default:\n              throw new TypeError('Template: ' + match[1] + ' has to be a Node, String or array of Nodes')\n          }\n        } else { // with square brackets\n          if (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    latex += template.slice(inputPos) // append rest of the template\n\n    return latex\n  }\n\n  class FunctionNode extends Node {\n    /**\n     * @constructor FunctionNode\n     * @extends {./Node}\n     * invoke a list with arguments on a node\n     * @param {./Node | string} fn\n     *     Item resolving to a function on which to invoke\n     *     the arguments, typically a SymboNode or AccessorNode\n     * @param {./Node[]} args\n     */\n    constructor (fn, args) {\n      super()\n      if (typeof fn === 'string') {\n        fn = new SymbolNode(fn)\n      }\n\n      // validate input\n      if (!isNode(fn)) throw new TypeError('Node expected as parameter \"fn\"')\n      if (!Array.isArray(args) || !args.every(isNode)) {\n        throw new TypeError(\n          'Array containing Nodes expected for parameter \"args\"')\n      }\n\n      this.fn = fn\n      this.args = args || []\n    }\n\n    // readonly property name\n    get name () {\n      return this.fn.name || ''\n    }\n\n    static name = name\n    get type () { return name }\n    get isFunctionNode () { return true }\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    _compile (math, argNames) {\n      // compile arguments\n      const evalArgs = this.args.map((arg) => arg._compile(math, argNames))\n\n      if (isSymbolNode(this.fn)) {\n        const name = this.fn.name\n        if (!argNames[name]) {\n          // we can statically determine whether the function\n          // has the rawArgs property\n          const fn = name in math ? getSafeProperty(math, name) : undefined\n          const isRaw = typeof fn === 'function' && fn.rawArgs === true\n\n          const resolveFn = (scope) => {\n            let value\n            if (scope.has(name)) {\n              value = scope.get(name)\n            } else if (name in math) {\n              value = getSafeProperty(math, name)\n            } else {\n              return FunctionNode.onUndefinedFunction(name)\n            }\n            if (typeof value === 'function') {\n              return value\n            }\n            throw new TypeError(\n              `'${name}' is not a function; its value is:\\n  ${strin(value)}`\n            )\n          }\n\n          if (isRaw) {\n            // pass unevaluated parameters (nodes) to the function\n            // \"raw\" evaluation\n            const rawArgs = this.args\n            return function evalFunctionNode (scope, args, context) {\n              const fn = resolveFn(scope)\n              return fn(rawArgs, math, createSubScope(scope, args))\n            }\n          } else {\n            // \"regular\" evaluation\n            switch (evalArgs.length) {\n              case 0: return function evalFunctionNode (scope, args, context) {\n                const fn = resolveFn(scope)\n                return fn()\n              }\n              case 1: return function evalFunctionNode (scope, args, context) {\n                const fn = resolveFn(scope)\n                const evalArg0 = evalArgs[0]\n                return fn(\n                  evalArg0(scope, args, context)\n                )\n              }\n              case 2: return function evalFunctionNode (scope, args, context) {\n                const fn = resolveFn(scope)\n                const evalArg0 = evalArgs[0]\n                const evalArg1 = evalArgs[1]\n                return fn(\n                  evalArg0(scope, args, context),\n                  evalArg1(scope, args, context)\n                )\n              }\n              default: return function evalFunctionNode (scope, args, context) {\n                const fn = resolveFn(scope)\n                const values = evalArgs.map(\n                  (evalArg) => evalArg(scope, args, context))\n                return fn(...values)\n              }\n            }\n          }\n        } else { // the function symbol is an argName\n          const rawArgs = this.args\n          return function evalFunctionNode (scope, args, context) {\n            const fn = getSafeProperty(args, name)\n            if (typeof fn !== 'function') {\n              throw new TypeError(\n                `Argument '${name}' was not a function; received: ${strin(fn)}`\n              )\n            }\n            if (fn.rawArgs) {\n              // \"Raw\" evaluation\n              return fn(rawArgs, math, createSubScope(scope, args))\n            } else {\n              const values = evalArgs.map(\n                (evalArg) => evalArg(scope, args, context))\n              return fn.apply(fn, values)\n            }\n          }\n        }\n      } else if (\n        isAccessorNode(this.fn) &&\n          isIndexNode(this.fn.index) &&\n          this.fn.index.isObjectProperty()\n      ) {\n        // execute the function with the right context:\n        // the object of the AccessorNode\n\n        const evalObject = this.fn.object._compile(math, argNames)\n        const prop = this.fn.index.getObjectProperty()\n        const rawArgs = this.args\n\n        return function evalFunctionNode (scope, args, context) {\n          const object = evalObject(scope, args, context)\n          const fn = getSafeMethod(object, prop)\n\n          if (fn?.rawArgs) {\n            // \"Raw\" evaluation\n            return fn(rawArgs, math, createSubScope(scope, args))\n          } else {\n            // \"regular\" evaluation\n            const values = evalArgs.map((evalArg) => evalArg(scope, args, context))\n            return fn.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 the\n        // rawArgs property\n        const fnExpr = this.fn.toString()\n        const evalFn = this.fn._compile(math, argNames)\n        const rawArgs = this.args\n\n        return function evalFunctionNode (scope, args, context) {\n          const fn = evalFn(scope, args, context)\n          if (typeof fn !== 'function') {\n            throw new TypeError(\n              `Expression '${fnExpr}' did not evaluate to a function; value is:` +\n                `\\n  ${strin(fn)}`\n            )\n          }\n          if (fn.rawArgs) {\n            // \"Raw\" evaluation\n            return fn(rawArgs, math, createSubScope(scope, args))\n          } else {\n            // \"regular\" evaluation\n            const values = evalArgs.map(\n              (evalArg) => evalArg(scope, args, context))\n            return fn.apply(fn, values)\n          }\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    forEach (callback) {\n      callback(this.fn, 'fn', this)\n\n      for (let i = 0; i < this.args.length; i++) {\n        callback(this.args[i], 'args[' + i + ']', this)\n      }\n    }\n\n    /**\n     * Create a new FunctionNode whose children are the results of calling\n     * the provided callback function for each child 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    map (callback) {\n      const fn = this._ifNode(callback(this.fn, 'fn', this))\n      const args = []\n      for (let i = 0; i < this.args.length; i++) {\n        args[i] = this._ifNode(callback(this.args[i], 'args[' + i + ']', this))\n      }\n      return new FunctionNode(fn, args)\n    }\n\n    /**\n     * Create a clone of this node, a shallow copy\n     * @return {FunctionNode}\n     */\n    clone () {\n      return new FunctionNode(this.fn, this.args.slice(0))\n    }\n\n    /**\n     * Throws an error 'Undefined function {name}'\n     * @param {string} name\n     */\n    static onUndefinedFunction = function (name) {\n      throw new Error('Undefined function ' + name)\n    }\n\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    toString (options) {\n      let customString\n      const name = this.fn.toString(options)\n      if (options &&\n          (typeof options.handler === 'object') &&\n          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      }\n\n      // fall back to Node's toString\n      return super.toString(options)\n    }\n\n    /**\n     * Get string representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toString (options) {\n      const args = this.args.map(function (arg) {\n        return arg.toString(options)\n      })\n\n      const fn = isFunctionAssignmentNode(this.fn)\n        ? ('(' + this.fn.toString(options) + ')')\n        : this.fn.toString(options)\n\n      // format the arguments like \"add(2, 4.2)\"\n      return fn + '(' + args.join(', ') + ')'\n    }\n\n    /**\n     * Get a JSON representation of the node\n     * @returns {Object}\n     */\n    toJSON () {\n      return {\n        mathjs: name,\n        fn: this.fn,\n        args: this.args\n      }\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    static fromJSON = function (json) {\n      return new FunctionNode(json.fn, json.args)\n    }\n\n    /**\n     * Get HTML representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toHTML (options) {\n      const args = this.args.map(function (arg) {\n        return arg.toHTML(options)\n      })\n\n      // format the arguments like \"add(2, 4.2)\"\n      return '<span class=\"math-function\">' + escape(this.fn) +\n        '</span><span class=\"math-paranthesis math-round-parenthesis\">(</span>' +\n        args.join('<span class=\"math-separator\">,</span>') +\n        '<span class=\"math-paranthesis math-round-parenthesis\">)</span>'\n    }\n\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    toTex (options) {\n      let customTex\n      if (options &&\n          (typeof options.handler === 'object') &&\n          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      }\n\n      // fall back to Node's toTex\n      return super.toTex(options)\n    }\n\n    /**\n     * Get LaTeX representation\n     * @param {Object} options\n     * @return {string} str\n     */\n    _toTex (options) {\n      const args = this.args.map(function (arg) { // get LaTeX of the arguments\n        return arg.toTex(options)\n      })\n\n      let latexConverter\n\n      if (latexFunctions[this.name]) {\n        latexConverter = latexFunctions[this.name]\n      }\n\n      // toTex property on the function itself\n      if (math[this.name] &&\n          ((typeof math[this.name].toTex === 'function') ||\n           (typeof math[this.name].toTex === 'object') ||\n           (typeof math[this.name].toTex === 'string'))\n      ) {\n        // .toTex is a callback function\n        latexConverter = math[this.name].toTex\n      }\n\n      let customToTex\n      switch (typeof latexConverter) {\n        case 'function': // a callback function\n          customToTex = latexConverter(this, options)\n          break\n        case 'string': // a template string\n          customToTex = expandTemplate(latexConverter, this, options)\n          break\n        case 'object':\n          // an object with different \"converters\" for different\n          // numbers of arguments\n          switch (typeof latexConverter[args.length]) {\n            case 'function':\n              customToTex = latexConverter[args.length](this, options)\n              break\n            case 'string':\n              customToTex =\n                expandTemplate(latexConverter[args.length], this, options)\n              break\n          }\n      }\n\n      if (typeof customToTex !== 'undefined') {\n        return customToTex\n      }\n\n      return expandTemplate(defaultTemplate, this, options)\n    }\n\n    /**\n     * Get identifier.\n     * @return {string}\n     */\n    getIdentifier () {\n      return this.type + ':' + this.name\n    }\n  }\n\n  return FunctionNode\n}, { isClass: true, isNode: true })\n","import { factory } from '../utils/factory.js'\nimport { isAccessorNode, isConstantNode, isFunctionNode, isOperatorNode, isSymbolNode, rule2Node } from '../utils/is.js'\nimport { deepMap } from '../utils/collection.js'\nimport { safeNumberType } from '../utils/number.js'\nimport { hasOwnProperty } from '../utils/object.js'\n\nconst name = 'parse'\nconst dependencies = [\n  'typed',\n  'numeric',\n  'config',\n  'AccessorNode',\n  'ArrayNode',\n  'AssignmentNode',\n  'BlockNode',\n  'ConditionalNode',\n  'ConstantNode',\n  'FunctionAssignmentNode',\n  'FunctionNode',\n  'IndexNode',\n  'ObjectNode',\n  'OperatorNode',\n  'ParenthesisNode',\n  'RangeNode',\n  'RelationalNode',\n  'SymbolNode'\n]\n\nexport const createParse = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  numeric,\n  config,\n  AccessorNode,\n  ArrayNode,\n  AssignmentNode,\n  BlockNode,\n  ConditionalNode,\n  ConstantNode,\n  FunctionAssignmentNode,\n  FunctionNode,\n  IndexNode,\n  ObjectNode,\n  OperatorNode,\n  ParenthesisNode,\n  RangeNode,\n  RelationalNode,\n  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<string, Node>}} [options]  Available options:\n   *                                                   - `nodes` a set of custom nodes\n   * @return {Node | Node[]} node\n   * @throws {Error}\n   */\n  const parse = typed(name, {\n    string: function (expression) {\n      return parseStart(expression, {})\n    },\n    'Array | Matrix': function (expressions) {\n      return parseMultiple(expressions, {})\n    },\n    'string, Object': function (expression, options) {\n      const extraNodes = options.nodes !== undefined ? options.nodes : {}\n\n      return parseStart(expression, extraNodes)\n    },\n    'Array | Matrix, Object': parseMultiple\n  })\n\n  function parseMultiple (expressions, options = {}) {\n    const extraNodes = options.nodes !== undefined ? options.nodes : {}\n\n    // parse an array or matrix with expressions\n    return deepMap(expressions, function (elem) {\n      if (typeof elem !== 'string') throw new TypeError('String expected')\n\n      return parseStart(elem, extraNodes)\n    })\n  }\n\n  // token types enumeration\n  const TOKENTYPE = {\n    NULL: 0,\n    DELIMITER: 1,\n    NUMBER: 2,\n    SYMBOL: 3,\n    UNKNOWN: 4\n  }\n\n  // map with all delimiters\n  const DELIMITERS = {\n    ',': true,\n    '(': true,\n    ')': true,\n    '[': true,\n    ']': true,\n    '{': true,\n    '}': true,\n    '\"': true,\n    '\\'': true,\n    ';': true,\n\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\n    '==': true,\n    '!=': true,\n    '<': true,\n    '>': true,\n    '<=': true,\n    '>=': true,\n\n    '<<': true,\n    '>>': true,\n    '>>>': true\n  }\n\n  // map with all named delimiters\n  const 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\n  const CONSTANTS = {\n    true: true,\n    false: false,\n    null: null,\n    undefined\n  }\n\n  const NUMERIC_CONSTANTS = [\n    'NaN',\n    'Infinity'\n  ]\n\n  const ESCAPE_CHARACTERS = {\n    '\"': '\"',\n    \"'\": \"'\",\n    '\\\\': '\\\\',\n    '/': '/',\n    b: '\\b',\n    f: '\\f',\n    n: '\\n',\n    r: '\\r',\n    t: '\\t'\n    // note that \\u is handled separately in parseStringToken()\n  }\n\n  function initialState () {\n    return {\n      extraNodes: {}, // current extra nodes, must be careful not to mutate\n      expression: '', // current expression\n      comment: '', // last parsed comment\n      index: 0, // current index in expr\n      token: '', // current token\n      tokenType: TOKENTYPE.NULL, // type of the token\n      nestingLevel: 0, // 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  function currentString (state, length) {\n    return state.expression.substr(state.index, length)\n  }\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  function currentCharacter (state) {\n    return currentString(state, 1)\n  }\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  function next (state) {\n    state.index++\n  }\n\n  /**\n   * Preview the previous character from the expression.\n   * @return {string} cNext\n   * @private\n   */\n  function prevCharacter (state) {\n    return state.expression.charAt(state.index - 1)\n  }\n\n  /**\n   * Preview the next character from the expression.\n   * @return {string} cNext\n   * @private\n   */\n  function nextCharacter (state) {\n    return state.expression.charAt(state.index + 1)\n  }\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  function getToken (state) {\n    state.tokenType = TOKENTYPE.NULL\n    state.token = ''\n    state.comment = ''\n\n    // skip over ignored characters:\n    while (true) {\n      // comments:\n      if (currentCharacter(state) === '#') {\n        while (currentCharacter(state) !== '\\n' &&\n               currentCharacter(state) !== '') {\n          state.comment += currentCharacter(state)\n          next(state)\n        }\n      }\n      // whitespace: space, tab, and newline when inside parameters\n      if (parse.isWhitespace(currentCharacter(state), state.nestingLevel)) {\n        next(state)\n      } else {\n        break\n      }\n    }\n\n    // check for end of expression\n    if (currentCharacter(state) === '') {\n      // token is still empty\n      state.tokenType = TOKENTYPE.DELIMITER\n      return\n    }\n\n    // check for new line character\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    const c1 = currentCharacter(state)\n    const c2 = currentString(state, 2)\n    const c3 = currentString(state, 3)\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    }\n\n    // check for delimiters consisting of 2 characters\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    }\n\n    // check for delimiters consisting of 1 character\n    if (DELIMITERS[c1]) {\n      state.tokenType = TOKENTYPE.DELIMITER\n      state.token = c1\n      next(state)\n      return\n    }\n\n    // check for a number\n    if (parse.isDigitDot(c1)) {\n      state.tokenType = TOKENTYPE.NUMBER\n\n      // check for binary, octal, or hex\n      const c2 = currentString(state, 2)\n      if (c2 === '0b' || c2 === '0o' || c2 === '0x') {\n        state.token += currentCharacter(state)\n        next(state)\n        state.token += currentCharacter(state)\n        next(state)\n        while (parse.isHexDigit(currentCharacter(state))) {\n          state.token += currentCharacter(state)\n          next(state)\n        }\n        if (currentCharacter(state) === '.') {\n          // this number has a radix point\n          state.token += '.'\n          next(state)\n          // get the digits after the radix\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)\n          // get the word size\n          while (parse.isDigit(currentCharacter(state))) {\n            state.token += currentCharacter(state)\n            next(state)\n          }\n        }\n        return\n      }\n\n      // get number, can have a single dot\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        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      }\n      // check for exponential notation like \"2.3e-4\", \"1.23e50\" or \"2e+4\"\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          }\n          // Scientific notation MUST be followed by an exponent\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    }\n\n    // check for variables, functions, named operators\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 (hasOwnProperty(NAMED_DELIMITERS, state.token)) {\n        state.tokenType = TOKENTYPE.DELIMITER\n      } else {\n        state.tokenType = TOKENTYPE.SYMBOL\n      }\n\n      return\n    }\n\n    // something unknown is found, wrong characters -> a syntax error\n    state.tokenType = TOKENTYPE.UNKNOWN\n    while (currentCharacter(state) !== '') {\n      state.token += currentCharacter(state)\n      next(state)\n    }\n    throw createSyntaxError(state, 'Syntax error in part \"' + state.token + '\"')\n  }\n\n  /**\n   * Get next token and skip newline tokens\n   */\n  function getTokenSkipNewline (state) {\n    do {\n      getToken(state)\n    }\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  function openParams (state) {\n    state.nestingLevel++\n  }\n\n  /**\n   * Close parameters.\n   * New line characters will no longer be ignored\n   */\n  function closeParams (state) {\n    state.nestingLevel--\n  }\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  parse.isAlpha = function isAlpha (c, cPrev, cNext) {\n    return parse.isValidLatinOrGreek(c) ||\n        parse.isValidMathSymbol(c, cNext) ||\n        parse.isValidMathSymbol(cPrev, c)\n  }\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  parse.isValidLatinOrGreek = function isValidLatinOrGreek (c) {\n    return /^[a-zA-Z_$\\u00C0-\\u02AF\\u0370-\\u03FF\\u2100-\\u214F]$/.test(c)\n  }\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  parse.isValidMathSymbol = function isValidMathSymbol (high, low) {\n    return /^[\\uD835]$/.test(high) &&\n        /^[\\uDC00-\\uDFFF]$/.test(low) &&\n        /^[^\\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  /**\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  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  /**\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  parse.isDecimalMark = function isDecimalMark (c, cNext) {\n    return c === '.' && cNext !== '/' && cNext !== '*' && cNext !== '^'\n  }\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  parse.isDigitDot = function isDigitDot (c) {\n    return ((c >= '0' && c <= '9') || c === '.')\n  }\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  parse.isDigit = function isDigit (c) {\n    return (c >= '0' && c <= '9')\n  }\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  parse.isHexDigit = function isHexDigit (c) {\n    return ((c >= '0' && c <= '9') ||\n            (c >= 'a' && c <= 'f') ||\n            (c >= 'A' && c <= 'F'))\n  }\n\n  /**\n   * Start of the parse levels below, in order of precedence\n   * @return {Node} node\n   * @private\n   */\n  function parseStart (expression, extraNodes) {\n    const state = initialState()\n    Object.assign(state, { expression, extraNodes })\n    getToken(state)\n\n    const node = parseBlock(state)\n\n    // check for garbage at the end of the expression\n    // an expression ends with a empty character '' and tokenType DELIMITER\n    if (state.token !== '') {\n      if (state.tokenType === TOKENTYPE.DELIMITER) {\n        // user entered a not existing operator like \"//\"\n\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  /**\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  function parseBlock (state) {\n    let node\n    const blocks = []\n    let visible\n\n    if (state.token !== '' && state.token !== '\\n' && state.token !== ';') {\n      node = parseAssignment(state)\n      if (state.comment) {\n        node.comment = state.comment\n      }\n    }\n\n    // TODO: simplify this loop\n    while (state.token === '\\n' || state.token === ';') { // eslint-disable-line no-unmodified-loop-condition\n      if (blocks.length === 0 && node) {\n        visible = (state.token !== ';')\n        blocks.push({ node, visible })\n      }\n\n      getToken(state)\n      if (state.token !== '\\n' && state.token !== ';' && state.token !== '') {\n        node = parseAssignment(state)\n        if (state.comment) {\n          node.comment = state.comment\n        }\n\n        visible = (state.token !== ';')\n        blocks.push({ node, visible })\n      }\n    }\n\n    if (blocks.length > 0) {\n      return new BlockNode(blocks)\n    } else {\n      if (!node) {\n        node = new ConstantNode(undefined)\n        if (state.comment) {\n          node.comment = state.comment\n        }\n      }\n\n      return node\n    }\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  function parseAssignment (state) {\n    let name, args, value, valid\n\n    const node = parseConditional(state)\n\n    if (state.token === '=') {\n      if (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 (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 (isFunctionNode(node) && isSymbolNode(node.fn)) {\n        // parse function assignment like 'f(x) = x^2'\n        valid = true\n        args = []\n\n        name = node.name\n        node.args.forEach(function (arg, index) {\n          if (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  /**\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  function parseConditional (state) {\n    let node = parseLogicalOr(state)\n\n    while (state.token === '?') { // 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      const prev = state.conditionalLevel\n      state.conditionalLevel = state.nestingLevel\n      getTokenSkipNewline(state)\n\n      const condition = node\n      const trueExpr = parseAssignment(state)\n\n      if (state.token !== ':') throw createSyntaxError(state, 'False part of conditional expression expected')\n\n      state.conditionalLevel = null\n      getTokenSkipNewline(state)\n\n      const falseExpr = parseAssignment(state) // Note: check for conditional operator again, right associativity\n\n      node = new ConditionalNode(condition, trueExpr, falseExpr)\n\n      // restore the previous conditional level\n      state.conditionalLevel = prev\n    }\n\n    return node\n  }\n\n  /**\n   * logical or, 'x or y'\n   * @return {Node} node\n   * @private\n   */\n  function parseLogicalOr (state) {\n    let node = parseLogicalXor(state)\n\n    while (state.token === 'or') { // 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  /**\n   * logical exclusive or, 'x xor y'\n   * @return {Node} node\n   * @private\n   */\n  function parseLogicalXor (state) {\n    let node = parseLogicalAnd(state)\n\n    while (state.token === 'xor') { // 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  /**\n   * logical and, 'x and y'\n   * @return {Node} node\n   * @private\n   */\n  function parseLogicalAnd (state) {\n    let node = parseBitwiseOr(state)\n\n    while (state.token === 'and') { // 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  /**\n   * bitwise or, 'x | y'\n   * @return {Node} node\n   * @private\n   */\n  function parseBitwiseOr (state) {\n    let node = parseBitwiseXor(state)\n\n    while (state.token === '|') { // 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  /**\n   * bitwise exclusive or (xor), 'x ^| y'\n   * @return {Node} node\n   * @private\n   */\n  function parseBitwiseXor (state) {\n    let node = parseBitwiseAnd(state)\n\n    while (state.token === '^|') { // 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  /**\n   * bitwise and, 'x & y'\n   * @return {Node} node\n   * @private\n   */\n  function parseBitwiseAnd (state) {\n    let node = parseRelational(state)\n\n    while (state.token === '&') { // 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  /**\n   * Parse a chained conditional, like 'a > b >= c'\n   * @return {Node} node\n   */\n  function parseRelational (state) {\n    const params = [parseShift(state)]\n    const conditionals = []\n\n    const operators = {\n      '==': 'equal',\n      '!=': 'unequal',\n      '<': 'smaller',\n      '>': 'larger',\n      '<=': 'smallerEq',\n      '>=': 'largerEq'\n    }\n\n    while (hasOwnProperty(operators, state.token)) { // eslint-disable-line no-unmodified-loop-condition\n      const cond = { name: state.token, fn: operators[state.token] }\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(c => c.fn), params)\n    }\n  }\n\n  /**\n   * Bitwise left shift, bitwise right arithmetic shift, bitwise right logical shift\n   * @return {Node} node\n   * @private\n   */\n  function parseShift (state) {\n    let node, name, fn, params\n\n    node = parseConversion(state)\n\n    const operators = {\n      '<<': 'leftShift',\n      '>>': 'rightArithShift',\n      '>>>': 'rightLogShift'\n    }\n\n    while (hasOwnProperty(operators, state.token)) {\n      name = state.token\n      fn = operators[name]\n\n      getTokenSkipNewline(state)\n      params = [node, parseConversion(state)]\n      node = new OperatorNode(name, fn, params)\n    }\n\n    return node\n  }\n\n  /**\n   * conversion operators 'to' and 'in'\n   * @return {Node} node\n   * @private\n   */\n  function parseConversion (state) {\n    let node, name, fn, params\n\n    node = parseRange(state)\n\n    const operators = {\n      to: 'to',\n      in: 'to' // alias of 'to'\n    }\n\n    while (hasOwnProperty(operators, state.token)) {\n      name = state.token\n      fn = operators[name]\n\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  /**\n   * parse range, \"start:end\", \"start:step:end\", \":\", \"start:\", \":end\", etc\n   * @return {Node} node\n   * @private\n   */\n  function parseRange (state) {\n    let node\n    const 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)\n\n      // parse step and end\n      while (state.token === ':' && params.length < 3) { // 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 { // 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  /**\n   * add or subtract\n   * @return {Node} node\n   * @private\n   */\n  function parseAddSubtract (state) {\n    let node, name, fn, params\n\n    node = parseMultiplyDivide(state)\n\n    const operators = {\n      '+': 'add',\n      '-': 'subtract'\n    }\n    while (hasOwnProperty(operators, state.token)) {\n      name = state.token\n      fn = operators[name]\n\n      getTokenSkipNewline(state)\n      const rightNode = parseMultiplyDivide(state)\n      if (rightNode.isPercentage) {\n        params = [node, new OperatorNode('*', 'multiply', [node, rightNode])]\n      } else {\n        params = [node, rightNode]\n      }\n      node = new OperatorNode(name, fn, params)\n    }\n\n    return node\n  }\n\n  /**\n   * multiply, divide\n   * @return {Node} node\n   * @private\n   */\n  function parseMultiplyDivide (state) {\n    let node, last, name, fn\n\n    node = parseImplicitMultiplication(state)\n    last = node\n\n    const operators = {\n      '*': 'multiply',\n      '.*': 'dotMultiply',\n      '/': 'divide',\n      './': 'dotDivide'\n    }\n\n    while (true) {\n      if (hasOwnProperty(operators, state.token)) {\n        // explicit operators\n        name = state.token\n        fn = operators[name]\n\n        getTokenSkipNewline(state)\n\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  /**\n   * implicit multiplication\n   * @return {Node} node\n   * @private\n   */\n  function parseImplicitMultiplication (state) {\n    let node, last\n\n    node = parseRule2(state)\n    last = node\n\n    while (true) {\n      if ((state.tokenType === TOKENTYPE.SYMBOL) ||\n          (state.token === 'in' && isConstantNode(node)) ||\n          (state.tokenType === TOKENTYPE.NUMBER &&\n              !isConstantNode(last) &&\n              (!isOperatorNode(last) || last.op === '!')) ||\n          (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 /* implicit */)\n      } else {\n        break\n      }\n    }\n\n    return node\n  }\n\n  /**\n   * Infamous \"rule 2\" as described in https://github.com/josdejong/mathjs/issues/792#issuecomment-361065370\n   * And as amended in https://github.com/josdejong/mathjs/issues/2370#issuecomment-1054052164\n   * Explicit division gets higher precedence than implicit multiplication\n   * when the division matches this pattern:\n   *   [unaryPrefixOp]?[number] / [number] [symbol]\n   * @return {Node} node\n   * @private\n   */\n  function parseRule2 (state) {\n    let node = parseModulusPercentage(state)\n    let last = node\n    const tokenStates = []\n\n    while (true) {\n      // Match the \"number /\" part of the pattern \"number / number symbol\"\n      if (state.token === '/' && rule2Node(last)) {\n        // Look ahead to see if the next token is a number\n        tokenStates.push(Object.assign({}, state))\n        getTokenSkipNewline(state)\n\n        // Match the \"number / number\" part of the pattern\n        if (state.tokenType === TOKENTYPE.NUMBER) {\n          // Look ahead again\n          tokenStates.push(Object.assign({}, state))\n          getTokenSkipNewline(state)\n\n          // Match the \"symbol\" part of the pattern, or a left parenthesis\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            Object.assign(state, tokenStates.pop())\n            tokenStates.pop()\n            last = parseModulusPercentage(state)\n            node = new OperatorNode('/', 'divide', [node, last])\n          } else {\n            // Not a match, so rewind\n            tokenStates.pop()\n            Object.assign(state, tokenStates.pop())\n            break\n          }\n        } else {\n          // Not a match, so rewind\n          Object.assign(state, tokenStates.pop())\n          break\n        }\n      } else {\n        break\n      }\n    }\n\n    return node\n  }\n\n  /**\n   * modulus and percentage\n   * @return {Node} node\n   * @private\n   */\n  function parseModulusPercentage (state) {\n    let node, name, fn, params\n\n    node = parseUnary(state)\n\n    const operators = {\n      '%': 'mod',\n      mod: 'mod'\n    }\n\n    while (hasOwnProperty(operators, state.token)) {\n      name = state.token\n      fn = operators[name]\n\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  /**\n   * Unary plus and minus, and logical and bitwise not\n   * @return {Node} node\n   * @private\n   */\n  function parseUnary (state) {\n    let name, params, fn\n    const operators = {\n      '-': 'unaryMinus',\n      '+': 'unaryPlus',\n      '~': 'bitNot',\n      not: 'not'\n    }\n\n    if (hasOwnProperty(operators, state.token)) {\n      fn = operators[state.token]\n      name = state.token\n\n      getTokenSkipNewline(state)\n      params = [parseUnary(state)]\n\n      return new OperatorNode(name, fn, params)\n    }\n\n    return parsePow(state)\n  }\n\n  /**\n   * power\n   * Note: power operator is right associative\n   * @return {Node} node\n   * @private\n   */\n  function parsePow (state) {\n    let node, name, fn, params\n\n    node = parseLeftHandOperators(state)\n\n    if (state.token === '^' || state.token === '.^') {\n      name = state.token\n      fn = (name === '^') ? 'pow' : 'dotPow'\n\n      getTokenSkipNewline(state)\n      params = [node, parseUnary(state)] // Go back to unary, we can have '2^-3'\n      node = new OperatorNode(name, fn, params)\n    }\n\n    return node\n  }\n\n  /**\n   * Left hand operators: factorial x!, ctranspose x'\n   * @return {Node} node\n   * @private\n   */\n  function parseLeftHandOperators (state) {\n    let node, name, fn, params\n\n    node = parseCustomNodes(state)\n\n    const operators = {\n      '!': 'factorial',\n      '\\'': 'ctranspose'\n    }\n\n    while (hasOwnProperty(operators, state.token)) {\n      name = state.token\n      fn = operators[name]\n\n      getToken(state)\n      params = [node]\n\n      node = new OperatorNode(name, fn, params)\n      node = parseAccessors(state, node)\n    }\n\n    return node\n  }\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  function parseCustomNodes (state) {\n    let params = []\n\n    if (state.tokenType === TOKENTYPE.SYMBOL && hasOwnProperty(state.extraNodes, state.token)) {\n      const CustomNode = state.extraNodes[state.token]\n\n      getToken(state)\n\n      // parse parameters\n      if (state.token === '(') {\n        params = []\n\n        openParams(state)\n        getToken(state)\n\n        if (state.token !== ')') {\n          params.push(parseAssignment(state))\n\n          // parse a list with parameters\n          while (state.token === ',') { // 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        closeParams(state)\n        getToken(state)\n      }\n\n      // create a new custom node\n      // noinspection JSValidateTypes\n      return new CustomNode(params)\n    }\n\n    return parseSymbol(state)\n  }\n\n  /**\n   * parse symbols: functions, variables, constants, units\n   * @return {Node} node\n   * @private\n   */\n  function parseSymbol (state) {\n    let node, name\n\n    if (state.tokenType === TOKENTYPE.SYMBOL ||\n        (state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS)) {\n      name = state.token\n\n      getToken(state)\n\n      if (hasOwnProperty(CONSTANTS, name)) { // true, false, null, ...\n        node = new ConstantNode(CONSTANTS[name])\n      } else if (NUMERIC_CONSTANTS.includes(name)) { // NaN, Infinity\n        node = new ConstantNode(numeric(name, 'number'))\n      } else {\n        node = new SymbolNode(name)\n      }\n\n      // parse function parameters and matrix index\n      node = parseAccessors(state, node)\n      return node\n    }\n\n    return parseString(state)\n  }\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  function parseAccessors (state, node, types) {\n    let params\n\n    while ((state.token === '(' || state.token === '[' || state.token === '.') &&\n        (!types || types.includes(state.token))) { // eslint-disable-line no-unmodified-loop-condition\n      params = []\n\n      if (state.token === '(') {\n        if (isSymbolNode(node) || 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))\n\n            // parse a list with parameters\n            while (state.token === ',') { // 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          closeParams(state)\n          getToken(state)\n\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))\n\n          // parse a list with parameters\n          while (state.token === ',') { // 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        closeParams(state)\n        getToken(state)\n\n        node = new AccessorNode(node, new IndexNode(params))\n      } else {\n        // dot notation like variable.prop\n        getToken(state)\n\n        const isPropertyName = state.tokenType === TOKENTYPE.SYMBOL ||\n          (state.tokenType === TOKENTYPE.DELIMITER && state.token in NAMED_DELIMITERS)\n        if (!isPropertyName) {\n          throw createSyntaxError(state, 'Property name expected after dot')\n        }\n\n        params.push(new ConstantNode(state.token))\n        getToken(state)\n\n        const dotNotation = true\n        node = new AccessorNode(node, new IndexNode(params, dotNotation))\n      }\n    }\n\n    return node\n  }\n\n  /**\n   * Parse a single or double quoted string.\n   * @return {Node} node\n   * @private\n   */\n  function parseString (state) {\n    let node, str\n\n    if (state.token === '\"' || state.token === \"'\") {\n      str = parseStringToken(state, state.token)\n\n      // create constant\n      node = new ConstantNode(str)\n\n      // parse index parameters\n      node = parseAccessors(state, node)\n\n      return node\n    }\n\n    return parseMatrix(state)\n  }\n\n  /**\n   * Parse a string surrounded by single or double quotes\n   * @param {Object} state\n   * @param {\"'\" | \"\\\"\"} quote\n   * @return {string}\n   */\n  function parseStringToken (state, quote) {\n    let str = ''\n\n    while (currentCharacter(state) !== '' && currentCharacter(state) !== quote) {\n      if (currentCharacter(state) === '\\\\') {\n        next(state)\n\n        const char = currentCharacter(state)\n        const escapeChar = ESCAPE_CHARACTERS[char]\n        if (escapeChar !== undefined) {\n          // an escaped control character like \\\" or \\n\n          str += escapeChar\n          state.index += 1\n        } else if (char === 'u') {\n          // escaped unicode character\n          const unicode = state.expression.slice(state.index + 1, state.index + 5)\n          if (/^[0-9A-Fa-f]{4}$/.test(unicode)) { // test whether the string holds four hexadecimal values\n            str += String.fromCharCode(parseInt(unicode, 16))\n            state.index += 5\n          } else {\n            throw createSyntaxError(state, `Invalid unicode character \\\\u${unicode}`)\n          }\n        } else {\n          throw createSyntaxError(state, `Bad escape character \\\\${char}`)\n        }\n      } else {\n        // any regular character\n        str += currentCharacter(state)\n        next(state)\n      }\n    }\n\n    getToken(state)\n    if (state.token !== quote) {\n      throw createSyntaxError(state, `End of string ${quote} expected`)\n    }\n    getToken(state)\n\n    return str\n  }\n\n  /**\n   * parse the matrix\n   * @return {Node} node\n   * @private\n   */\n  function parseMatrix (state) {\n    let 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        const row = parseRow(state)\n\n        if (state.token === ';') {\n          // 2 dimensional array\n          rows = 1\n          params = [row]\n\n          // the rows of the matrix are separated by dot-comma's\n          while (state.token === ';') { // eslint-disable-line no-unmodified-loop-condition\n            getToken(state)\n\n            if (state.token !== ']') {\n              params[rows] = parseRow(state)\n              rows++\n            }\n          }\n\n          if (state.token !== ']') {\n            throw createSyntaxError(state, 'End of matrix ] expected')\n          }\n          closeParams(state)\n          getToken(state)\n\n          // check if the number of columns matches in all rows\n          cols = params[0].items.length\n          for (let r = 1; r < rows; r++) {\n            if (params[r].items.length !== cols) {\n              throw createError(state, 'Column dimensions mismatch ' +\n                  '(' + 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          closeParams(state)\n          getToken(state)\n\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  /**\n   * Parse a single comma-separated row from a matrix, like 'a, b, c'\n   * @return {ArrayNode} node\n   */\n  function parseRow (state) {\n    const params = [parseAssignment(state)]\n    let len = 1\n\n    while (state.token === ',') { // eslint-disable-line no-unmodified-loop-condition\n      getToken(state)\n\n      // parse expression\n      if (state.token !== ']' && state.token !== ';') {\n        params[len] = parseAssignment(state)\n        len++\n      }\n    }\n\n    return new ArrayNode(params)\n  }\n\n  /**\n   * parse an object, enclosed in angle brackets{...}, for example {value: 2}\n   * @return {Node} node\n   * @private\n   */\n  function parseObject (state) {\n    if (state.token === '{') {\n      openParams(state)\n      let key\n\n      const properties = {}\n      do {\n        getToken(state)\n\n        if (state.token !== '}') {\n          // parse key\n          if (state.token === '\"' || state.token === \"'\") {\n            key = parseStringToken(state, state.token)\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          }\n\n          // parse key/value separator\n          if (state.token !== ':') {\n            throw createSyntaxError(state, 'Colon : expected after object key')\n          }\n          getToken(state)\n\n          // parse key\n          properties[key] = parseAssignment(state)\n        }\n      }\n      while (state.token === ',') // eslint-disable-line no-unmodified-loop-condition\n\n      if (state.token !== '}') {\n        throw createSyntaxError(state, 'Comma , or bracket } expected after object value')\n      }\n      closeParams(state)\n      getToken(state)\n\n      let node = new ObjectNode(properties)\n\n      // parse index parameters\n      node = parseAccessors(state, node)\n\n      return node\n    }\n\n    return parseNumber(state)\n  }\n\n  /**\n   * parse a number\n   * @return {Node} node\n   * @private\n   */\n  function parseNumber (state) {\n    let numberStr\n\n    if (state.tokenType === TOKENTYPE.NUMBER) {\n      // this is a number\n      numberStr = state.token\n      getToken(state)\n\n      const numericType = safeNumberType(numberStr, config)\n      const value = numeric(numberStr, numericType)\n\n      return new ConstantNode(value)\n    }\n\n    return parseParentheses(state)\n  }\n\n  /**\n   * parentheses\n   * @return {Node} node\n   * @private\n   */\n  function parseParentheses (state) {\n    let node\n\n    // check if it is a parenthesized expression\n    if (state.token === '(') {\n      // parentheses (...)\n      openParams(state)\n      getToken(state)\n\n      node = parseAssignment(state) // start again\n\n      if (state.token !== ')') {\n        throw createSyntaxError(state, 'Parenthesis ) expected')\n      }\n      closeParams(state)\n      getToken(state)\n\n      node = new ParenthesisNode(node)\n      node = parseAccessors(state, node)\n      return node\n    }\n\n    return parseEnd(state)\n  }\n\n  /**\n   * Evaluated when the expression is not yet ended but expected to end\n   * @return {Node} res\n   * @private\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  /**\n   * Shortcut for getting the current row value (one based)\n   * Returns the line of the currently handled expression\n   * @private\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  function col (state) {\n    return state.index - state.token.length + 1\n  }\n\n  /**\n   * Create an error\n   * @param {Object} state\n   * @param {string} message\n   * @return {SyntaxError} instantiated error\n   * @private\n   */\n  function createSyntaxError (state, message) {\n    const c = col(state)\n    const error = new SyntaxError(message + ' (char ' + c + ')')\n    error.char = c\n\n    return error\n  }\n\n  /**\n   * Create an error\n   * @param {Object} state\n   * @param {string} message\n   * @return {Error} instantiated error\n   * @private\n   */\n  function createError (state, message) {\n    const c = col(state)\n    const error = new SyntaxError(message + ' (char ' + c + ')')\n    error.char = c\n\n    return error\n  }\n\n  // Now that we can parse, automatically convert strings to Nodes by parsing\n  typed.addConversion({ from: 'string', to: 'Node', convert: parse })\n\n  return parse\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'compile'\nconst dependencies = ['typed', 'parse']\n\nexport const createCompile = /* #__PURE__ */ factory(name, dependencies, ({ typed, parse }) => {\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 (expr) {\n      return parse(expr).compile()\n    },\n\n    'Array | Matrix': function (expr) {\n      return deepMap(expr, function (entry) {\n        return parse(entry).compile()\n      })\n    }\n  })\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { createEmptyMap } from '../../utils/map.js'\n\nconst name = 'evaluate'\nconst dependencies = ['typed', 'parse']\n\nexport const createEvaluate = /* #__PURE__ */ factory(name, dependencies, ({ typed, parse }) => {\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 (expr) {\n      const scope = createEmptyMap()\n      return parse(expr).compile().evaluate(scope)\n    },\n\n    'string, Map | Object': function (expr, scope) {\n      return parse(expr).compile().evaluate(scope)\n    },\n\n    'Array | Matrix': function (expr) {\n      const scope = createEmptyMap()\n      return deepMap(expr, function (entry) {\n        return parse(entry).compile().evaluate(scope)\n      })\n    },\n\n    'Array | Matrix, Map | Object': function (expr, scope) {\n      return deepMap(expr, function (entry) {\n        return parse(entry).compile().evaluate(scope)\n      })\n    }\n  })\n})\n","import { factory } from '../utils/factory.js'\nimport { createEmptyMap, toObject } from '../utils/map.js'\n\nconst name = 'Parser'\nconst dependencies = ['evaluate']\n\nexport const createParserClass = /* #__PURE__ */ factory(name, dependencies, ({ evaluate }) => {\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')                 // 3.5\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(\n        'Constructor must be called with the new operator')\n    }\n\n    Object.defineProperty(this, 'scope', {\n      value: createEmptyMap(),\n      writable: false\n    })\n  }\n\n  /**\n   * Attach type information\n   */\n  Parser.prototype.type = 'Parser'\n  Parser.prototype.isParser = true\n\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  Parser.prototype.evaluate = function (expr) {\n    // TODO: validate arguments\n    return evaluate(expr, this.scope)\n  }\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  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  /**\n   * Get a map with all defined variables\n   * @return {Object} values\n   */\n  Parser.prototype.getAll = function () {\n    return toObject(this.scope)\n  }\n\n  /**\n   * Get a map with all defined variables\n   * @return {Map} values\n   */\n  Parser.prototype.getAllAsMap = function () {\n    return this.scope\n  }\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  Parser.prototype.set = function (name, value) {\n    this.scope.set(name, value)\n    return value\n  }\n\n  /**\n   * Remove a variable from the parsers scope\n   * @param {string} name\n   */\n  Parser.prototype.remove = function (name) {\n    this.scope.delete(name)\n  }\n\n  /**\n   * Clear the scope with variables and functions\n   */\n  Parser.prototype.clear = function () {\n    this.scope.clear()\n  }\n\n  return Parser\n}, { isClass: true })\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'parser'\nconst dependencies = ['typed', 'Parser']\n\nexport const createParser = /* #__PURE__ */ factory(name, dependencies, ({ typed, Parser }) => {\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')                // 3.5\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})\n","import { clone } from '../../../utils/object.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'lup'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'abs',\n  'addScalar',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'larger',\n  'equalScalar',\n  'unaryMinus',\n  'DenseMatrix',\n  'SparseMatrix',\n  'Spa'\n]\n\nexport const createLup = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    matrix,\n    abs,\n    addScalar,\n    divideScalar,\n    multiplyScalar,\n    subtractScalar,\n    larger,\n    equalScalar,\n    unaryMinus,\n    DenseMatrix,\n    SparseMatrix,\n    Spa\n  }\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.<number>}} The lower triangular matrix, the upper triangular matrix and the permutation matrix.\n   */\n  return typed(name, {\n\n    DenseMatrix: function (m) {\n      return _denseLUP(m)\n    },\n\n    SparseMatrix: function (m) {\n      return _sparseLUP(m)\n    },\n\n    Array: function (a) {\n      // create dense matrix from array\n      const m = matrix(a)\n      // lup, use matrix implementation\n      const r = _denseLUP(m)\n      // result\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    const rows = m._size[0]\n    const columns = m._size[1]\n    // minimum rows and columns\n    let n = Math.min(rows, columns)\n    // matrix array, clone original data\n    const data = clone(m._data)\n    // l matrix arrays\n    const ldata = []\n    const lsize = [rows, n]\n    // u matrix arrays\n    const udata = []\n    const usize = [n, columns]\n    // vars\n    let i, j, k\n    // permutation vector\n    const p = []\n    for (i = 0; i < rows; i++) { p[i] = i }\n    // loop columns\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          const min = Math.min(i, j)\n          // v[i, j]\n          let s = 0\n          // loop up to min\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          data[i][j] = subtractScalar(data[i][j], s)\n        }\n      }\n      // row with larger value in cvector, row >= j\n      let pi = j\n      let pabsv = 0\n      let vjj = 0\n      // loop rows\n      for (i = j; i < rows; i++) {\n        // data @ i, j\n        const v = data[i][j]\n        // absolute value\n        const absv = abs(v)\n        // value is greater than pivote value\n        if (larger(absv, pabsv)) {\n          // store row\n          pi = i\n          // update max value\n          pabsv = absv\n          // value @ [j, j]\n          vjj = v\n        }\n      }\n      // swap rows (j <-> pi)\n      if (j !== pi) {\n        // swap values j <-> pi in p\n        p[j] = [p[pi], p[pi] = p[j]][0]\n        // swap j <-> pi in data\n        DenseMatrix._swapRows(j, pi, data)\n      }\n      // check column is in lower triangular matrix\n      if (j < rows) {\n        // loop rows (lower triangular matrix)\n        for (i = j + 1; i < rows; i++) {\n          // value @ i, j\n          const vij = data[i][j]\n          if (!equalScalar(vij, 0)) {\n            // update data\n            data[i][j] = divideScalar(data[i][j], vjj)\n          }\n        }\n      }\n    }\n    // loop columns\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          }\n          // L\n          ldata[i] = []\n        }\n        // check we are in the upper triangular matrix\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          }\n          // check column exists in lower triangular matrix\n          if (j < rows) {\n            // L\n            ldata[i][j] = 0\n          }\n          continue\n        }\n        // diagonal value\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          }\n          // check column exists in lower triangular matrix\n          if (j < rows) {\n            // L\n            ldata[i][j] = 1\n          }\n          continue\n        }\n        // check row exists in upper triangular matrix\n        if (i < columns) {\n          // U\n          udata[i][j] = 0\n        }\n        // check column exists in lower triangular matrix\n        if (j < rows) {\n          // L\n          ldata[i][j] = data[i][j]\n        }\n      }\n    }\n    // l matrix\n    const l = new DenseMatrix({\n      data: ldata,\n      size: lsize\n    })\n    // u matrix\n    const u = new DenseMatrix({\n      data: udata,\n      size: usize\n    })\n    // p vector\n    const pv = []\n    for (i = 0, n = p.length; i < n; i++) { pv[p[i]] = i }\n    // return matrices\n    return {\n      L: l,\n      U: u,\n      p: pv,\n      toString: function () {\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    const rows = m._size[0]\n    const columns = m._size[1]\n    // minimum rows and columns\n    const n = Math.min(rows, columns)\n    // matrix arrays (will not be modified, thanks to permutation vector)\n    const values = m._values\n    const index = m._index\n    const ptr = m._ptr\n    // l matrix arrays\n    const lvalues = []\n    const lindex = []\n    const lptr = []\n    const lsize = [rows, n]\n    // u matrix arrays\n    const uvalues = []\n    const uindex = []\n    const uptr = []\n    const usize = [n, columns]\n    // vars\n    let i, j, k\n    // permutation vectors, (current index -> original index) and (original index -> current index)\n    const pvCo = []\n    const pvOc = []\n    for (i = 0; i < rows; i++) {\n      pvCo[i] = i\n      pvOc[i] = i\n    }\n    // swap indices in permutation vectors (condition x < y)!\n    const swapIndeces = function (x, y) {\n      // find pv indeces getting data from x and y\n      const kx = pvOc[x]\n      const ky = pvOc[y]\n      // update permutation vector current -> original\n      pvCo[kx] = y\n      pvCo[ky] = x\n      // update permutation vector original -> current\n      pvOc[x] = ky\n      pvOc[y] = kx\n    }\n    // loop columns\n    for (j = 0; j < columns; j++) {\n      // sparse accumulator\n      const spa = new Spa()\n      // check lower triangular matrix has a value @ column j\n      if (j < rows) {\n        // update ptr\n        lptr.push(lvalues.length)\n        // first value in j column for lower triangular matrix\n        lvalues.push(1)\n        lindex.push(j)\n      }\n      // update ptr\n      uptr.push(uvalues.length)\n      // k0 <= k < k1 where k0 = _ptr[j] && k1 = _ptr[j+1]\n      const k0 = ptr[j]\n      const k1 = ptr[j + 1]\n      // copy column j into sparse accumulator\n      for (k = k0; k < k1; k++) {\n        // row\n        i = index[k]\n        // copy column values into sparse accumulator (use permutation vector)\n        spa.set(pvCo[i], values[k])\n      }\n      // skip first column in upper triangular matrix\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      }\n      // row with larger value in spa, row >= j\n      let pi = j\n      let vjj = spa.get(j)\n      let pabsv = abs(vjj)\n      // loop values in spa (order by row, below diagonal)\n      spa.forEach(j + 1, rows - 1, function (x, v) {\n        // absolute value\n        const absv = abs(v)\n        // value is greater than pivote value\n        if (larger(absv, pabsv)) {\n          // store row\n          pi = x\n          // update max value\n          pabsv = absv\n          // value @ [j, j]\n          vjj = v\n        }\n      })\n      // swap rows (j <-> pi)\n      if (j !== pi) {\n        // swap values j <-> pi in L\n        SparseMatrix._swapRows(j, pi, lsize[1], lvalues, lindex, lptr)\n        // swap values j <-> pi in U\n        SparseMatrix._swapRows(j, pi, usize[1], uvalues, uindex, uptr)\n        // swap values in spa\n        spa.swap(j, pi)\n        // update permutation vector (swap values @ j, pi)\n        swapIndeces(j, pi)\n      }\n      // loop values in spa (order by row)\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)\n          // check value is non zero\n          if (!equalScalar(v, 0)) {\n            // update lower triangular matrix\n            lvalues.push(v)\n            lindex.push(x)\n          }\n        }\n      })\n    }\n    // update ptrs\n    uptr.push(uvalues.length)\n    lptr.push(lvalues.length)\n\n    // return matrices\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 () {\n        return 'L: ' + this.L.toString() + '\\nU: ' + this.U.toString() + '\\nP: ' + this.p\n      }\n    }\n  }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'qr'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'zeros',\n  'identity',\n  'isZero',\n  'equal',\n  'sign',\n  'sqrt',\n  'conj',\n  'unaryMinus',\n  'addScalar',\n  'divideScalar',\n  'multiplyScalar',\n  'subtractScalar',\n  'complex'\n]\n\nexport const createQr = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    matrix,\n    zeros,\n    identity,\n    isZero,\n    equal,\n    sign,\n    sqrt,\n    conj,\n    unaryMinus,\n    addScalar,\n    divideScalar,\n    multiplyScalar,\n    subtractScalar,\n    complex\n  }\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 Object.assign(typed(name, {\n\n    DenseMatrix: function (m) {\n      return _denseQR(m)\n    },\n\n    SparseMatrix: function (m) {\n      return _sparseQR(m)\n    },\n\n    Array: function (a) {\n      // create dense matrix from array\n      const m = matrix(a)\n      // lup, use matrix implementation\n      const r = _denseQR(m)\n      // result\n      return {\n        Q: r.Q.valueOf(),\n        R: r.R.valueOf()\n      }\n    }\n  }), { _denseQRimpl })\n\n  function _denseQRimpl (m) {\n    // rows & columns (m x n)\n    const rows = m._size[0] // m\n    const cols = m._size[1] // n\n\n    const Q = identity([rows], 'dense')\n    const Qdata = Q._data\n\n    const R = m.clone()\n    const Rdata = R._data\n\n    // vars\n    let i, j, k\n\n    const 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\n      const pivot = Rdata[k][k]\n      const sgn = unaryMinus(equal(pivot, 0) ? 1 : sign(pivot))\n      const conjSgn = conj(sgn)\n\n      let 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      const alpha = multiplyScalar(sgn, sqrt(alphaSquared))\n\n      if (!isZero(alpha)) {\n        // first element in vector u\n        const u1 = subtractScalar(pivot, alpha)\n\n        // w = v * u1 / |u|    (only elements k to (rows-1) are used)\n        w[k] = 1\n\n        for (i = k + 1; i < rows; i++) {\n          w[i] = divideScalar(Rdata[i][k], u1)\n        }\n\n        // tau = - conj(u1 / alpha)\n        const tau = unaryMinus(conj(divideScalar(u1, alpha)))\n\n        let s\n\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        for (j = k; j < cols; j++) {\n          s = 0.0\n\n          // calculate jth element of [tranpose(w) * R]\n          for (i = k; i < rows; i++) {\n            s = addScalar(s, multiplyScalar(conj(w[i]), Rdata[i][j]))\n          }\n\n          // calculate the jth element of [tau * transpose(w) * R]\n          s = multiplyScalar(s, tau)\n\n          for (i = k; i < rows; i++) {\n            Rdata[i][j] = multiplyScalar(\n              subtractScalar(Rdata[i][j], multiplyScalar(w[i], s)),\n              conjSgn\n            )\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        for (i = 0; i < rows; i++) {\n          s = 0.0\n\n          // calculate ith element of [Q * w]\n          for (j = k; j < rows; j++) {\n            s = addScalar(s, multiplyScalar(Qdata[i][j], w[j]))\n          }\n\n          // calculate the ith element of [tau * Q * w]\n          s = multiplyScalar(s, tau)\n\n          for (j = k; j < rows; ++j) {\n            Qdata[i][j] = divideScalar(\n              subtractScalar(Qdata[i][j], multiplyScalar(s, conj(w[j]))),\n              conjSgn\n            )\n          }\n        }\n      }\n    }\n\n    // return matrices\n    return {\n      Q,\n      R,\n      toString: function () {\n        return 'Q: ' + this.Q.toString() + '\\nR: ' + this.R.toString()\n      }\n    }\n  }\n\n  function _denseQR (m) {\n    const ret = _denseQRimpl(m)\n    const Rdata = ret.R._data\n    if (m._data.length > 0) {\n      const zero = Rdata[0][0].type === 'Complex' ? complex(0) : 0\n\n      for (let i = 0; i < Rdata.length; ++i) {\n        for (let 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})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csTdfs (j, k, w, head, next, post, stack) {\n  // variables\n  let top = 0\n  // place j on the stack\n  w[stack] = j\n  // while (stack is not empty)\n  while (top >= 0) {\n    // p = top of stack\n    const p = w[stack + top]\n    // i = youngest child of p\n    const i = w[head + p]\n    if (i === -1) {\n      // p has no unordered children left\n      top--\n      // node p is the kth postordered node\n      post[k++] = p\n    } else {\n      // remove i from children of p\n      w[head + p] = w[next + i]\n      // increment top\n      ++top\n      // start dfs on child node i\n      w[stack + top] = i\n    }\n  }\n  return k\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\n/**\n * This function \"flips\" its input about the integer -1.\n *\n * @param {Number}  i               The value to flip\n */\nexport function csFlip (i) {\n  // flip the value\n  return -i - 2\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { factory } from '../../../utils/factory.js'\nimport { csFkeep } from './csFkeep.js'\nimport { csFlip } from './csFlip.js'\nimport { csTdfs } from './csTdfs.js'\n\nconst name = 'csAmd'\nconst dependencies = [\n  'add',\n  'multiply',\n  'transpose'\n]\n\nexport const createCsAmd = /* #__PURE__ */ factory(name, dependencies, ({ add, multiply, transpose }) => {\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   * @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) { return null }\n    // a matrix arrays\n    const asize = a._size\n    // rows and columns\n    const m = asize[0]\n    const n = asize[1]\n    // initialize vars\n    let lemax = 0\n    // dense threshold\n    let dense = Math.max(16, 10 * Math.sqrt(n))\n    dense = Math.min(n - 2, dense)\n    // create target matrix C\n    const cm = _createTargetMatrix(order, a, m, n, dense)\n    // drop diagonal entries\n    csFkeep(cm, _diag, null)\n    // C matrix arrays\n    const cindex = cm._index\n    const cptr = cm._ptr\n\n    // number of nonzero elements in C\n    let cnz = cptr[n]\n\n    // allocate result (n+1)\n    const P = []\n\n    // create workspace (8 * (n + 1))\n    const W = []\n    const len = 0 // first n + 1 entries\n    const nv = n + 1 // next n + 1 entries\n    const next = 2 * (n + 1) // next n + 1 entries\n    const head = 3 * (n + 1) // next n + 1 entries\n    const elen = 4 * (n + 1) // next n + 1 entries\n    const degree = 5 * (n + 1) // next n + 1 entries\n    const w = 6 * (n + 1) // next n + 1 entries\n    const hhead = 7 * (n + 1) // last n + 1 entries\n\n    // use P as workspace for last\n    const last = P\n\n    // initialize quotient graph\n    let mark = _initializeQuotientGraph(n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree)\n\n    // initialize degree lists\n    let nel = _initializeDegreeLists(n, cptr, W, degree, elen, w, dense, nv, head, last, next)\n\n    // minimum degree node\n    let mindeg = 0\n\n    // vars\n    let i, j, k, k1, k2, e, pj, ln, nvi, pk, eln, p1, p2, pn, h, d\n\n    // while (selecting pivots) do\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      if (W[next + k] !== -1) { last[W[next + k]] = -1 }\n      // remove k from degree list\n      W[head + mindeg] = W[next + k]\n      // elenk = |Ek|\n      const elenk = W[elen + k]\n      // # of nodes k represents\n      let nvk = W[nv + k]\n      // W[nv + k] nodes of A eliminated\n      nel += nvk\n\n      // 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      let dk = 0\n      // flag k as in Lk\n      W[nv + k] = -nvk\n      let p = cptr[k]\n      // do in place if W[elen + k] === 0\n      const pk1 = (elenk === 0) ? p : cnz\n      let pk2 = pk1\n      for (k1 = 1; k1 <= elenk + 1; k1++) {\n        if (k1 > elenk) {\n          // search the nodes in k\n          e = k\n          // list of nodes starts at cindex[pj]\n          pj = p\n          // length of list of nodes in k\n          ln = W[len + k] - elenk\n        } else {\n          // search the nodes in e\n          e = cindex[p++]\n          pj = cptr[e]\n          // length of list of nodes in e\n          ln = W[len + e]\n        }\n        for (k2 = 1; k2 <= ln; k2++) {\n          i = cindex[pj++]\n          // check  node i dead, or seen\n          if ((nvi = W[nv + i]) <= 0) { continue }\n          // W[degree + Lk] += size of node i\n          dk += nvi\n          // negate W[nv + i] to denote i in Lk\n          W[nv + i] = -nvi\n          // place i in Lk\n          cindex[pk2++] = i\n          if (W[next + i] !== -1) { last[W[next + i]] = last[i] }\n          // check we need to remove i from degree list\n          if (last[i] !== -1) { W[next + last[i]] = W[next + i] } else { W[head + W[degree + i]] = W[next + i] }\n        }\n        if (e !== k) {\n          // absorb e into k\n          cptr[e] = csFlip(k)\n          // e is now a dead element\n          W[w + e] = 0\n        }\n      }\n      // cindex[cnz...nzmax] is free\n      if (elenk !== 0) { cnz = pk2 }\n      // external degree of k - |Lk\\i|\n      W[degree + k] = dk\n      // element k is in cindex[pk1..pk2-1]\n      cptr[k] = pk1\n      W[len + k] = pk2 - pk1\n      // k is now an element\n      W[elen + k] = -2\n\n      // 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\n      // clear w if necessary\n      mark = _wclear(mark, lemax, W, w, n)\n      // scan 1: find |Le\\Lk|\n      for (pk = pk1; pk < pk2; pk++) {\n        i = cindex[pk]\n        // check if W[elen + i] empty, skip it\n        if ((eln = W[elen + i]) <= 0) { continue }\n        // W[nv + i] was negated\n        nvi = -W[nv + i]\n        const wnvi = mark - nvi\n        // scan Ei\n        for (p = cptr[i], p1 = cptr[i] + eln - 1; p <= p1; p++) {\n          e = cindex[p]\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      }\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\n      // scan2: degree update\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\n        // scan Ei\n        for (h = 0, d = 0, p = p1; p <= p2; p++) {\n          e = cindex[p]\n          // check e is an unabsorbed element\n          if (W[w + e] !== 0) {\n            // dext = |Le\\Lk|\n            const dext = W[w + e] - mark\n            if (dext > 0) {\n              // sum up the set differences\n              d += dext\n              // keep e in Ei\n              cindex[pn++] = e\n              // compute the hash of node i\n              h += e\n            } else {\n              // aggressive absorb. e->k\n              cptr[e] = csFlip(k)\n              // e is a dead element\n              W[w + e] = 0\n            }\n          }\n        }\n        // W[elen + i] = |Ei|\n        W[elen + i] = pn - p1 + 1\n        const p3 = pn\n        const p4 = p1 + W[len + i]\n        // prune edges in Ai\n        for (p = p2 + 1; p < p4; p++) {\n          j = cindex[p]\n          // check node j dead or in Lk\n          const nvj = W[nv + j]\n          if (nvj <= 0) { continue }\n          // degree(i) += |j|\n          d += nvj\n          // place j in node list of i\n          cindex[pn++] = j\n          // compute hash for node i\n          h += j\n        }\n        // check for mass elimination\n        if (d === 0) {\n          // absorb i into k\n          cptr[i] = csFlip(k)\n          nvi = -W[nv + i]\n          // |Lk| -= |i|\n          dk -= nvi\n          // |k| += W[nv + i]\n          nvk += nvi\n          nel += nvi\n          W[nv + i] = 0\n          // node i is dead\n          W[elen + i] = -1\n        } else {\n          // update degree(i)\n          W[degree + i] = Math.min(W[degree + i], d)\n          // move first node to end\n          cindex[pn] = cindex[p3]\n          // move 1st el. to end of Ei\n          cindex[p3] = cindex[p1]\n          // add k as 1st element in of Ei\n          cindex[p1] = k\n          // new len of adj. list of node i\n          W[len + i] = pn - p1 + 1\n          // finalize hash of i\n          h = (h < 0 ? -h : h) % n\n          // place i in hash bucket\n          W[next + i] = W[hhead + h]\n          W[hhead + h] = i\n          // save hash of i in last[i]\n          last[i] = h\n        }\n      }\n      // finalize |Lk|\n      W[degree + k] = dk\n      lemax = Math.max(lemax, dk)\n      // clear w\n      mark = _wclear(mark + lemax, lemax, W, w, n)\n\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      for (pk = pk1; pk < pk2; pk++) {\n        i = cindex[pk]\n        // check i is dead, skip it\n        if (W[nv + i] >= 0) { continue }\n        // scan hash bucket of node i\n        h = last[i]\n        i = W[hhead + h]\n        // hash bucket will be empty\n        W[hhead + h] = -1\n        for (; i !== -1 && W[next + i] !== -1; i = W[next + i], mark++) {\n          ln = W[len + i]\n          eln = W[elen + i]\n          for (p = cptr[i] + 1; p <= cptr[i] + ln - 1; p++) { W[w + cindex[p]] = mark }\n          let jlast = i\n          // compare i with all j\n          for (j = W[next + i]; j !== -1;) {\n            let ok = W[len + j] === ln && W[elen + j] === eln\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) { ok = 0 }\n            }\n            // check i and j are identical\n            if (ok) {\n              // absorb j into i\n              cptr[j] = csFlip(i)\n              W[nv + i] += W[nv + j]\n              W[nv + j] = 0\n              // node j is dead\n              W[elen + j] = -1\n              // delete j from hash bucket\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      }\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      for (p = pk1, pk = pk1; pk < pk2; pk++) {\n        i = cindex[pk]\n        // check  i is dead, skip it\n        if ((nvi = -W[nv + i]) <= 0) { continue }\n        // restore W[nv + i]\n        W[nv + i] = nvi\n        // compute external degree(i)\n        d = W[degree + i] + dk - nvi\n        d = Math.min(d, n - nel - nvi)\n        if (W[head + d] !== -1) { last[W[head + d]] = i }\n        // put i back in degree list\n        W[next + i] = W[head + d]\n        last[i] = -1\n        W[head + d] = i\n        // find new minimum degree\n        mindeg = Math.min(mindeg, d)\n        W[degree + i] = d\n        // place i in Lk\n        cindex[p++] = i\n      }\n      // # nodes absorbed into k\n      W[nv + k] = nvk\n      // length of adj list of element k\n      if ((W[len + k] = p - pk1) === 0) {\n        // k is a root of the tree\n        cptr[k] = -1\n        // k is now a dead element\n        W[w + k] = 0\n      }\n      if (elenk !== 0) {\n        // free unused space in Lk\n        cnz = p\n      }\n    }\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\n    // fix assembly tree\n    for (i = 0; i < n; i++) { cptr[i] = csFlip(cptr[i]) }\n    for (j = 0; j <= n; j++) { W[head + j] = -1 }\n    // place unordered nodes in lists\n    for (j = n; j >= 0; j--) {\n      // skip if j is an element\n      if (W[nv + j] > 0) { continue }\n      // place j in list of its parent\n      W[next + j] = W[head + cptr[j]]\n      W[head + cptr[j]] = j\n    }\n    // place elements in lists\n    for (e = n; e >= 0; e--) {\n      // skip unless e is an element\n      if (W[nv + e] <= 0) { continue }\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    }\n    // postorder the assembly tree\n    for (k = 0, i = 0; i <= n; i++) {\n      if (cptr[i] === -1) { k = csTdfs(i, k, W, head, next, P, w) }\n    }\n    // remove last item in array\n    P.splice(P.length - 1, 1)\n    // return P\n    return P\n  }\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  function _createTargetMatrix (order, a, m, n, dense) {\n    // compute A'\n    const at = transpose(a)\n\n    // check order = 1, matrix must be square\n    if (order === 1 && n === m) {\n      // C = A + A'\n      return add(a, at)\n    }\n\n    // check order = 2, drop dense columns from M'\n    if (order === 2) {\n      // transpose arrays\n      const tindex = at._index\n      const tptr = at._ptr\n      // new column index\n      let p2 = 0\n      // loop A' columns (rows)\n      for (let j = 0; j < m; j++) {\n        // column j of AT starts here\n        let p = tptr[j]\n        // new column j starts here\n        tptr[j] = p2\n        // skip dense col j\n        if (tptr[j + 1] - p > dense) { continue }\n        // map rows in column j of A\n        for (const p1 = tptr[j + 1]; p < p1; p++) { tindex[p2++] = tindex[p] }\n      }\n      // finalize AT\n      tptr[m] = p2\n      // recreate A from new transpose matrix\n      a = transpose(at)\n      // use A' * A\n      return multiply(at, a)\n    }\n\n    // use A' * A, square or rectangular matrix\n    return multiply(at, a)\n  }\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  function _initializeQuotientGraph (n, cptr, W, len, head, last, next, hhead, nv, w, elen, degree) {\n    // Initialize quotient graph\n    for (let k = 0; k < n; k++) { W[len + k] = cptr[k + 1] - cptr[k] }\n    W[len + n] = 0\n    // initialize workspace\n    for (let 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\n      // hash list i is empty\n      W[hhead + i] = -1\n      // node i is just one node\n      W[nv + i] = 1\n      // node i is alive\n      W[w + i] = 1\n      // Ek of node i is empty\n      W[elen + i] = 0\n      // degree of node i\n      W[degree + i] = W[len + i]\n    }\n    // clear w\n    const mark = _wclear(0, 0, W, w, n)\n    // n is a dead element\n    W[elen + n] = -2\n    // n is a root of assembly tree\n    cptr[n] = -1\n    // n is a dead element\n    W[w + n] = 0\n    // return mark\n    return mark\n  }\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  function _initializeDegreeLists (n, cptr, W, degree, elen, w, dense, nv, head, last, next) {\n    // result\n    let nel = 0\n    // loop columns\n    for (let i = 0; i < n; i++) {\n      // degree @ i\n      const d = W[degree + i]\n      // check node i is empty\n      if (d === 0) {\n        // element i is dead\n        W[elen + i] = -2\n        nel++\n        // i is a root of assembly tree\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\n        // node i is dead\n        W[elen + i] = -1\n        nel++\n        cptr[i] = csFlip(n)\n        W[nv + n]++\n      } else {\n        const h = W[head + d]\n        if (h !== -1) { last[h] = i }\n        // put node i in degree list d\n        W[next + i] = W[head + d]\n        W[head + d] = i\n      }\n    }\n    return nel\n  }\n\n  function _wclear (mark, lemax, W, w, n) {\n    if (mark < 2 || (mark + lemax < 0)) {\n      for (let k = 0; k < n; k++) {\n        if (W[w + k] !== 0) { W[w + k] = 1 }\n      }\n      mark = 2\n    }\n    // at this point, W [0..n-1] < mark holds\n    return mark\n  }\n\n  function _diag (i, j) {\n    return i !== j\n  }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csFkeep (a, callback, other) {\n  // a arrays\n  const avalues = a._values\n  const aindex = a._index\n  const aptr = a._ptr\n  const asize = a._size\n  // columns\n  const n = asize[1]\n  // nonzero items\n  let nz = 0\n  // loop columns\n  for (let j = 0; j < n; j++) {\n    // get current location of col j\n    let p = aptr[j]\n    // record new location of col j\n    aptr[j] = nz\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]\n        // check we need to process values (pattern only)\n        if (avalues) { avalues[nz] = avalues[p] }\n        // increment nonzero items\n        nz++\n      }\n    }\n  }\n  // finalize A\n  aptr[n] = nz\n  // trim arrays\n  aindex.splice(nz, aindex.length - nz)\n  // check we need to process values (pattern only)\n  if (avalues) { avalues.splice(nz, avalues.length - nz) }\n  // return number of nonzero items\n  return nz\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csLeaf (i, j, w, first, maxfirst, prevleaf, ancestor) {\n  let s, sparent\n\n  // our result\n  let jleaf = 0\n  let q\n\n  // check j is a leaf\n  if (i <= j || w[first + j] <= w[maxfirst + i]) { return (-1) }\n  // update max first[j] seen so far\n  w[maxfirst + i] = w[first + j]\n  // jprev = previous leaf of ith subtree\n  const jprev = w[prevleaf + i]\n  w[prevleaf + i] = j\n\n  // check j is first or subsequent leaf\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\n    // q = least common ancester (jprev,j)\n    for (q = jprev; q !== w[ancestor + q]; q = w[ancestor + q]);\n    for (s = jprev; s !== q; s = sparent) {\n      // path compression\n      sparent = w[ancestor + s]\n      w[ancestor + s] = q\n    }\n  }\n  return { jleaf, q }\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { factory } from '../../../utils/factory.js'\nimport { csLeaf } from './csLeaf.js'\n\nconst name = 'csCounts'\nconst dependencies = [\n  'transpose'\n]\n\nexport const createCsCounts = /* #__PURE__ */ factory(name, dependencies, ({ transpose }) => {\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  return function (a, parent, post, ata) {\n    // check inputs\n    if (!a || !parent || !post) { return null }\n    // a matrix arrays\n    const asize = a._size\n    // rows and columns\n    const m = asize[0]\n    const n = asize[1]\n    // variables\n    let i, j, k, J, p, p0, p1\n\n    // workspace size\n    const s = 4 * n + (ata ? (n + m + 1) : 0)\n    // allocate workspace\n    const w = [] // (s)\n    const ancestor = 0 // first n entries\n    const maxfirst = n // next n entries\n    const prevleaf = 2 * n // next n entries\n    const first = 3 * n // next n entries\n    const head = 4 * n // next n + 1 entries (used when ata is true)\n    const next = 5 * n + 1 // last entries in workspace\n    // clear workspace w[0..s-1]\n    for (k = 0; k < s; k++) { w[k] = -1 }\n\n    // allocate result\n    const colcount = [] // (n)\n\n    // AT = A'\n    const at = transpose(a)\n    // at arrays\n    const tindex = at._index\n    const tptr = at._ptr\n\n    // find w[first + j]\n    for (k = 0; k < n; k++) {\n      j = post[k]\n      // colcount[j]=1 if j is a leaf\n      colcount[j] = (w[first + j] === -1) ? 1 : 0\n      for (; j !== -1 && w[first + j] === -1; j = parent[j]) { w[first + j] = k }\n    }\n\n    // initialize ata if needed\n    if (ata) {\n      // invert post\n      for (k = 0; k < n; k++) { w[post[k]] = k }\n      // loop rows (columns in AT)\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++) { k = Math.min(k, w[tindex[p]]) }\n        // place row i in linked list k\n        w[next + i] = w[head + k]\n        w[head + k] = i\n      }\n    }\n\n    // each node in its own set\n    for (i = 0; i < n; i++) { w[ancestor + i] = i }\n\n    for (k = 0; k < n; k++) {\n      // j is the kth node in postordered etree\n      j = post[k]\n      // check j is not a root\n      if (parent[j] !== -1) { colcount[parent[j]]-- }\n\n      // J=j for LL'=A case\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          const r = csLeaf(i, j, w, first, maxfirst, prevleaf, ancestor)\n          // check A(i,j) is in skeleton\n          if (r.jleaf >= 1) { colcount[j]++ }\n          // check account for overlap in q\n          if (r.jleaf === 2) { colcount[r.q]-- }\n        }\n      }\n      if (parent[j] !== -1) { w[ancestor + j] = parent[j] }\n    }\n    // sum up colcount's of each child\n    for (j = 0; j < n; j++) {\n      if (parent[j] !== -1) { colcount[parent[j]] += colcount[j] }\n    }\n    return colcount\n  }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csPermute } from './csPermute.js'\nimport { csPost } from './csPost.js'\nimport { csEtree } from './csEtree.js'\nimport { createCsAmd } from './csAmd.js'\nimport { createCsCounts } from './csCounts.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'csSqr'\nconst dependencies = [\n  'add',\n  'multiply',\n  'transpose'\n]\n\nexport const createCsSqr = /* #__PURE__ */ factory(name, dependencies, ({ add, multiply, transpose }) => {\n  const csAmd = createCsAmd({ add, multiply, transpose })\n  const csCounts = createCsCounts({ 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  return function csSqr (order, a, qr) {\n    // a arrays\n    const aptr = a._ptr\n    const asize = a._size\n    // columns\n    const n = asize[1]\n    // vars\n    let k\n    // symbolic analysis result\n    const s = {}\n    // fill-reducing ordering\n    s.q = csAmd(order, a)\n    // validate results\n    if (order && !s.q) { return null }\n    // QR symbolic analysis\n    if (qr) {\n      // apply permutations if needed\n      const c = order ? csPermute(a, null, s.q, 0) : a\n      // etree of C'*C, where C=A(:,q)\n      s.parent = csEtree(c, 1)\n      // post order elimination tree\n      const post = csPost(s.parent, n)\n      // col counts chol(C'*C)\n      s.cp = csCounts(c, s.parent, post, 1)\n      // check we have everything needed to calculate number of nonzero elements\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++) { s.unz += s.cp[k] }\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    }\n    // return result S\n    return s\n  }\n\n  /**\n   * Compute nnz(V) = s.lnz, s.pinv, s.leftmost, s.m2 from A and s.parent\n   */\n  function _vcount (a, s) {\n    // a arrays\n    const aptr = a._ptr\n    const aindex = a._index\n    const asize = a._size\n    // rows & columns\n    const m = asize[0]\n    const n = asize[1]\n    // initialize s arrays\n    s.pinv = [] // (m + n)\n    s.leftmost = [] // (m)\n    // vars\n    const parent = s.parent\n    const pinv = s.pinv\n    const leftmost = s.leftmost\n    // workspace, next: first m entries, head: next n entries, tail: next n entries, nque: next n entries\n    const w = [] // (m + 3 * n)\n    const next = 0\n    const head = m\n    const tail = m + n\n    const nque = m + 2 * n\n    // vars\n    let i, k, p, p0, p1\n    // initialize w\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    }\n    // initialize row arrays\n    for (i = 0; i < m; i++) { leftmost[i] = -1 }\n    // loop columns backwards\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    }\n    // scan rows in reverse order\n    for (i = m - 1; i >= 0; i--) {\n      // row i is not yet ordered\n      pinv[i] = -1\n      k = leftmost[i]\n      // check row i is empty\n      if (k === -1) { continue }\n      // first row in queue k\n      if (w[nque + k]++ === 0) { w[tail + k] = i }\n      // put i at head of queue k\n      w[next + i] = w[head + k]\n      w[head + k] = i\n    }\n    s.lnz = 0\n    s.m2 = m\n    // find row permutation and nnz(V)\n    for (k = 0; k < n; k++) {\n      // remove row i from queue k\n      i = w[head + k]\n      // count V(k,k) as nonzero\n      s.lnz++\n      // add a fictitious row\n      if (i < 0) { i = s.m2++ }\n      // associate row i with V(:,k)\n      pinv[i] = k\n      // skip if V(k+1:m,k) is empty\n      if (--nque[k] <= 0) { continue }\n      // nque[k] is nnz (V(k+1:m,k))\n      s.lnz += w[nque + k]\n      // move all rows to parent of k\n      const pa = parent[k]\n      if (pa !== -1) {\n        if (w[nque + pa] === 0) { w[tail + pa] = w[tail + k] }\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    for (i = 0; i < m; i++) {\n      if (pinv[i] < 0) { pinv[i] = k++ }\n    }\n    return true\n  }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csPermute (a, pinv, q, values) {\n  // a arrays\n  const avalues = a._values\n  const aindex = a._index\n  const aptr = a._ptr\n  const asize = a._size\n  const adt = a._datatype\n  // rows & columns\n  const m = asize[0]\n  const n = asize[1]\n  // c arrays\n  const cvalues = values && a._values ? [] : null\n  const cindex = [] // (aptr[n])\n  const cptr = [] // (n + 1)\n  // initialize vars\n  let nz = 0\n  // loop columns\n  for (let k = 0; k < n; k++) {\n    // column k of C is column q[k] of A\n    cptr[k] = nz\n    // apply column permutation\n    const j = q ? (q[k]) : k\n    // loop values in column j of A\n    for (let t0 = aptr[j], t1 = aptr[j + 1], t = t0; t < t1; t++) {\n      // row i of A is row pinv[i] of C\n      const r = pinv ? pinv[aindex[t]] : aindex[t]\n      // index\n      cindex[nz] = r\n      // check we need to populate values\n      if (cvalues) { cvalues[nz] = avalues[t] }\n      // increment number of nonzero elements\n      nz++\n    }\n  }\n  // finalize the last column of C\n  cptr[n] = nz\n  // return C matrix\n  return a.createSparseMatrix({\n    values: cvalues,\n    index: cindex,\n    ptr: cptr,\n    size: [m, n],\n    datatype: adt\n  })\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csEtree (a, ata) {\n  // check inputs\n  if (!a) { return null }\n  // a arrays\n  const aindex = a._index\n  const aptr = a._ptr\n  const asize = a._size\n  // rows & columns\n  const m = asize[0]\n  const n = asize[1]\n\n  // allocate result\n  const parent = [] // (n)\n\n  // allocate workspace\n  const w = [] // (n + (ata ? m : 0))\n  const ancestor = 0 // first n entries in w\n  const prev = n // last m entries (ata = true)\n\n  let i, inext\n\n  // check we are calculating A'A\n  if (ata) {\n    // initialize workspace\n    for (i = 0; i < m; i++) { w[prev + i] = -1 }\n  }\n  // loop columns\n  for (let k = 0; k < n; k++) {\n    // node k has no parent yet\n    parent[k] = -1\n    // nor does k have an ancestor\n    w[ancestor + k] = -1\n    // values in column k\n    for (let p0 = aptr[k], p1 = aptr[k + 1], p = p0; p < p1; p++) {\n      // row\n      const r = aindex[p]\n      // node\n      i = ata ? (w[prev + r]) : r\n      // traverse from i to k\n      for (; i !== -1 && i < k; i = inext) {\n        // inext = ancestor of i\n        inext = w[ancestor + i]\n        // path compression\n        w[ancestor + i] = k\n        // check no anc., parent is k\n        if (inext === -1) { parent[i] = k }\n      }\n      if (ata) { w[prev + r] = k }\n    }\n  }\n  return parent\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csTdfs } from './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 */\nexport function csPost (parent, n) {\n  // check inputs\n  if (!parent) { return null }\n  // vars\n  let k = 0\n  let j\n  // allocate result\n  const post = [] // (n)\n  // workspace, head: first n entries, next: next n entries, stack: last n entries\n  const w = [] // (3 * n)\n  const head = 0\n  const next = n\n  const stack = 2 * n\n  // initialize workspace\n  for (j = 0; j < n; j++) {\n    // empty linked lists\n    w[head + j] = -1\n  }\n  // traverse nodes in reverse order\n  for (j = n - 1; j >= 0; j--) {\n    // check j is a root\n    if (parent[j] === -1) { continue }\n    // add j to list of its parent\n    w[next + j] = w[head + parent[j]]\n    w[head + parent[j]] = j\n  }\n  // loop nodes\n  for (j = 0; j < n; j++) {\n    // skip j if it is not a root\n    if (parent[j] !== -1) { continue }\n    // depth-first search\n    k = csTdfs(j, k, w, head, next, post, stack)\n  }\n  return post\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csMarked (w, j) {\n  // check node is marked\n  return w[j] < 0\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { csFlip } from './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 */\nexport function csMark (w, j) {\n  // mark w[j]\n  w[j] = csFlip(w[j])\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csFlip } from './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 */\nexport function csUnflip (i) {\n  // flip the value if it is negative\n  return i < 0 ? csFlip(i) : i\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csMarked } from './csMarked.js'\nimport { csMark } from './csMark.js'\nimport { csUnflip } from './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 */\nexport function csDfs (j, g, top, xi, pinv) {\n  // g arrays\n  const index = g._index\n  const ptr = g._ptr\n  const size = g._size\n  // columns\n  const n = size[1]\n  // vars\n  let i, p, p2\n  // initialize head\n  let head = 0\n  // initialize the recursion stack\n  xi[0] = j\n  // loop\n  while (head >= 0) {\n    // get j from the top of the recursion stack\n    j = xi[head]\n    // apply permutation vector\n    const jnew = pinv ? pinv[j] : j\n    // check node j is marked\n    if (!csMarked(ptr, j)) {\n      // mark node j as visited\n      csMark(ptr, j)\n      // update stack (last n entries in xi)\n      xi[n + head] = jnew < 0 ? 0 : csUnflip(ptr[jnew])\n    }\n    // node j done if no unvisited neighbors\n    let done = 1\n    // examine all neighbors of j, stack (last n entries in xi)\n    for (p = xi[n + head], p2 = jnew < 0 ? 0 : csUnflip(ptr[jnew + 1]); p < p2; p++) {\n      // consider neighbor node i\n      i = index[p]\n      // check we have visited node i, skip it\n      if (csMarked(ptr, i)) { continue }\n      // pause depth-first search of node j, update stack (last n entries in xi)\n      xi[n + head] = p\n      // start dfs at node i\n      xi[++head] = i\n      // node j is not done\n      done = 0\n      // break, to start dfs(i)\n      break\n    }\n    // check depth-first search at node j is done\n    if (done) {\n      // remove j from the recursion stack\n      head--\n      // and place in the output stack\n      xi[--top] = j\n    }\n  }\n  return top\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\nimport { csReach } from './csReach.js'\nimport { factory } from '../../../utils/factory.js'\n\nconst name = 'csSpsolve'\nconst dependencies = [\n  'divideScalar',\n  'multiply',\n  'subtract'\n]\n\nexport const createCsSpsolve = /* #__PURE__ */ factory(name, dependencies, ({ divideScalar, multiply, subtract }) => {\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  return function csSpsolve (g, b, k, xi, x, pinv, lo) {\n    // g arrays\n    const gvalues = g._values\n    const gindex = g._index\n    const gptr = g._ptr\n    const gsize = g._size\n    // columns\n    const n = gsize[1]\n    // b arrays\n    const bvalues = b._values\n    const bindex = b._index\n    const bptr = b._ptr\n    // vars\n    let p, p0, p1, q\n    // xi[top..n-1] = csReach(B(:,k))\n    const top = csReach(g, b, k, xi, pinv)\n    // clear x\n    for (p = top; p < n; p++) { x[xi[p]] = 0 }\n    // scatter b\n    for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) { x[bindex[p]] = bvalues[p] }\n    // loop columns\n    for (let px = top; px < n; px++) {\n      // x array index for px\n      const j = xi[px]\n      // apply permutation vector (U x = b), j maps to column J of G\n      const J = pinv ? pinv[j] : j\n      // check column J is empty\n      if (J < 0) { continue }\n      // column value indeces in G, p0 <= p < p1\n      p0 = gptr[J]\n      p1 = gptr[J + 1]\n      // x(j) /= G(j,j)\n      x[j] = divideScalar(x[j], gvalues[lo ? p0 : (p1 - 1)])\n      // first entry L(j,j)\n      p = lo ? (p0 + 1) : p0\n      q = lo ? (p1) : (p1 - 1)\n      // loop\n      for (; p < q; p++) {\n        // row\n        const i = gindex[p]\n        // x(i) -= G(i,j) * x(j)\n        x[i] = subtract(x[i], multiply(gvalues[p], x[j]))\n      }\n    }\n    // return top of stack\n    return top\n  }\n})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { csMarked } from './csMarked.js'\nimport { csMark } from './csMark.js'\nimport { csDfs } from './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 */\nexport function csReach (g, b, k, xi, pinv) {\n  // g arrays\n  const gptr = g._ptr\n  const gsize = g._size\n  // b arrays\n  const bindex = b._index\n  const bptr = b._ptr\n  // columns\n  const n = gsize[1]\n  // vars\n  let p, p0, p1\n  // initialize top\n  let top = n\n  // loop column indeces in B\n  for (p0 = bptr[k], p1 = bptr[k + 1], p = p0; p < p1; p++) {\n    // node i\n    const i = bindex[p]\n    // check node i is marked\n    if (!csMarked(gptr, i)) {\n      // start a dfs at unmarked node i\n      top = csDfs(i, g, top, xi, pinv)\n    }\n  }\n  // loop columns from top -> n - 1\n  for (p = top; p < n; p++) {\n    // restore G\n    csMark(gptr, xi[p])\n  }\n  return top\n}\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\n\nimport { factory } from '../../../utils/factory.js'\nimport { createCsSpsolve } from './csSpsolve.js'\n\nconst name = 'csLu'\nconst dependencies = [\n  'abs',\n  'divideScalar',\n  'multiply',\n  'subtract',\n  'larger',\n  'largerEq',\n  'SparseMatrix'\n]\n\nexport const createCsLu = /* #__PURE__ */ factory(name, dependencies, ({ abs, divideScalar, multiply, subtract, larger, largerEq, SparseMatrix }) => {\n  const csSpsolve = createCsSpsolve({ divideScalar, multiply, 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  return function csLu (m, s, tol) {\n    // validate input\n    if (!m) { return null }\n    // m arrays\n    const size = m._size\n    // columns\n    const n = size[1]\n    // symbolic analysis result\n    let q\n    let lnz = 100\n    let unz = 100\n    // update symbolic analysis parameters\n    if (s) {\n      q = s.q\n      lnz = s.lnz || lnz\n      unz = s.unz || unz\n    }\n    // L arrays\n    const lvalues = [] // (lnz)\n    const lindex = [] // (lnz)\n    const lptr = [] // (n + 1)\n    // L\n    const L = new SparseMatrix({\n      values: lvalues,\n      index: lindex,\n      ptr: lptr,\n      size: [n, n]\n    })\n    // U arrays\n    const uvalues = [] // (unz)\n    const uindex = [] // (unz)\n    const uptr = [] // (n + 1)\n    // U\n    const U = new SparseMatrix({\n      values: uvalues,\n      index: uindex,\n      ptr: uptr,\n      size: [n, n]\n    })\n    // inverse of permutation vector\n    const pinv = [] // (n)\n    // vars\n    let i, p\n    // allocate arrays\n    const x = [] // (n)\n    const xi = [] // (2 * n)\n    // initialize variables\n    for (i = 0; i < n; i++) {\n      // clear workspace\n      x[i] = 0\n      // no rows pivotal yet\n      pinv[i] = -1\n      // no cols of L yet\n      lptr[i + 1] = 0\n    }\n    // reset number of nonzero elements in L and U\n    lnz = 0\n    unz = 0\n    // compute L(:,k) and U(:,k)\n    for (let k = 0; k < n; k++) {\n      // update ptr\n      lptr[k] = lnz\n      uptr[k] = unz\n      // apply column permutations if needed\n      const col = q ? q[k] : k\n      // solve triangular system, x = L\\A(:,col)\n      const top = csSpsolve(L, m, col, xi, x, pinv, 1)\n      // find pivot\n      let ipiv = -1\n      let a = -1\n      // loop xi[] from top -> n\n      for (p = top; p < n; p++) {\n        // x[i] is nonzero\n        i = xi[p]\n        // check row i is not yet pivotal\n        if (pinv[i] < 0) {\n          // absolute value of x[i]\n          const xabs = abs(x[i])\n          // check absoulte value is greater than pivot value\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      }\n      // validate we found a valid pivot\n      if (ipiv === -1 || a <= 0) { return null }\n      // update actual pivot column, give preference to diagonal value\n      if (pinv[col] < 0 && largerEq(abs(x[col]), multiply(a, tol))) { ipiv = col }\n      // the chosen pivot\n      const pivot = x[ipiv]\n      // last entry in U(:,k) is U(k,k)\n      uindex[unz] = k\n      uvalues[unz++] = pivot\n      // ipiv is the kth pivot row\n      pinv[ipiv] = k\n      // first entry in L(:,k) is L(k,k) = 1\n      lindex[lnz] = ipiv\n      lvalues[lnz++] = 1\n      // L(k+1:n,k) = x / pivot\n      for (p = top; p < n; p++) {\n        // row\n        i = xi[p]\n        // check x(i) is an entry in L(:,k)\n        if (pinv[i] < 0) {\n          // save unpermuted row in L\n          lindex[lnz] = i\n          // scale pivot column\n          lvalues[lnz++] = divideScalar(x[i], pivot)\n        }\n        // x[0..n-1] = 0 for next k\n        x[i] = 0\n      }\n    }\n    // update ptr\n    lptr[n] = lnz\n    uptr[n] = unz\n    // fix row indices of L for final pinv\n    for (p = 0; p < lnz; p++) { lindex[p] = pinv[lindex[p]] }\n    // trim arrays\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)\n    // return LU factor\n    return { L, U, pinv }\n  }\n})\n","import { isInteger } from '../../../utils/number.js'\nimport { factory } from '../../../utils/factory.js'\nimport { createCsSqr } from '../sparse/csSqr.js'\nimport { createCsLu } from '../sparse/csLu.js'\n\nconst name = 'slu'\nconst dependencies = [\n  'typed',\n  'abs',\n  'add',\n  'multiply',\n  'transpose',\n  'divideScalar',\n  'subtract',\n  'larger',\n  'largerEq',\n  'SparseMatrix'\n]\n\nexport const createSlu = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, multiply, transpose, divideScalar, subtract, larger, largerEq, SparseMatrix }) => {\n  const csSqr = createCsSqr({ add, multiply, transpose })\n  const csLu = createCsLu({ abs, divideScalar, multiply, subtract, larger, largerEq, 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  return typed(name, {\n\n    'SparseMatrix, number, number': function (a, order, threshold) {\n      // verify order\n      if (!isInteger(order) || order < 0 || order > 3) { throw new Error('Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]') }\n      // verify threshold\n      if (threshold < 0 || threshold > 1) { throw new Error('Partial pivoting threshold must be a number from 0 to 1') }\n\n      // perform symbolic ordering and analysis\n      const s = csSqr(order, a, false)\n\n      // perform lu decomposition\n      const f = csLu(a, s, threshold)\n\n      // return decomposition\n      return {\n        L: f.L,\n        U: f.U,\n        p: f.pinv,\n        q: s.q,\n        toString: function () {\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})\n","// Copyright (c) 2006-2024, Timothy A. Davis, All Rights Reserved.\n// SPDX-License-Identifier: LGPL-2.1+\n// https://github.com/DrTimothyAldenDavis/SuiteSparse/tree/dev/CSparse/Source\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 */\nexport function csIpvec (p, b) {\n  // vars\n  let k\n  const n = b.length\n  const x = []\n  // check permutation vector was provided, p = null denotes identity\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  return x\n}\n","import { isArray, isMatrix } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\nimport { createSolveValidation } from './utils/solveValidation.js'\nimport { csIpvec } from '../sparse/csIpvec.js'\n\nconst name = 'lusolve'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'lup',\n  'slu',\n  'usolve',\n  'lsolve',\n  'DenseMatrix'\n]\n\nexport const createLusolve = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, lup, slu, usolve, lsolve, DenseMatrix }) => {\n  const solveValidation = createSolveValidation({ 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  return typed(name, {\n\n    'Array, Array | Matrix': function (a, b) {\n      a = matrix(a)\n      const d = lup(a)\n      const x = _lusolve(d.L, d.U, d.p, null, b)\n      return x.valueOf()\n    },\n\n    'DenseMatrix, Array | Matrix': function (a, b) {\n      const d = lup(a)\n      return _lusolve(d.L, d.U, d.p, null, b)\n    },\n\n    'SparseMatrix, Array | Matrix': function (a, b) {\n      const d = lup(a)\n      return _lusolve(d.L, d.U, d.p, null, b)\n    },\n\n    'SparseMatrix, Array | Matrix, number, number': function (a, b, order, threshold) {\n      const d = slu(a, order, threshold)\n      return _lusolve(d.L, d.U, d.p, d.q, b)\n    },\n\n    'Object, Array | Matrix': function (d, b) {\n      return _lusolve(d.L, d.U, d.p, d.q, b)\n    }\n  })\n\n  function _toMatrix (a) {\n    if (isMatrix(a)) { return a }\n    if (isArray(a)) { return matrix(a) }\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)\n\n    // apply row permutations if needed (b is a DenseMatrix)\n    if (p) {\n      b = solveValidation(l, b, true)\n      b._data = csIpvec(p, b._data)\n    }\n\n    // use forward substitution to resolve L * y = b\n    const y = lsolve(l, b)\n    // use backward substitution to resolve U * x = y\n    const x = usolve(u, y)\n\n    // apply column permutations if needed (x is a DenseMatrix)\n    if (q) { x._data = csIpvec(q, x._data) }\n\n    return x\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'polynomialRoot'\nconst dependencies = [\n  'typed',\n  'isZero',\n  'equalScalar',\n  'add',\n  'subtract',\n  'multiply',\n  'divide',\n  'sqrt',\n  'unaryMinus',\n  'cbrt',\n  'typeOf',\n  'im',\n  're'\n]\n\nexport const createPolynomialRoot = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  isZero,\n  equalScalar,\n  add,\n  subtract,\n  multiply,\n  divide,\n  sqrt,\n  unaryMinus,\n  cbrt,\n  typeOf,\n  im,\n  re\n}) => {\n  /**\n   * Finds the numerical values of the distinct roots of a polynomial with real or complex coefficients.\n   * Currently operates only on linear, quadratic, and cubic polynomials using the standard\n   * formulas for the roots.\n   *\n   * Syntax:\n   *\n   *     math.polynomialRoot(constant, linearCoeff, quadraticCoeff, cubicCoeff)\n   *\n   * Examples:\n   *     // linear\n   *     math.polynomialRoot(6, 3)                                        // [-2]\n   *     math.polynomialRoot(math.complex(6,3), 3)                        // [-2 - i]\n   *     math.polynomialRoot(math.complex(6,3), math.complex(2,1))        // [-3 + 0i]\n   *     // quadratic\n   *     math.polynomialRoot(2, -3, 1)                                    // [2, 1]\n   *     math.polynomialRoot(8, 8, 2)                                     // [-2]\n   *     math.polynomialRoot(-2, 0, 1)                                    // [1.4142135623730951, -1.4142135623730951]\n   *     math.polynomialRoot(2, -2, 1)                                    // [1 + i, 1 - i]\n   *     math.polynomialRoot(math.complex(1,3), math.complex(-3, -2), 1)  // [2 + i, 1 + i]\n   *     // cubic\n   *     math.polynomialRoot(-6, 11, -6, 1)                               // [1, 3, 2]\n   *     math.polynomialRoot(-8, 0, 0, 1)                                 // [-1 - 1.7320508075688774i, 2, -1 + 1.7320508075688774i]\n   *     math.polynomialRoot(0, 8, 8, 2)                                  // [0, -2]\n   *     math.polynomialRoot(1, 1, 1, 1)                                  // [-1 + 0i, 0 - i, 0 + i]\n   *\n   * See also:\n   *     cbrt, sqrt\n   *\n   * @param {... number | Complex} coeffs\n   *     The coefficients of the polynomial, starting with with the constant coefficent, followed\n   *     by the linear coefficient and subsequent coefficients of increasing powers.\n   * @return {Array} The distinct roots of the polynomial\n   */\n\n  return typed(name, {\n    'number|Complex, ...number|Complex': (constant, restCoeffs) => {\n      const coeffs = [constant, ...restCoeffs]\n      while (coeffs.length > 0 && isZero(coeffs[coeffs.length - 1])) {\n        coeffs.pop()\n      }\n      if (coeffs.length < 2) {\n        throw new RangeError(\n          `Polynomial [${constant}, ${restCoeffs}] must have a non-zero non-constant coefficient`)\n      }\n      switch (coeffs.length) {\n        case 2: // linear\n          return [unaryMinus(divide(coeffs[0], coeffs[1]))]\n        case 3: { // quadratic\n          const [c, b, a] = coeffs\n          const denom = multiply(2, a)\n          const d1 = multiply(b, b)\n          const d2 = multiply(4, a, c)\n          if (equalScalar(d1, d2)) return [divide(unaryMinus(b), denom)]\n          const discriminant = sqrt(subtract(d1, d2))\n          return [\n            divide(subtract(discriminant, b), denom),\n            divide(subtract(unaryMinus(discriminant), b), denom)\n          ]\n        }\n        case 4: { // cubic, cf. https://en.wikipedia.org/wiki/Cubic_equation\n          const [d, c, b, a] = coeffs\n          const denom = unaryMinus(multiply(3, a))\n          const D0_1 = multiply(b, b)\n          const D0_2 = multiply(3, a, c)\n          const D1_1 = add(multiply(2, b, b, b), multiply(27, a, a, d))\n          const D1_2 = multiply(9, a, b, c)\n          if (equalScalar(D0_1, D0_2) && equalScalar(D1_1, D1_2)) {\n            return [divide(b, denom)]\n          }\n          const Delta0 = subtract(D0_1, D0_2)\n          const Delta1 = subtract(D1_1, D1_2)\n          const discriminant1 = add(\n            multiply(18, a, b, c, d), multiply(b, b, c, c))\n          const discriminant2 = add(\n            multiply(4, b, b, b, d),\n            multiply(4, a, c, c, c),\n            multiply(27, a, a, d, d))\n          if (equalScalar(discriminant1, discriminant2)) {\n            return [\n              divide(\n                subtract(\n                  multiply(4, a, b, c),\n                  add(multiply(9, a, a, d), multiply(b, b, b))),\n                multiply(a, Delta0)), // simple root\n              divide(\n                subtract(multiply(9, a, d), multiply(b, c)),\n                multiply(2, Delta0)) // double root\n            ]\n          }\n          // OK, we have three distinct roots\n          let Ccubed\n          if (equalScalar(D0_1, D0_2)) {\n            Ccubed = Delta1\n          } else {\n            Ccubed = divide(\n              add(\n                Delta1,\n                sqrt(subtract(\n                  multiply(Delta1, Delta1), multiply(4, Delta0, Delta0, Delta0)))\n              ),\n              2)\n          }\n          const allRoots = true\n          const rawRoots = cbrt(Ccubed, allRoots).toArray().map(\n            C => divide(add(b, C, divide(Delta0, C)), denom))\n          return rawRoots.map(r => {\n            if (typeOf(r) === 'Complex' && equalScalar(re(r), re(r) + im(r))) {\n              return re(r)\n            }\n            return r\n          })\n        }\n        default:\n          throw new RangeError(`only implemented for cubic or lower-order polynomials, not ${coeffs}`)\n      }\n    }\n  })\n})\n","import { isHelp } from '../utils/is.js'\nimport { clone } from '../utils/object.js'\nimport { format } from '../utils/string.js'\nimport { factory } from '../utils/factory.js'\n\nconst name = 'Help'\nconst dependencies = ['evaluate']\n\nexport const createHelpClass = /* #__PURE__ */ factory(name, dependencies, ({ evaluate }) => {\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\n    this.doc = doc\n  }\n\n  /**\n   * Attach type information\n   */\n  Help.prototype.type = 'Help'\n  Help.prototype.isHelp = true\n\n  /**\n   * Generate a string representation of the Help object\n   * @return {string} Returns a string\n   * @private\n   */\n  Help.prototype.toString = function () {\n    const doc = this.doc || {}\n    let desc = '\\n'\n\n    if (doc.name) {\n      desc += 'Name: ' + doc.name + '\\n\\n'\n    }\n    if (doc.category) {\n      desc += 'Category: ' + doc.category + '\\n\\n'\n    }\n    if (doc.description) {\n      desc += 'Description:\\n    ' + doc.description + '\\n\\n'\n    }\n    if (doc.syntax) {\n      desc += 'Syntax:\\n    ' + doc.syntax.join('\\n    ') + '\\n\\n'\n    }\n    if (doc.examples) {\n      desc += 'Examples:\\n'\n\n      // after evaluating the examples, we restore config in case the examples\n      // did change the config.\n      let configChanged = false\n      const originalConfig = evaluate('config()')\n\n      const scope = {\n        config: (newConfig) => {\n          configChanged = true\n          return evaluate('config(newConfig)', { newConfig })\n        }\n      }\n\n      for (let i = 0; i < doc.examples.length; i++) {\n        const expr = doc.examples[i]\n        desc += '    ' + expr + '\\n'\n\n        let res\n        try {\n          // note: res can be undefined when `expr` is an empty string\n          res = evaluate(expr, scope)\n        } catch (e) {\n          res = e\n        }\n        if (res !== undefined && !isHelp(res)) {\n          desc += '        ' + format(res, { precision: 14 }) + '\\n'\n        }\n      }\n      desc += '\\n'\n\n      if (configChanged) {\n        evaluate('config(originalConfig)', { originalConfig })\n      }\n    }\n    if (doc.mayThrow && doc.mayThrow.length) {\n      desc += 'Throws: ' + doc.mayThrow.join(', ') + '\\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  /**\n   * Export the help object to JSON\n   */\n  Help.prototype.toJSON = function () {\n    const obj = clone(this.doc)\n    obj.mathjs = 'Help'\n    return obj\n  }\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  Help.fromJSON = function (json) {\n    const doc = {}\n\n    Object.keys(json)\n      .filter(prop => prop !== 'mathjs')\n      .forEach(prop => {\n        doc[prop] = json[prop]\n      })\n\n    return new Help(doc)\n  }\n\n  /**\n   * Returns a string representation of the Help object\n   */\n  Help.prototype.valueOf = Help.prototype.toString\n\n  return Help\n}, { isClass: true })\n","import { isChain } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { hasOwnProperty, lazy } from '../../utils/object.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'Chain'\nconst dependencies = ['?on', 'math', 'typed']\n\nexport const createChainClass = /* #__PURE__ */ factory(name, dependencies, ({ on, math, typed }) => {\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 (isChain(value)) {\n      this.value = value.value\n    } else {\n      this.value = value\n    }\n  }\n\n  /**\n   * Attach type information\n   */\n  Chain.prototype.type = 'Chain'\n  Chain.prototype.isChain = true\n\n  /**\n   * Close the chain. Returns the final value.\n   * Does the same as method valueOf()\n   * @returns {*} value\n   */\n  Chain.prototype.done = function () {\n    return this.value\n  }\n\n  /**\n   * Close the chain. Returns the final value.\n   * Does the same as method done()\n   * @returns {*} value\n   */\n  Chain.prototype.valueOf = function () {\n    return this.value\n  }\n\n  /**\n   * Get a string representation of the value in the chain\n   * @returns {string}\n   */\n  Chain.prototype.toString = function () {\n    return format(this.value)\n  }\n\n  /**\n   * Get a JSON representation of the chain\n   * @returns {Object}\n   */\n  Chain.prototype.toJSON = function () {\n    return {\n      mathjs: 'Chain',\n      value: this.value\n    }\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  Chain.fromJSON = function (json) {\n    return new Chain(json.value)\n  }\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  function createProxy (name, fn) {\n    if (typeof fn === 'function') {\n      Chain.prototype[name] = chainify(fn)\n    }\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  function createLazyProxy (name, resolver) {\n    lazy(Chain.prototype, name, function outerResolver () {\n      const fn = resolver()\n      if (typeof fn === 'function') {\n        return chainify(fn)\n      }\n\n      return undefined // if not a function, ignore\n    })\n  }\n\n  /**\n   * Make a function chainable\n   * @param {function} fn\n   * @return {Function} chain function\n   * @private\n   */\n  function chainify (fn) {\n    return function () {\n      // Here, `this` will be the context of a Chain instance\n      if (arguments.length === 0) {\n        return new Chain(fn(this.value))\n      }\n      const args = [this.value]\n      for (let i = 0; i < arguments.length; i++) {\n        args[i + 1] = arguments[i]\n      }\n      if (typed.isTypedFunction(fn)) {\n        const sigObject = typed.resolve(fn, args)\n        // We want to detect if a rest parameter has matched across the\n        // value in the chain and the current arguments of this call.\n        // That is the case if and only if the matching signature has\n        // exactly one parameter (which then must be a rest parameter\n        // as it is matching at least two actual arguments).\n        if (sigObject.params.length === 1) {\n          throw new Error('chain function ' + fn.name + ' cannot match rest parameter between chain value and additional arguments.')\n        }\n        return new Chain(sigObject.implementation.apply(fn, args))\n      }\n      return new Chain(fn.apply(fn, args))\n    }\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  Chain.createProxy = function (arg0, arg1) {\n    if (typeof arg0 === 'string') {\n      // createProxy(name, value)\n      createProxy(arg0, arg1)\n    } else {\n      // createProxy(values)\n      for (const name in arg0) {\n        if (hasOwnProperty(arg0, name) && excludedNames[name] === undefined) {\n          createLazyProxy(name, () => arg0[name])\n        }\n      }\n    }\n  }\n\n  const 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\n  // create proxy for everything that is in math.js\n  Chain.createProxy(math)\n\n  // register on the import event, automatically add a proxy for every imported function.\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}, { isClass: true })\n","export const eDocs = {\n  name: 'e',\n  category: 'Constants',\n  syntax: [\n    'e'\n  ],\n  description: 'Euler\\'s number, the base of the natural logarithm. Approximately equal to 2.71828',\n  examples: [\n    'e',\n    'e ^ 2',\n    'exp(2)',\n    'log(e)'\n  ],\n  seealso: ['exp']\n}\n","export const piDocs = {\n  name: 'pi',\n  category: 'Constants',\n  syntax: [\n    'pi'\n  ],\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: [\n    'pi',\n    'sin(pi/2)'\n  ],\n  seealso: ['tau']\n}\n","import { eDocs } from './constants/e.js'\nimport { falseDocs } from './constants/false.js'\nimport { iDocs } from './constants/i.js'\nimport { InfinityDocs } from './constants/Infinity.js'\nimport { LN10Docs } from './constants/LN10.js'\nimport { LN2Docs } from './constants/LN2.js'\nimport { LOG10EDocs } from './constants/LOG10E.js'\nimport { LOG2EDocs } from './constants/LOG2E.js'\nimport { NaNDocs } from './constants/NaN.js'\nimport { nullDocs } from './constants/null.js'\nimport { phiDocs } from './constants/phi.js'\nimport { piDocs } from './constants/pi.js'\nimport { SQRT12Docs } from './constants/SQRT1_2.js'\nimport { SQRT2Docs } from './constants/SQRT2.js'\nimport { tauDocs } from './constants/tau.js'\nimport { trueDocs } from './constants/true.js'\nimport { versionDocs } from './constants/version.js'\nimport { bignumberDocs } from './construction/bignumber.js'\nimport { bigintDocs } from './construction/bigint.js'\nimport { booleanDocs } from './construction/boolean.js'\nimport { complexDocs } from './construction/complex.js'\nimport { createUnitDocs } from './construction/createUnit.js'\nimport { fractionDocs } from './construction/fraction.js'\nimport { indexDocs } from './construction/index.js'\nimport { matrixDocs } from './construction/matrix.js'\nimport { numberDocs } from './construction/number.js'\nimport { sparseDocs } from './construction/sparse.js'\nimport { splitUnitDocs } from './construction/splitUnit.js'\nimport { stringDocs } from './construction/string.js'\nimport { unitDocs } from './construction/unit.js'\nimport { configDocs } from './core/config.js'\nimport { importDocs } from './core/import.js'\nimport { typedDocs } from './core/typed.js'\nimport { derivativeDocs } from './function/algebra/derivative.js'\nimport { leafCountDocs } from './function/algebra/leafCount.js'\nimport { lsolveDocs } from './function/algebra/lsolve.js'\nimport { lsolveAllDocs } from './function/algebra/lsolveAll.js'\nimport { lupDocs } from './function/algebra/lup.js'\nimport { lusolveDocs } from './function/algebra/lusolve.js'\nimport { polynomialRootDocs } from './function/algebra/polynomialRoot.js'\nimport { qrDocs } from './function/algebra/qr.js'\nimport { rationalizeDocs } from './function/algebra/rationalize.js'\nimport { resolveDocs } from './function/algebra/resolve.js'\nimport { simplifyDocs } from './function/algebra/simplify.js'\nimport { simplifyConstantDocs } from './function/algebra/simplifyConstant.js'\nimport { simplifyCoreDocs } from './function/algebra/simplifyCore.js'\nimport { sluDocs } from './function/algebra/slu.js'\nimport { symbolicEqualDocs } from './function/algebra/symbolicEqual.js'\nimport { usolveDocs } from './function/algebra/usolve.js'\nimport { usolveAllDocs } from './function/algebra/usolveAll.js'\nimport { absDocs } from './function/arithmetic/abs.js'\nimport { addDocs } from './function/arithmetic/add.js'\nimport { cbrtDocs } from './function/arithmetic/cbrt.js'\nimport { ceilDocs } from './function/arithmetic/ceil.js'\nimport { cubeDocs } from './function/arithmetic/cube.js'\nimport { divideDocs } from './function/arithmetic/divide.js'\nimport { dotDivideDocs } from './function/arithmetic/dotDivide.js'\nimport { dotMultiplyDocs } from './function/arithmetic/dotMultiply.js'\nimport { dotPowDocs } from './function/arithmetic/dotPow.js'\nimport { expDocs } from './function/arithmetic/exp.js'\nimport { expmDocs } from './function/arithmetic/expm.js'\nimport { expm1Docs } from './function/arithmetic/expm1.js'\nimport { fixDocs } from './function/arithmetic/fix.js'\nimport { floorDocs } from './function/arithmetic/floor.js'\nimport { gcdDocs } from './function/arithmetic/gcd.js'\nimport { hypotDocs } from './function/arithmetic/hypot.js'\nimport { invmodDocs } from './function/arithmetic/invmod.js'\nimport { lcmDocs } from './function/arithmetic/lcm.js'\nimport { logDocs } from './function/arithmetic/log.js'\nimport { log10Docs } from './function/arithmetic/log10.js'\nimport { log1pDocs } from './function/arithmetic/log1p.js'\nimport { log2Docs } from './function/arithmetic/log2.js'\nimport { modDocs } from './function/arithmetic/mod.js'\nimport { multiplyDocs } from './function/arithmetic/multiply.js'\nimport { normDocs } from './function/arithmetic/norm.js'\nimport { nthRootDocs } from './function/arithmetic/nthRoot.js'\nimport { nthRootsDocs } from './function/arithmetic/nthRoots.js'\nimport { powDocs } from './function/arithmetic/pow.js'\nimport { roundDocs } from './function/arithmetic/round.js'\nimport { signDocs } from './function/arithmetic/sign.js'\nimport { sqrtDocs } from './function/arithmetic/sqrt.js'\nimport { sqrtmDocs } from './function/arithmetic/sqrtm.js'\nimport { sylvesterDocs } from './function/algebra/sylvester.js'\nimport { schurDocs } from './function/algebra/schur.js'\nimport { lyapDocs } from './function/algebra/lyap.js'\nimport { squareDocs } from './function/arithmetic/square.js'\nimport { subtractDocs } from './function/arithmetic/subtract.js'\nimport { unaryMinusDocs } from './function/arithmetic/unaryMinus.js'\nimport { unaryPlusDocs } from './function/arithmetic/unaryPlus.js'\nimport { xgcdDocs } from './function/arithmetic/xgcd.js'\nimport { bitAndDocs } from './function/bitwise/bitAnd.js'\nimport { bitNotDocs } from './function/bitwise/bitNot.js'\nimport { bitOrDocs } from './function/bitwise/bitOr.js'\nimport { bitXorDocs } from './function/bitwise/bitXor.js'\nimport { leftShiftDocs } from './function/bitwise/leftShift.js'\nimport { rightArithShiftDocs } from './function/bitwise/rightArithShift.js'\nimport { rightLogShiftDocs } from './function/bitwise/rightLogShift.js'\nimport { bellNumbersDocs } from './function/combinatorics/bellNumbers.js'\nimport { catalanDocs } from './function/combinatorics/catalan.js'\nimport { compositionDocs } from './function/combinatorics/composition.js'\nimport { stirlingS2Docs } from './function/combinatorics/stirlingS2.js'\nimport { argDocs } from './function/complex/arg.js'\nimport { conjDocs } from './function/complex/conj.js'\nimport { imDocs } from './function/complex/im.js'\nimport { reDocs } from './function/complex/re.js'\nimport { evaluateDocs } from './function/expression/evaluate.js'\nimport { helpDocs } from './function/expression/help.js'\nimport { distanceDocs } from './function/geometry/distance.js'\nimport { intersectDocs } from './function/geometry/intersect.js'\nimport { andDocs } from './function/logical/and.js'\nimport { notDocs } from './function/logical/not.js'\nimport { orDocs } from './function/logical/or.js'\nimport { xorDocs } from './function/logical/xor.js'\nimport { columnDocs } from './function/matrix/column.js'\nimport { concatDocs } from './function/matrix/concat.js'\nimport { countDocs } from './function/matrix/count.js'\nimport { crossDocs } from './function/matrix/cross.js'\nimport { ctransposeDocs } from './function/matrix/ctranspose.js'\nimport { detDocs } from './function/matrix/det.js'\nimport { diagDocs } from './function/matrix/diag.js'\nimport { diffDocs } from './function/matrix/diff.js'\nimport { dotDocs } from './function/matrix/dot.js'\nimport { eigsDocs } from './function/matrix/eigs.js'\nimport { filterDocs } from './function/matrix/filter.js'\nimport { flattenDocs } from './function/matrix/flatten.js'\nimport { forEachDocs } from './function/matrix/forEach.js'\nimport { getMatrixDataTypeDocs } from './function/matrix/getMatrixDataType.js'\nimport { identityDocs } from './function/matrix/identity.js'\nimport { invDocs } from './function/matrix/inv.js'\nimport { pinvDocs } from './function/matrix/pinv.js'\nimport { kronDocs } from './function/matrix/kron.js'\nimport { mapDocs } from './function/matrix/map.js'\nimport { matrixFromColumnsDocs } from './function/matrix/matrixFromColumns.js'\nimport { matrixFromFunctionDocs } from './function/matrix/matrixFromFunction.js'\nimport { matrixFromRowsDocs } from './function/matrix/matrixFromRows.js'\nimport { onesDocs } from './function/matrix/ones.js'\nimport { partitionSelectDocs } from './function/matrix/partitionSelect.js'\nimport { rangeDocs } from './function/matrix/range.js'\nimport { reshapeDocs } from './function/matrix/reshape.js'\nimport { resizeDocs } from './function/matrix/resize.js'\nimport { rotateDocs } from './function/matrix/rotate.js'\nimport { rotationMatrixDocs } from './function/matrix/rotationMatrix.js'\nimport { rowDocs } from './function/matrix/row.js'\nimport { sizeDocs } from './function/matrix/size.js'\nimport { sortDocs } from './function/matrix/sort.js'\nimport { squeezeDocs } from './function/matrix/squeeze.js'\nimport { subsetDocs } from './function/matrix/subset.js'\nimport { traceDocs } from './function/matrix/trace.js'\nimport { transposeDocs } from './function/matrix/transpose.js'\nimport { zerosDocs } from './function/matrix/zeros.js'\nimport { fftDocs } from './function/matrix/fft.js'\nimport { ifftDocs } from './function/matrix/ifft.js'\nimport { combinationsDocs } from './function/probability/combinations.js'\nimport { combinationsWithRepDocs } from './function/probability/combinationsWithRep.js'\nimport { factorialDocs } from './function/probability/factorial.js'\nimport { gammaDocs } from './function/probability/gamma.js'\nimport { lgammaDocs } from './function/probability/lgamma.js'\nimport { kldivergenceDocs } from './function/probability/kldivergence.js'\nimport { multinomialDocs } from './function/probability/multinomial.js'\nimport { permutationsDocs } from './function/probability/permutations.js'\nimport { pickRandomDocs } from './function/probability/pickRandom.js'\nimport { randomDocs } from './function/probability/random.js'\nimport { randomIntDocs } from './function/probability/randomInt.js'\nimport { compareDocs } from './function/relational/compare.js'\nimport { compareNaturalDocs } from './function/relational/compareNatural.js'\nimport { compareTextDocs } from './function/relational/compareText.js'\nimport { deepEqualDocs } from './function/relational/deepEqual.js'\nimport { equalDocs } from './function/relational/equal.js'\nimport { equalTextDocs } from './function/relational/equalText.js'\nimport { largerDocs } from './function/relational/larger.js'\nimport { largerEqDocs } from './function/relational/largerEq.js'\nimport { smallerDocs } from './function/relational/smaller.js'\nimport { smallerEqDocs } from './function/relational/smallerEq.js'\nimport { unequalDocs } from './function/relational/unequal.js'\nimport { setCartesianDocs } from './function/set/setCartesian.js'\nimport { setDifferenceDocs } from './function/set/setDifference.js'\nimport { setDistinctDocs } from './function/set/setDistinct.js'\nimport { setIntersectDocs } from './function/set/setIntersect.js'\nimport { setIsSubsetDocs } from './function/set/setIsSubset.js'\nimport { setMultiplicityDocs } from './function/set/setMultiplicity.js'\nimport { setPowersetDocs } from './function/set/setPowerset.js'\nimport { setSizeDocs } from './function/set/setSize.js'\nimport { setSymDifferenceDocs } from './function/set/setSymDifference.js'\nimport { setUnionDocs } from './function/set/setUnion.js'\nimport { zpk2tfDocs } from './function/signal/zpk2tf.js'\nimport { freqzDocs } from './function/signal/freqz.js'\nimport { erfDocs } from './function/special/erf.js'\nimport { zetaDocs } from './function/special/zeta.js'\nimport { madDocs } from './function/statistics/mad.js'\nimport { maxDocs } from './function/statistics/max.js'\nimport { meanDocs } from './function/statistics/mean.js'\nimport { medianDocs } from './function/statistics/median.js'\nimport { minDocs } from './function/statistics/min.js'\nimport { modeDocs } from './function/statistics/mode.js'\nimport { prodDocs } from './function/statistics/prod.js'\nimport { quantileSeqDocs } from './function/statistics/quantileSeq.js'\nimport { stdDocs } from './function/statistics/std.js'\nimport { cumSumDocs } from './function/statistics/cumsum.js'\nimport { sumDocs } from './function/statistics/sum.js'\nimport { varianceDocs } from './function/statistics/variance.js'\nimport { corrDocs } from './function/statistics/corr.js'\nimport { acosDocs } from './function/trigonometry/acos.js'\nimport { acoshDocs } from './function/trigonometry/acosh.js'\nimport { acotDocs } from './function/trigonometry/acot.js'\nimport { acothDocs } from './function/trigonometry/acoth.js'\nimport { acscDocs } from './function/trigonometry/acsc.js'\nimport { acschDocs } from './function/trigonometry/acsch.js'\nimport { asecDocs } from './function/trigonometry/asec.js'\nimport { asechDocs } from './function/trigonometry/asech.js'\nimport { asinDocs } from './function/trigonometry/asin.js'\nimport { asinhDocs } from './function/trigonometry/asinh.js'\nimport { atanDocs } from './function/trigonometry/atan.js'\nimport { atan2Docs } from './function/trigonometry/atan2.js'\nimport { atanhDocs } from './function/trigonometry/atanh.js'\nimport { cosDocs } from './function/trigonometry/cos.js'\nimport { coshDocs } from './function/trigonometry/cosh.js'\nimport { cotDocs } from './function/trigonometry/cot.js'\nimport { cothDocs } from './function/trigonometry/coth.js'\nimport { cscDocs } from './function/trigonometry/csc.js'\nimport { cschDocs } from './function/trigonometry/csch.js'\nimport { secDocs } from './function/trigonometry/sec.js'\nimport { sechDocs } from './function/trigonometry/sech.js'\nimport { sinDocs } from './function/trigonometry/sin.js'\nimport { sinhDocs } from './function/trigonometry/sinh.js'\nimport { tanDocs } from './function/trigonometry/tan.js'\nimport { tanhDocs } from './function/trigonometry/tanh.js'\nimport { toDocs } from './function/units/to.js'\nimport { binDocs } from './function/utils/bin.js'\nimport { cloneDocs } from './function/utils/clone.js'\nimport { formatDocs } from './function/utils/format.js'\nimport { hasNumericValueDocs } from './function/utils/hasNumericValue.js'\nimport { hexDocs } from './function/utils/hex.js'\nimport { isIntegerDocs } from './function/utils/isInteger.js'\nimport { isNaNDocs } from './function/utils/isNaN.js'\nimport { isNegativeDocs } from './function/utils/isNegative.js'\nimport { isNumericDocs } from './function/utils/isNumeric.js'\nimport { isPositiveDocs } from './function/utils/isPositive.js'\nimport { isPrimeDocs } from './function/utils/isPrime.js'\nimport { isZeroDocs } from './function/utils/isZero.js'\nimport { numericDocs } from './function/utils/numeric.js'\nimport { octDocs } from './function/utils/oct.js'\nimport { printDocs } from './function/utils/print.js'\nimport { typeOfDocs } from './function/utils/typeOf.js'\nimport { solveODEDocs } from './function/numeric/solveODE.js'\n\nexport const embeddedDocs = {\n\n  // construction functions\n  bignumber: bignumberDocs,\n  bigint: bigintDocs,\n  boolean: booleanDocs,\n  complex: complexDocs,\n  createUnit: createUnitDocs,\n  fraction: fractionDocs,\n  index: indexDocs,\n  matrix: matrixDocs,\n  number: numberDocs,\n  sparse: sparseDocs,\n  splitUnit: splitUnitDocs,\n  string: stringDocs,\n  unit: unitDocs,\n\n  // constants\n  e: eDocs,\n  E: eDocs,\n  false: falseDocs,\n  i: iDocs,\n  Infinity: InfinityDocs,\n  LN2: LN2Docs,\n  LN10: LN10Docs,\n  LOG2E: LOG2EDocs,\n  LOG10E: LOG10EDocs,\n  NaN: NaNDocs,\n  null: nullDocs,\n  pi: piDocs,\n  PI: piDocs,\n  phi: phiDocs,\n  SQRT1_2: SQRT12Docs,\n  SQRT2: SQRT2Docs,\n  tau: tauDocs,\n  true: trueDocs,\n  version: versionDocs,\n\n  // physical constants\n  // TODO: more detailed docs for physical constants\n  speedOfLight: { description: 'Speed of light in vacuum', examples: ['speedOfLight'] },\n  gravitationConstant: { description: 'Newtonian constant of gravitation', examples: ['gravitationConstant'] },\n  planckConstant: { description: 'Planck constant', examples: ['planckConstant'] },\n  reducedPlanckConstant: { description: 'Reduced Planck constant', examples: ['reducedPlanckConstant'] },\n\n  magneticConstant: { description: 'Magnetic constant (vacuum permeability)', examples: ['magneticConstant'] },\n  electricConstant: { description: 'Electric constant (vacuum permeability)', examples: ['electricConstant'] },\n  vacuumImpedance: { description: 'Characteristic impedance of vacuum', examples: ['vacuumImpedance'] },\n  coulomb: { description: 'Coulomb\\'s constant', examples: ['coulomb'] },\n  elementaryCharge: { description: 'Elementary charge', examples: ['elementaryCharge'] },\n  bohrMagneton: { description: 'Borh magneton', examples: ['bohrMagneton'] },\n  conductanceQuantum: { description: 'Conductance quantum', examples: ['conductanceQuantum'] },\n  inverseConductanceQuantum: { description: 'Inverse conductance quantum', examples: ['inverseConductanceQuantum'] },\n  // josephson: {description: 'Josephson constant', examples: ['josephson']},\n  magneticFluxQuantum: { description: 'Magnetic flux quantum', examples: ['magneticFluxQuantum'] },\n  nuclearMagneton: { description: 'Nuclear magneton', examples: ['nuclearMagneton'] },\n  klitzing: { description: 'Von Klitzing constant', examples: ['klitzing'] },\n\n  bohrRadius: { description: 'Borh radius', examples: ['bohrRadius'] },\n  classicalElectronRadius: { description: 'Classical electron radius', examples: ['classicalElectronRadius'] },\n  electronMass: { description: 'Electron mass', examples: ['electronMass'] },\n  fermiCoupling: { description: 'Fermi coupling constant', examples: ['fermiCoupling'] },\n  fineStructure: { description: 'Fine-structure constant', examples: ['fineStructure'] },\n  hartreeEnergy: { description: 'Hartree energy', examples: ['hartreeEnergy'] },\n  protonMass: { description: 'Proton mass', examples: ['protonMass'] },\n  deuteronMass: { description: 'Deuteron Mass', examples: ['deuteronMass'] },\n  neutronMass: { description: 'Neutron mass', examples: ['neutronMass'] },\n  quantumOfCirculation: { description: 'Quantum of circulation', examples: ['quantumOfCirculation'] },\n  rydberg: { description: 'Rydberg constant', examples: ['rydberg'] },\n  thomsonCrossSection: { description: 'Thomson cross section', examples: ['thomsonCrossSection'] },\n  weakMixingAngle: { description: 'Weak mixing angle', examples: ['weakMixingAngle'] },\n  efimovFactor: { description: 'Efimov factor', examples: ['efimovFactor'] },\n\n  atomicMass: { description: 'Atomic mass constant', examples: ['atomicMass'] },\n  avogadro: { description: 'Avogadro\\'s number', examples: ['avogadro'] },\n  boltzmann: { description: 'Boltzmann constant', examples: ['boltzmann'] },\n  faraday: { description: 'Faraday constant', examples: ['faraday'] },\n  firstRadiation: { description: 'First radiation constant', examples: ['firstRadiation'] },\n  loschmidt: { description: 'Loschmidt constant at T=273.15 K and p=101.325 kPa', examples: ['loschmidt'] },\n  gasConstant: { description: 'Gas constant', examples: ['gasConstant'] },\n  molarPlanckConstant: { description: 'Molar Planck constant', examples: ['molarPlanckConstant'] },\n  molarVolume: { description: 'Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa', examples: ['molarVolume'] },\n  sackurTetrode: { description: 'Sackur-Tetrode constant at T=1 K and p=101.325 kPa', examples: ['sackurTetrode'] },\n  secondRadiation: { description: 'Second radiation constant', examples: ['secondRadiation'] },\n  stefanBoltzmann: { description: 'Stefan-Boltzmann constant', examples: ['stefanBoltzmann'] },\n  wienDisplacement: { description: 'Wien displacement law constant', examples: ['wienDisplacement'] },\n  // spectralRadiance: {description: 'First radiation constant for spectral radiance', examples: ['spectralRadiance']},\n\n  molarMass: { description: 'Molar mass constant', examples: ['molarMass'] },\n  molarMassC12: { description: 'Molar mass constant of carbon-12', examples: ['molarMassC12'] },\n  gravity: { description: 'Standard acceleration of gravity (standard acceleration of free-fall on Earth)', examples: ['gravity'] },\n\n  planckLength: { description: 'Planck length', examples: ['planckLength'] },\n  planckMass: { description: 'Planck mass', examples: ['planckMass'] },\n  planckTime: { description: 'Planck time', examples: ['planckTime'] },\n  planckCharge: { description: 'Planck charge', examples: ['planckCharge'] },\n  planckTemperature: { description: 'Planck temperature', examples: ['planckTemperature'] },\n\n  // functions - algebra\n  derivative: derivativeDocs,\n  lsolve: lsolveDocs,\n  lsolveAll: lsolveAllDocs,\n  lup: lupDocs,\n  lusolve: lusolveDocs,\n  leafCount: leafCountDocs,\n  polynomialRoot: polynomialRootDocs,\n  resolve: resolveDocs,\n  simplify: simplifyDocs,\n  simplifyConstant: simplifyConstantDocs,\n  simplifyCore: simplifyCoreDocs,\n  symbolicEqual: symbolicEqualDocs,\n  rationalize: rationalizeDocs,\n  slu: sluDocs,\n  usolve: usolveDocs,\n  usolveAll: usolveAllDocs,\n  qr: qrDocs,\n\n  // functions - arithmetic\n  abs: absDocs,\n  add: addDocs,\n  cbrt: cbrtDocs,\n  ceil: ceilDocs,\n  cube: cubeDocs,\n  divide: divideDocs,\n  dotDivide: dotDivideDocs,\n  dotMultiply: dotMultiplyDocs,\n  dotPow: dotPowDocs,\n  exp: expDocs,\n  expm: expmDocs,\n  expm1: expm1Docs,\n  fix: fixDocs,\n  floor: floorDocs,\n  gcd: gcdDocs,\n  hypot: hypotDocs,\n  lcm: lcmDocs,\n  log: logDocs,\n  log2: log2Docs,\n  log1p: log1pDocs,\n  log10: log10Docs,\n  mod: modDocs,\n  multiply: multiplyDocs,\n  norm: normDocs,\n  nthRoot: nthRootDocs,\n  nthRoots: nthRootsDocs,\n  pow: powDocs,\n  round: roundDocs,\n  sign: signDocs,\n  sqrt: sqrtDocs,\n  sqrtm: sqrtmDocs,\n  square: squareDocs,\n  subtract: subtractDocs,\n  unaryMinus: unaryMinusDocs,\n  unaryPlus: unaryPlusDocs,\n  xgcd: xgcdDocs,\n  invmod: invmodDocs,\n\n  // functions - bitwise\n  bitAnd: bitAndDocs,\n  bitNot: bitNotDocs,\n  bitOr: bitOrDocs,\n  bitXor: bitXorDocs,\n  leftShift: leftShiftDocs,\n  rightArithShift: rightArithShiftDocs,\n  rightLogShift: rightLogShiftDocs,\n\n  // functions - combinatorics\n  bellNumbers: bellNumbersDocs,\n  catalan: catalanDocs,\n  composition: compositionDocs,\n  stirlingS2: stirlingS2Docs,\n\n  // functions - core\n  config: configDocs,\n  import: importDocs,\n  typed: typedDocs,\n\n  // functions - complex\n  arg: argDocs,\n  conj: conjDocs,\n  re: reDocs,\n  im: imDocs,\n\n  // functions - expression\n  evaluate: evaluateDocs,\n  help: helpDocs,\n\n  // functions - geometry\n  distance: distanceDocs,\n  intersect: intersectDocs,\n\n  // functions - logical\n  and: andDocs,\n  not: notDocs,\n  or: orDocs,\n  xor: xorDocs,\n\n  // functions - matrix\n  concat: concatDocs,\n  count: countDocs,\n  cross: crossDocs,\n  column: columnDocs,\n  ctranspose: ctransposeDocs,\n  det: detDocs,\n  diag: diagDocs,\n  diff: diffDocs,\n  dot: dotDocs,\n  getMatrixDataType: getMatrixDataTypeDocs,\n  identity: identityDocs,\n  filter: filterDocs,\n  flatten: flattenDocs,\n  forEach: forEachDocs,\n  inv: invDocs,\n  pinv: pinvDocs,\n  eigs: eigsDocs,\n  kron: kronDocs,\n  matrixFromFunction: matrixFromFunctionDocs,\n  matrixFromRows: matrixFromRowsDocs,\n  matrixFromColumns: matrixFromColumnsDocs,\n  map: mapDocs,\n  ones: onesDocs,\n  partitionSelect: partitionSelectDocs,\n  range: rangeDocs,\n  resize: resizeDocs,\n  reshape: reshapeDocs,\n  rotate: rotateDocs,\n  rotationMatrix: rotationMatrixDocs,\n  row: rowDocs,\n  size: sizeDocs,\n  sort: sortDocs,\n  squeeze: squeezeDocs,\n  subset: subsetDocs,\n  trace: traceDocs,\n  transpose: transposeDocs,\n  zeros: zerosDocs,\n  fft: fftDocs,\n  ifft: ifftDocs,\n  sylvester: sylvesterDocs,\n  schur: schurDocs,\n  lyap: lyapDocs,\n\n  // functions - numeric\n  solveODE: solveODEDocs,\n\n  // functions - probability\n  combinations: combinationsDocs,\n  combinationsWithRep: combinationsWithRepDocs,\n  // distribution: distributionDocs,\n  factorial: factorialDocs,\n  gamma: gammaDocs,\n  kldivergence: kldivergenceDocs,\n  lgamma: lgammaDocs,\n  multinomial: multinomialDocs,\n  permutations: permutationsDocs,\n  pickRandom: pickRandomDocs,\n  random: randomDocs,\n  randomInt: randomIntDocs,\n\n  // functions - relational\n  compare: compareDocs,\n  compareNatural: compareNaturalDocs,\n  compareText: compareTextDocs,\n  deepEqual: deepEqualDocs,\n  equal: equalDocs,\n  equalText: equalTextDocs,\n  larger: largerDocs,\n  largerEq: largerEqDocs,\n  smaller: smallerDocs,\n  smallerEq: smallerEqDocs,\n  unequal: unequalDocs,\n\n  // functions - set\n  setCartesian: setCartesianDocs,\n  setDifference: setDifferenceDocs,\n  setDistinct: setDistinctDocs,\n  setIntersect: setIntersectDocs,\n  setIsSubset: setIsSubsetDocs,\n  setMultiplicity: setMultiplicityDocs,\n  setPowerset: setPowersetDocs,\n  setSize: setSizeDocs,\n  setSymDifference: setSymDifferenceDocs,\n  setUnion: setUnionDocs,\n\n  // functions - signal\n  zpk2tf: zpk2tfDocs,\n  freqz: freqzDocs,\n\n  // functions - special\n  erf: erfDocs,\n  zeta: zetaDocs,\n\n  // functions - statistics\n  cumsum: cumSumDocs,\n  mad: madDocs,\n  max: maxDocs,\n  mean: meanDocs,\n  median: medianDocs,\n  min: minDocs,\n  mode: modeDocs,\n  prod: prodDocs,\n  quantileSeq: quantileSeqDocs,\n  std: stdDocs,\n  sum: sumDocs,\n  variance: varianceDocs,\n  corr: corrDocs,\n\n  // functions - trigonometry\n  acos: acosDocs,\n  acosh: acoshDocs,\n  acot: acotDocs,\n  acoth: acothDocs,\n  acsc: acscDocs,\n  acsch: acschDocs,\n  asec: asecDocs,\n  asech: asechDocs,\n  asin: asinDocs,\n  asinh: asinhDocs,\n  atan: atanDocs,\n  atanh: atanhDocs,\n  atan2: atan2Docs,\n  cos: cosDocs,\n  cosh: coshDocs,\n  cot: cotDocs,\n  coth: cothDocs,\n  csc: cscDocs,\n  csch: cschDocs,\n  sec: secDocs,\n  sech: sechDocs,\n  sin: sinDocs,\n  sinh: sinhDocs,\n  tan: tanDocs,\n  tanh: tanhDocs,\n\n  // functions - units\n  to: toDocs,\n\n  // functions - utils\n  clone: cloneDocs,\n  format: formatDocs,\n  bin: binDocs,\n  oct: octDocs,\n  hex: hexDocs,\n  isNaN: isNaNDocs,\n  isInteger: isIntegerDocs,\n  isNegative: isNegativeDocs,\n  isNumeric: isNumericDocs,\n  hasNumericValue: hasNumericValueDocs,\n  isPositive: isPositiveDocs,\n  isPrime: isPrimeDocs,\n  isZero: isZeroDocs,\n  print: printDocs,\n  typeOf: typeOfDocs,\n  numeric: numericDocs\n}\n","export const bignumberDocs = {\n  name: 'bignumber',\n  category: 'Construction',\n  syntax: [\n    'bignumber(x)'\n  ],\n  description:\n      'Create a big number from a number or string.',\n  examples: [\n    '0.1 + 0.2',\n    'bignumber(0.1) + bignumber(0.2)',\n    'bignumber(\"7.2\")',\n    'bignumber(\"7.2e500\")',\n    'bignumber([0.1, 0.2, 0.3])'\n  ],\n  seealso: [\n    'boolean', 'bigint', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n  ]\n}\n","export const bigintDocs = {\n  name: 'bigint',\n  category: 'Construction',\n  syntax: [\n    'bigint(x)'\n  ],\n  description:\n      'Create a bigint, an integer with an arbitrary number of digits, from a number or string.',\n  examples: [\n    '123123123123123123 # a large number will lose digits',\n    'bigint(\"123123123123123123\")',\n    'bignumber([\"1\", \"3\", \"5\"])'\n  ],\n  seealso: [\n    'boolean', 'bignumber', 'number', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n  ]\n}\n","export const booleanDocs = {\n  name: 'boolean',\n  category: 'Construction',\n  syntax: [\n    'x',\n    'boolean(x)'\n  ],\n  description:\n      'Convert a string or number into a boolean.',\n  examples: [\n    'boolean(0)',\n    'boolean(1)',\n    'boolean(3)',\n    'boolean(\"true\")',\n    'boolean(\"false\")',\n    'boolean([1, 0, 1, 1])'\n  ],\n  seealso: [\n    'bignumber', 'complex', 'index', 'matrix', 'number', 'string', 'unit'\n  ]\n}\n","export const complexDocs = {\n  name: 'complex',\n  category: 'Construction',\n  syntax: [\n    'complex()',\n    'complex(re, im)',\n    'complex(string)'\n  ],\n  description:\n      'Create a complex number.',\n  examples: [\n    'complex()',\n    'complex(2, 3)',\n    'complex(\"7 - 2i\")'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'index', 'matrix', 'number', 'string', 'unit'\n  ]\n}\n","export const createUnitDocs = {\n  name: 'createUnit',\n  category: 'Construction',\n  syntax: [\n    'createUnit(definitions)',\n    'createUnit(name, definition)'\n  ],\n  description:\n      'Create a user-defined unit and register it with the Unit type.',\n  examples: [\n    'createUnit(\"foo\")',\n    'createUnit(\"knot\", {definition: \"0.514444444 m/s\", aliases: [\"knots\", \"kt\", \"kts\"]})',\n    'createUnit(\"mph\", \"1 mile/hour\")'\n  ],\n  seealso: [\n    'unit', 'splitUnit'\n  ]\n}\n","export const fractionDocs = {\n  name: 'fraction',\n  category: 'Construction',\n  syntax: [\n    'fraction(num)',\n    'fraction(matrix)',\n    'fraction(num,den)',\n    'fraction({n: num, d: den})'\n  ],\n  description:\n    'Create a fraction from a number or from integer numerator and denominator.',\n  examples: [\n    'fraction(0.125)',\n    'fraction(1, 3) + fraction(2, 5)',\n    'fraction({n: 333, d: 53})',\n    'fraction([sqrt(9), sqrt(10), sqrt(11)])'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'index', 'matrix', 'string', 'unit'\n  ]\n}\n","export const indexDocs = {\n  name: 'index',\n  category: 'Construction',\n  syntax: [\n    '[start]',\n    '[start:end]',\n    '[start:step:end]',\n    '[start1, start 2, ...]',\n    '[start1:end1, start2:end2, ...]',\n    '[start1:step1:end1, start2:step2:end2, ...]'\n  ],\n  description:\n      'Create an index to get or replace a subset of a matrix',\n  examples: [\n    'A = [1, 2, 3; 4, 5, 6]',\n    'A[1, :]',\n    'A[1, 2] = 50',\n    'A[1:2, 1:2] = 1',\n    'B = [1, 2, 3]',\n    'B[B>1 and B<3]'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'matrix,', 'number', 'range', 'string', 'unit'\n  ]\n}\n","export const matrixDocs = {\n  name: 'matrix',\n  category: 'Construction',\n  syntax: [\n    '[]',\n    '[a1, b1, ...; a2, b2, ...]',\n    'matrix()',\n    'matrix(\"dense\")',\n    'matrix([...])'\n  ],\n  description:\n      'Create a matrix.',\n  examples: [\n    '[]',\n    '[1, 2, 3]',\n    '[1, 2, 3; 4, 5, 6]',\n    'matrix()',\n    'matrix([3, 4])',\n    'matrix([3, 4; 5, 6], \"sparse\")',\n    'matrix([3, 4; 5, 6], \"sparse\", \"number\")'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'sparse'\n  ]\n}\n","export const numberDocs = {\n  name: 'number',\n  category: 'Construction',\n  syntax: [\n    'x',\n    'number(x)',\n    'number(unit, valuelessUnit)'\n  ],\n  description:\n      'Create a number or convert a string or boolean into a number.',\n  examples: [\n    '2',\n    '2e3',\n    '4.05',\n    'number(2)',\n    'number(\"7.2\")',\n    'number(true)',\n    'number([true, false, true, true])',\n    'number(unit(\"52cm\"), \"m\")'\n  ],\n  seealso: [\n    'bignumber', 'bigint', 'boolean', 'complex', 'fraction', 'index', 'matrix', 'string', 'unit'\n  ]\n}\n","export const sparseDocs = {\n  name: 'sparse',\n  category: 'Construction',\n  syntax: [\n    'sparse()',\n    'sparse([a1, b1, ...; a1, b2, ...])',\n    'sparse([a1, b1, ...; a1, b2, ...], \"number\")'\n  ],\n  description:\n  'Create a sparse matrix.',\n  examples: [\n    'sparse()',\n    'sparse([3, 4; 5, 6])',\n    'sparse([3, 0; 5, 0], \"number\")'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'index', 'number', 'string', 'unit', 'matrix'\n  ]\n}\n","export const splitUnitDocs = {\n  name: 'splitUnit',\n  category: 'Construction',\n  syntax: [\n    'splitUnit(unit: Unit, parts: Unit[])'\n  ],\n  description:\n      'Split a unit in an array of units whose sum is equal to the original unit.',\n  examples: [\n    'splitUnit(1 m, [\"feet\", \"inch\"])'\n  ],\n  seealso: [\n    'unit', 'createUnit'\n  ]\n}\n","export const stringDocs = {\n  name: 'string',\n  category: 'Construction',\n  syntax: [\n    '\"text\"',\n    'string(x)'\n  ],\n  description:\n      'Create a string or convert a value to a string',\n  examples: [\n    '\"Hello World!\"',\n    'string(4.2)',\n    'string(3 + 2i)'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'unit'\n  ]\n}\n","export const unitDocs = {\n  name: 'unit',\n  category: 'Construction',\n  syntax: [\n    'value unit',\n    'unit(value, unit)',\n    'unit(string)'\n  ],\n  description:\n      'Create a unit.',\n  examples: [\n    '5.5 mm',\n    '3 inch',\n    'unit(7.1, \"kilogram\")',\n    'unit(\"23 deg\")'\n  ],\n  seealso: [\n    'bignumber', 'boolean', 'complex', 'index', 'matrix', 'number', 'string'\n  ]\n}\n","export const falseDocs = {\n  name: 'false',\n  category: 'Constants',\n  syntax: [\n    'false'\n  ],\n  description: 'Boolean value false',\n  examples: [\n    'false'\n  ],\n  seealso: ['true']\n}\n","export const iDocs = {\n  name: 'i',\n  category: 'Constants',\n  syntax: [\n    'i'\n  ],\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: [\n    'i',\n    'i * i',\n    'sqrt(-1)'\n  ],\n  seealso: []\n}\n","export const InfinityDocs = {\n  name: 'Infinity',\n  category: 'Constants',\n  syntax: [\n    'Infinity'\n  ],\n  description: 'Infinity, a number which is larger than the maximum number that can be handled by a floating point number.',\n  examples: [\n    'Infinity',\n    '1 / 0'\n  ],\n  seealso: []\n}\n","export const LN2Docs = {\n  name: 'LN2',\n  category: 'Constants',\n  syntax: [\n    'LN2'\n  ],\n  description: 'Returns the natural logarithm of 2, approximately equal to 0.693',\n  examples: [\n    'LN2',\n    'log(2)'\n  ],\n  seealso: []\n}\n","export const LN10Docs = {\n  name: 'LN10',\n  category: 'Constants',\n  syntax: [\n    'LN10'\n  ],\n  description: 'Returns the natural logarithm of 10, approximately equal to 2.302',\n  examples: [\n    'LN10',\n    'log(10)'\n  ],\n  seealso: []\n}\n","export const LOG2EDocs = {\n  name: 'LOG2E',\n  category: 'Constants',\n  syntax: [\n    'LOG2E'\n  ],\n  description: 'Returns the base-2 logarithm of E, approximately equal to 1.442',\n  examples: [\n    'LOG2E',\n    'log(e, 2)'\n  ],\n  seealso: []\n}\n","export const LOG10EDocs = {\n  name: 'LOG10E',\n  category: 'Constants',\n  syntax: [\n    'LOG10E'\n  ],\n  description: 'Returns the base-10 logarithm of E, approximately equal to 0.434',\n  examples: [\n    'LOG10E',\n    'log(e, 10)'\n  ],\n  seealso: []\n}\n","export const NaNDocs = {\n  name: 'NaN',\n  category: 'Constants',\n  syntax: [\n    'NaN'\n  ],\n  description: 'Not a number',\n  examples: [\n    'NaN',\n    '0 / 0'\n  ],\n  seealso: []\n}\n","export const nullDocs = {\n  name: 'null',\n  category: 'Constants',\n  syntax: [\n    'null'\n  ],\n  description: 'Value null',\n  examples: [\n    'null'\n  ],\n  seealso: ['true', 'false']\n}\n","export const phiDocs = {\n  name: 'phi',\n  category: 'Constants',\n  syntax: [\n    'phi'\n  ],\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: [\n    'phi'\n  ],\n  seealso: []\n}\n","export const SQRT12Docs = {\n  name: 'SQRT1_2',\n  category: 'Constants',\n  syntax: [\n    'SQRT1_2'\n  ],\n  description: 'Returns the square root of 1/2, approximately equal to 0.707',\n  examples: [\n    'SQRT1_2',\n    'sqrt(1/2)'\n  ],\n  seealso: []\n}\n","export const SQRT2Docs = {\n  name: 'SQRT2',\n  category: 'Constants',\n  syntax: [\n    'SQRT2'\n  ],\n  description: 'Returns the square root of 2, approximately equal to 1.414',\n  examples: [\n    'SQRT2',\n    'sqrt(2)'\n  ],\n  seealso: []\n}\n","export const tauDocs = {\n  name: 'tau',\n  category: 'Constants',\n  syntax: [\n    'tau'\n  ],\n  description: 'Tau is the ratio constant of a circle\\'s circumference to radius, equal to 2 * pi, approximately 6.2832.',\n  examples: [\n    'tau',\n    '2 * pi'\n  ],\n  seealso: ['pi']\n}\n","export const trueDocs = {\n  name: 'true',\n  category: 'Constants',\n  syntax: [\n    'true'\n  ],\n  description: 'Boolean value true',\n  examples: [\n    'true'\n  ],\n  seealso: ['false']\n}\n","export const versionDocs = {\n  name: 'version',\n  category: 'Constants',\n  syntax: [\n    'version'\n  ],\n  description: 'A string with the version number of math.js',\n  examples: [\n    'version'\n  ],\n  seealso: []\n}\n","export const derivativeDocs = {\n  name: 'derivative',\n  category: 'Algebra',\n  syntax: [\n    'derivative(expr, variable)',\n    'derivative(expr, variable, {simplify: boolean})'\n  ],\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: [\n    'derivative(\"2x^3\", \"x\")',\n    'derivative(\"2x^3\", \"x\", {simplify: false})',\n    'derivative(\"2x^2 + 3x + 4\", \"x\")',\n    'derivative(\"sin(2x)\", \"x\")',\n    'f = parse(\"x^2 + x\")',\n    'x = parse(\"x\")',\n    'df = derivative(f, x)',\n    'df.evaluate({x: 3})'\n  ],\n  seealso: [\n    'simplify', 'parse', 'evaluate'\n  ]\n}\n","export const lsolveDocs = {\n  name: 'lsolve',\n  category: 'Algebra',\n  syntax: [\n    'x=lsolve(L, b)'\n  ],\n  description:\n  '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: [\n    'a = [-2, 3; 2, 1]',\n    'b = [11, 9]',\n    'x = lsolve(a, b)'\n  ],\n  seealso: [\n    'lsolveAll', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'\n  ]\n}\n","export const lsolveAllDocs = {\n  name: 'lsolveAll',\n  category: 'Algebra',\n  syntax: [\n    'x=lsolveAll(L, b)'\n  ],\n  description:\n  '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: [\n    'a = [-2, 3; 2, 1]',\n    'b = [11, 9]',\n    'x = lsolve(a, b)'\n  ],\n  seealso: [\n    'lsolve', 'lup', 'lusolve', 'usolve', 'matrix', 'sparse'\n  ]\n}\n","export const lupDocs = {\n  name: 'lup',\n  category: 'Algebra',\n  syntax: [\n    'lup(m)'\n  ],\n  description:\n  '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: [\n    'lup([[2, 1], [1, 4]])',\n    'lup(matrix([[2, 1], [1, 4]]))',\n    'lup(sparse([[2, 1], [1, 4]]))'\n  ],\n  seealso: [\n    'lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'slu', 'qr'\n  ]\n}\n","export const lusolveDocs = {\n  name: 'lusolve',\n  category: 'Algebra',\n  syntax: [\n    'x=lusolve(A, b)',\n    'x=lusolve(lu, b)'\n  ],\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: [\n    'a = [-2, 3; 2, 1]',\n    'b = [11, 9]',\n    'x = lusolve(a, b)'\n  ],\n  seealso: [\n    'lup', 'slu', 'lsolve', 'usolve', 'matrix', 'sparse'\n  ]\n}\n","export const 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: [\n    'leafCount(\"e^(i*pi)-1\")',\n    'leafCount(parse(\"{a: 22/7, b: 10^(1/2)}\"))'\n  ],\n  seealso: ['simplify']\n}\n","export const polynomialRootDocs = {\n  name: 'polynomialRoot',\n  category: 'Algebra',\n  syntax: [\n    'x=polynomialRoot(-6, 3)',\n    'x=polynomialRoot(4, -4, 1)',\n    'x=polynomialRoot(-8, 12, -6, 1)'\n  ],\n  description: 'Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.',\n  examples: [\n    'a = polynomialRoot(-6, 11, -6, 1)'\n  ],\n  seealso: [\n    'cbrt', 'sqrt'\n  ]\n}\n","export const resolveDocs = {\n  name: 'resolve',\n  category: 'Algebra',\n  syntax: [\n    'resolve(node, scope)'\n  ],\n  description: 'Recursively substitute variables in an expression tree.',\n  examples: [\n    'resolve(parse(\"1 + x\"), { x: 7 })',\n    'resolve(parse(\"size(text)\"), { text: \"Hello World\" })',\n    'resolve(parse(\"x + y\"), { x: parse(\"3z\") })',\n    'resolve(parse(\"3x\"), { x: parse(\"y+z\"), z: parse(\"w^y\") })'\n  ],\n  seealso: [\n    'simplify', 'evaluate'\n  ],\n  mayThrow: [\n    'ReferenceError'\n  ]\n}\n","export const simplifyDocs = {\n  name: 'simplify',\n  category: 'Algebra',\n  syntax: [\n    'simplify(expr)',\n    'simplify(expr, rules)'\n  ],\n  description: 'Simplify an expression tree.',\n  examples: [\n    'simplify(\"3 + 2 / 4\")',\n    'simplify(\"2x + x\")',\n    'f = parse(\"x * (x + 2 + x)\")',\n    'simplified = simplify(f)',\n    'simplified.evaluate({x: 2})'\n  ],\n  seealso: [\n    'simplifyCore', 'derivative', 'evaluate', 'parse', 'rationalize', 'resolve'\n  ]\n}\n","export const simplifyConstantDocs = {\n  name: 'simplifyConstant',\n  category: 'Algebra',\n  syntax: [\n    'simplifyConstant(expr)',\n    'simplifyConstant(expr, options)'\n  ],\n  description: 'Replace constant subexpressions of node with their values.',\n  examples: [\n    'simplifyConstant(\"(3-3)*x\")',\n    'simplifyConstant(parse(\"z-cos(tau/8)\"))'\n  ],\n  seealso: [\n    'simplify', 'simplifyCore', 'evaluate'\n  ]\n}\n","export const simplifyCoreDocs = {\n  name: 'simplifyCore',\n  category: 'Algebra',\n  syntax: [\n    'simplifyCore(node)'\n  ],\n  description: 'Perform simple one-pass simplifications on an expression tree.',\n  examples: [\n    'simplifyCore(parse(\"0*x\"))',\n    'simplifyCore(parse(\"(x+0)*2\"))'\n  ],\n  seealso: [\n    'simplify', 'simplifyConstant', 'evaluate'\n  ]\n}\n","export const symbolicEqualDocs = {\n  name: 'symbolicEqual',\n  category: 'Algebra',\n  syntax: [\n    'symbolicEqual(expr1, expr2)',\n    'symbolicEqual(expr1, expr2, options)'\n  ],\n  description: 'Returns true if the difference of the expressions simplifies to 0',\n  examples: [\n    'symbolicEqual(\"x*y\",\"y*x\")',\n    'symbolicEqual(\"abs(x^2)\", \"x^2\")',\n    'symbolicEqual(\"abs(x)\", \"x\", {context: {abs: {trivial: true}}})'\n  ],\n  seealso: ['simplify', 'evaluate']\n}\n","export const rationalizeDocs = {\n  name: 'rationalize',\n  category: 'Algebra',\n  syntax: [\n    'rationalize(expr)',\n    'rationalize(expr, scope)',\n    'rationalize(expr, scope, detailed)'\n  ],\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: [\n    'rationalize(\"2x/y - y/(x+1)\")',\n    'rationalize(\"2x/y - y/(x+1)\", true)'\n  ],\n  seealso: [\n    'simplify'\n  ]\n}\n","export const sluDocs = {\n  name: 'slu',\n  category: 'Algebra',\n  syntax: [\n    'slu(A, order, threshold)'\n  ],\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: [\n    '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  ],\n  seealso: [\n    'lusolve', 'lsolve', 'usolve', 'matrix', 'sparse', 'lup', 'qr'\n  ]\n}\n","export const usolveDocs = {\n  name: 'usolve',\n  category: 'Algebra',\n  syntax: [\n    'x=usolve(U, b)'\n  ],\n  description:\n  '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: [\n    'x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'\n  ],\n  seealso: [\n    'usolveAll', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'\n  ]\n}\n","export const usolveAllDocs = {\n  name: 'usolveAll',\n  category: 'Algebra',\n  syntax: [\n    'x=usolve(U, b)'\n  ],\n  description:\n  '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: [\n    'x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])'\n  ],\n  seealso: [\n    'usolve', 'lup', 'lusolve', 'lsolve', 'matrix', 'sparse'\n  ]\n}\n","export const qrDocs = {\n  name: 'qr',\n  category: 'Algebra',\n  syntax: [\n    'qr(A)'\n  ],\n  description:\n  '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: [\n    'qr([[1, -1,  4], [1,  4, -2], [1,  4,  2], [1,  -1, 0]])'\n  ],\n  seealso: [\n    'lup', 'slu', 'matrix'\n  ]\n}\n","export const absDocs = {\n  name: 'abs',\n  category: 'Arithmetic',\n  syntax: [\n    'abs(x)'\n  ],\n  description: 'Compute the absolute value.',\n  examples: [\n    'abs(3.5)',\n    'abs(-4.2)'\n  ],\n  seealso: ['sign']\n}\n","export const addDocs = {\n  name: 'add',\n  category: 'Operators',\n  syntax: [\n    'x + y',\n    'add(x, y)'\n  ],\n  description: 'Add two values.',\n  examples: [\n    'a = 2.1 + 3.6',\n    'a - 3.6',\n    '3 + 2i',\n    '3 cm + 2 inch',\n    '\"2.3\" + \"4\"'\n  ],\n  seealso: [\n    'subtract'\n  ]\n}\n","export const cbrtDocs = {\n  name: 'cbrt',\n  category: 'Arithmetic',\n  syntax: [\n    'cbrt(x)',\n    'cbrt(x, allRoots)'\n  ],\n  description:\n      '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: [\n    'cbrt(64)',\n    'cube(4)',\n    'cbrt(-8)',\n    'cbrt(2 + 3i)',\n    'cbrt(8i)',\n    'cbrt(8i, true)',\n    'cbrt(27 m^3)'\n  ],\n  seealso: [\n    'square',\n    'sqrt',\n    'cube',\n    'multiply'\n  ]\n}\n","export const ceilDocs = {\n  name: 'ceil',\n  category: 'Arithmetic',\n  syntax: [\n    'ceil(x)'\n  ],\n  description:\n      'Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.',\n  examples: [\n    'ceil(3.2)',\n    'ceil(3.8)',\n    'ceil(-4.2)'\n  ],\n  seealso: ['floor', 'fix', 'round']\n}\n","export const cubeDocs = {\n  name: 'cube',\n  category: 'Arithmetic',\n  syntax: [\n    'cube(x)'\n  ],\n  description: 'Compute the cube of a value. The cube of x is x * x * x.',\n  examples: [\n    'cube(2)',\n    '2^3',\n    '2 * 2 * 2'\n  ],\n  seealso: [\n    'multiply',\n    'square',\n    'pow'\n  ]\n}\n","export const divideDocs = {\n  name: 'divide',\n  category: 'Operators',\n  syntax: [\n    'x / y',\n    'divide(x, y)'\n  ],\n  description: 'Divide two values.',\n  examples: [\n    'a = 2 / 3',\n    'a * 3',\n    '4.5 / 2',\n    '3 + 4 / 2',\n    '(3 + 4) / 2',\n    '18 km / 4.5'\n  ],\n  seealso: [\n    'multiply'\n  ]\n}\n","export const dotDivideDocs = {\n  name: 'dotDivide',\n  category: 'Operators',\n  syntax: [\n    'x ./ y',\n    'dotDivide(x, y)'\n  ],\n  description: 'Divide two values element wise.',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'b = [2, 1, 1; 3, 2, 5]',\n    'a ./ b'\n  ],\n  seealso: [\n    'multiply',\n    'dotMultiply',\n    'divide'\n  ]\n}\n","export const dotMultiplyDocs = {\n  name: 'dotMultiply',\n  category: 'Operators',\n  syntax: [\n    'x .* y',\n    'dotMultiply(x, y)'\n  ],\n  description: 'Multiply two values element wise.',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'b = [2, 1, 1; 3, 2, 5]',\n    'a .* b'\n  ],\n  seealso: [\n    'multiply',\n    'divide',\n    'dotDivide'\n  ]\n}\n","export const dotPowDocs = {\n  name: 'dotPow',\n  category: 'Operators',\n  syntax: [\n    'x .^ y',\n    'dotPow(x, y)'\n  ],\n  description:\n      'Calculates the power of x to y element wise.',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'a .^ 2'\n  ],\n  seealso: [\n    'pow'\n  ]\n}\n","export const expDocs = {\n  name: 'exp',\n  category: 'Arithmetic',\n  syntax: [\n    'exp(x)'\n  ],\n  description: 'Calculate the exponent of a value.',\n  examples: [\n    'exp(1.3)',\n    'e ^ 1.3',\n    'log(exp(1.3))',\n    'x = 2.4',\n    '(exp(i*x) == cos(x) + i*sin(x))   # Euler\\'s formula'\n  ],\n  seealso: [\n    'expm',\n    'expm1',\n    'pow',\n    'log'\n  ]\n}\n","export const expmDocs = {\n  name: 'expm',\n  category: 'Arithmetic',\n  syntax: [\n    'exp(x)'\n  ],\n  description: 'Compute the matrix exponential, expm(A) = e^A. ' +\n    'The matrix must be square. ' +\n    'Not to be confused with exp(a), which performs element-wise exponentiation.',\n  examples: [\n    'expm([[0,2],[0,0]])'\n  ],\n  seealso: [\n    'exp'\n  ]\n}\n","export const expm1Docs = {\n  name: 'expm1',\n  category: 'Arithmetic',\n  syntax: [\n    'expm1(x)'\n  ],\n  description: 'Calculate the value of subtracting 1 from the exponential value.',\n  examples: [\n    'expm1(2)',\n    'pow(e, 2) - 1',\n    'log(expm1(2) + 1)'\n  ],\n  seealso: [\n    'exp',\n    'pow',\n    'log'\n  ]\n}\n","export const fixDocs = {\n  name: 'fix',\n  category: 'Arithmetic',\n  syntax: [\n    'fix(x)'\n  ],\n  description:\n      'Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.',\n  examples: [\n    'fix(3.2)',\n    'fix(3.8)',\n    'fix(-4.2)',\n    'fix(-4.8)'\n  ],\n  seealso: ['ceil', 'floor', 'round']\n}\n","export const floorDocs = {\n  name: 'floor',\n  category: 'Arithmetic',\n  syntax: [\n    'floor(x)'\n  ],\n  description:\n      'Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.',\n  examples: [\n    'floor(3.2)',\n    'floor(3.8)',\n    'floor(-4.2)'\n  ],\n  seealso: ['ceil', 'fix', 'round']\n}\n","export const gcdDocs = {\n  name: 'gcd',\n  category: 'Arithmetic',\n  syntax: [\n    'gcd(a, b)',\n    'gcd(a, b, c, ...)'\n  ],\n  description: 'Compute the greatest common divisor.',\n  examples: [\n    'gcd(8, 12)',\n    'gcd(-4, 6)',\n    'gcd(25, 15, -10)'\n  ],\n  seealso: ['lcm', 'xgcd']\n}\n","export const hypotDocs = {\n  name: 'hypot',\n  category: 'Arithmetic',\n  syntax: [\n    'hypot(a, b, c, ...)',\n    'hypot([a, b, c, ...])'\n  ],\n  description: 'Calculate the hypotenusa of a list with values. ',\n  examples: [\n    'hypot(3, 4)',\n    'sqrt(3^2 + 4^2)',\n    'hypot(-2)',\n    'hypot([3, 4, 5])'\n  ],\n  seealso: ['abs', 'norm']\n}\n","export const lcmDocs = {\n  name: 'lcm',\n  category: 'Arithmetic',\n  syntax: [\n    'lcm(x, y)'\n  ],\n  description: 'Compute the least common multiple.',\n  examples: [\n    'lcm(4, 6)',\n    'lcm(6, 21)',\n    'lcm(6, 21, 5)'\n  ],\n  seealso: ['gcd']\n}\n","export const logDocs = {\n  name: 'log',\n  category: 'Arithmetic',\n  syntax: [\n    'log(x)',\n    'log(x, base)'\n  ],\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: [\n    'log(3.5)',\n    'a = log(2.4)',\n    'exp(a)',\n    '10 ^ 4',\n    'log(10000, 10)',\n    'log(10000) / log(10)',\n    'b = log(1024, 2)',\n    '2 ^ b'\n  ],\n  seealso: [\n    'exp',\n    'log1p',\n    'log2',\n    'log10'\n  ]\n}\n","export const log2Docs = {\n  name: 'log2',\n  category: 'Arithmetic',\n  syntax: [\n    'log2(x)'\n  ],\n  description: 'Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.',\n  examples: [\n    'log2(0.03125)',\n    'log2(16)',\n    'log2(16) / log2(2)',\n    'pow(2, 4)'\n  ],\n  seealso: [\n    'exp',\n    'log1p',\n    'log',\n    'log10'\n  ]\n}\n","export const log1pDocs = {\n  name: 'log1p',\n  category: 'Arithmetic',\n  syntax: [\n    'log1p(x)',\n    'log1p(x, base)'\n  ],\n  description: 'Calculate the logarithm of a `value+1`',\n  examples: [\n    'log1p(2.5)',\n    'exp(log1p(1.4))',\n    'pow(10, 4)',\n    'log1p(9999, 10)',\n    'log1p(9999) / log(10)'\n  ],\n  seealso: [\n    'exp',\n    'log',\n    'log2',\n    'log10'\n  ]\n}\n","export const log10Docs = {\n  name: 'log10',\n  category: 'Arithmetic',\n  syntax: [\n    'log10(x)'\n  ],\n  description: 'Compute the 10-base logarithm of a value.',\n  examples: [\n    'log10(0.00001)',\n    'log10(10000)',\n    '10 ^ 4',\n    'log(10000) / log(10)',\n    'log(10000, 10)'\n  ],\n  seealso: [\n    'exp',\n    'log'\n  ]\n}\n","export const modDocs = {\n  name: 'mod',\n  category: 'Operators',\n  syntax: [\n    'x % y',\n    'x mod y',\n    'mod(x, y)'\n  ],\n  description:\n      'Calculates the modulus, the remainder of an integer division.',\n  examples: [\n    '7 % 3',\n    '11 % 2',\n    '10 mod 4',\n    'isOdd(x) = x % 2',\n    'isOdd(2)',\n    'isOdd(3)'\n  ],\n  seealso: ['divide']\n}\n","export const multiplyDocs = {\n  name: 'multiply',\n  category: 'Operators',\n  syntax: [\n    'x * y',\n    'multiply(x, y)'\n  ],\n  description: 'multiply two values.',\n  examples: [\n    'a = 2.1 * 3.4',\n    'a / 3.4',\n    '2 * 3 + 4',\n    '2 * (3 + 4)',\n    '3 * 2.1 km'\n  ],\n  seealso: [\n    'divide'\n  ]\n}\n","export const normDocs = {\n  name: 'norm',\n  category: 'Arithmetic',\n  syntax: [\n    'norm(x)',\n    'norm(x, p)'\n  ],\n  description: 'Calculate the norm of a number, vector or matrix.',\n  examples: [\n    'abs(-3.5)',\n    'norm(-3.5)',\n    'norm(3 - 4i)',\n    'norm([1, 2, -3], Infinity)',\n    'norm([1, 2, -3], -Infinity)',\n    'norm([3, 4], 2)',\n    'norm([[1, 2], [3, 4]], 1)',\n    'norm([[1, 2], [3, 4]], \"inf\")',\n    'norm([[1, 2], [3, 4]], \"fro\")'\n  ]\n}\n","export const nthRootDocs = {\n  name: 'nthRoot',\n  category: 'Arithmetic',\n  syntax: [\n    'nthRoot(a)',\n    'nthRoot(a, root)'\n  ],\n  description: 'Calculate the nth root of a value. ' +\n      'The principal nth root of a positive real number A, ' +\n      'is the positive real solution of the equation \"x^root = A\".',\n  examples: [\n    '4 ^ 3',\n    'nthRoot(64, 3)',\n    'nthRoot(9, 2)',\n    'sqrt(9)'\n  ],\n  seealso: [\n    'nthRoots',\n    'pow',\n    'sqrt'\n  ]\n}\n","export const nthRootsDocs = {\n  name: 'nthRoots',\n  category: 'Arithmetic',\n  syntax: [\n    'nthRoots(A)',\n    'nthRoots(A, root)'\n  ],\n  description: ('' +\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  examples: [\n    'nthRoots(1)',\n    'nthRoots(1, 3)'\n  ],\n  seealso: [\n    'sqrt',\n    'pow',\n    'nthRoot'\n  ]\n}\n","export const powDocs = {\n  name: 'pow',\n  category: 'Operators',\n  syntax: [\n    'x ^ y',\n    'pow(x, y)'\n  ],\n  description:\n      'Calculates the power of x to y, x^y.',\n  examples: [\n    '2^3',\n    '2*2*2',\n    '1 + e ^ (pi * i)',\n    'pow([[1, 2], [4, 3]], 2)',\n    'pow([[1, 2], [4, 3]], -1)'\n  ],\n  seealso: [\n    'multiply',\n    'nthRoot',\n    'nthRoots',\n    'sqrt'\n  ]\n}\n","export const roundDocs = {\n  name: 'round',\n  category: 'Arithmetic',\n  syntax: [\n    'round(x)',\n    'round(x, n)',\n    'round(unit, valuelessUnit)',\n    'round(unit, n, valuelessUnit)'\n  ],\n  description:\n      '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: [\n    'round(3.2)',\n    'round(3.8)',\n    'round(-4.2)',\n    'round(-4.8)',\n    'round(pi, 3)',\n    'round(123.45678, 2)',\n    'round(3.241cm, 2, cm)',\n    'round([3.2, 3.8, -4.7])'\n  ],\n  seealso: ['ceil', 'floor', 'fix']\n}\n","export const signDocs = {\n  name: 'sign',\n  category: 'Arithmetic',\n  syntax: [\n    'sign(x)'\n  ],\n  description:\n      '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: [\n    'sign(3.5)',\n    'sign(-4.2)',\n    'sign(0)'\n  ],\n  seealso: [\n    'abs'\n  ]\n}\n","export const sqrtDocs = {\n  name: 'sqrt',\n  category: 'Arithmetic',\n  syntax: [\n    'sqrt(x)'\n  ],\n  description:\n      'Compute the square root value. If x = y * y, then y is the square root of x.',\n  examples: [\n    'sqrt(25)',\n    '5 * 5',\n    'sqrt(-1)'\n  ],\n  seealso: [\n    'square',\n    'sqrtm',\n    'multiply',\n    'nthRoot',\n    'nthRoots',\n    'pow'\n  ]\n}\n","export const sqrtmDocs = {\n  name: 'sqrtm',\n  category: 'Arithmetic',\n  syntax: [\n    'sqrtm(x)'\n  ],\n  description:\n      '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: [\n    'sqrtm([[33, 24], [48, 57]])'\n  ],\n  seealso: [\n    'sqrt',\n    'abs',\n    'square',\n    'multiply'\n  ]\n}\n","export const squareDocs = {\n  name: 'square',\n  category: 'Arithmetic',\n  syntax: [\n    'square(x)'\n  ],\n  description:\n      'Compute the square of a value. The square of x is x * x.',\n  examples: [\n    'square(3)',\n    'sqrt(9)',\n    '3^2',\n    '3 * 3'\n  ],\n  seealso: [\n    'multiply',\n    'pow',\n    'sqrt',\n    'cube'\n  ]\n}\n","export const subtractDocs = {\n  name: 'subtract',\n  category: 'Operators',\n  syntax: [\n    'x - y',\n    'subtract(x, y)'\n  ],\n  description: 'subtract two values.',\n  examples: [\n    'a = 5.3 - 2',\n    'a + 2',\n    '2/3 - 1/6',\n    '2 * 3 - 3',\n    '2.1 km - 500m'\n  ],\n  seealso: [\n    'add'\n  ]\n}\n","export const unaryMinusDocs = {\n  name: 'unaryMinus',\n  category: 'Operators',\n  syntax: [\n    '-x',\n    'unaryMinus(x)'\n  ],\n  description:\n      'Inverse the sign of a value. Converts booleans and strings to numbers.',\n  examples: [\n    '-4.5',\n    '-(-5.6)',\n    '-\"22\"'\n  ],\n  seealso: [\n    'add', 'subtract', 'unaryPlus'\n  ]\n}\n","export const unaryPlusDocs = {\n  name: 'unaryPlus',\n  category: 'Operators',\n  syntax: [\n    '+x',\n    'unaryPlus(x)'\n  ],\n  description:\n      'Converts booleans and strings to numbers.',\n  examples: [\n    '+true',\n    '+\"2\"'\n  ],\n  seealso: [\n    'add', 'subtract', 'unaryMinus'\n  ]\n}\n","export const xgcdDocs = {\n  name: 'xgcd',\n  category: 'Arithmetic',\n  syntax: [\n    'xgcd(a, b)'\n  ],\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: [\n    'xgcd(8, 12)',\n    'gcd(8, 12)',\n    'xgcd(36163, 21199)'\n  ],\n  seealso: ['gcd', 'lcm']\n}\n","export const invmodDocs = {\n  name: 'invmod',\n  category: 'Arithmetic',\n  syntax: [\n    'invmod(a, b)'\n  ],\n  description: 'Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)',\n  examples: [\n    'invmod(8, 12)',\n    'invmod(7, 13)',\n    'invmod(15151, 15122)'\n  ],\n  seealso: ['gcd', 'xgcd']\n}\n","export const bitAndDocs = {\n  name: 'bitAnd',\n  category: 'Bitwise',\n  syntax: [\n    'x & y',\n    'bitAnd(x, y)'\n  ],\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: [\n    '5 & 3',\n    'bitAnd(53, 131)',\n    '[1, 12, 31] & 42'\n  ],\n  seealso: [\n    'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n  ]\n}\n","export const bitNotDocs = {\n  name: 'bitNot',\n  category: 'Bitwise',\n  syntax: [\n    '~x',\n    'bitNot(x)'\n  ],\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: [\n    '~1',\n    '~2',\n    'bitNot([2, -3, 4])'\n  ],\n  seealso: [\n    'bitAnd', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n  ]\n}\n","export const bitOrDocs = {\n  name: 'bitOr',\n  category: 'Bitwise',\n  syntax: [\n    'x | y',\n    'bitOr(x, y)'\n  ],\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: [\n    '5 | 3',\n    'bitOr([1, 2, 3], 4)'\n  ],\n  seealso: [\n    'bitAnd', 'bitNot', 'bitXor', 'leftShift', 'rightArithShift', 'rightLogShift'\n  ]\n}\n","export const bitXorDocs = {\n  name: 'bitXor',\n  category: 'Bitwise',\n  syntax: [\n    'bitXor(x, y)'\n  ],\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: [\n    'bitOr(1, 2)',\n    'bitXor([2, 3, 4], 4)'\n  ],\n  seealso: [\n    'bitAnd', 'bitNot', 'bitOr', 'leftShift', 'rightArithShift', 'rightLogShift'\n  ]\n}\n","export const leftShiftDocs = {\n  name: 'leftShift',\n  category: 'Bitwise',\n  syntax: [\n    'x << y',\n    'leftShift(x, y)'\n  ],\n  description: 'Bitwise left logical shift of a value x by y number of bits.',\n  examples: [\n    '4 << 1',\n    '8 >> 1'\n  ],\n  seealso: [\n    'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'rightArithShift', 'rightLogShift'\n  ]\n}\n","export const rightArithShiftDocs = {\n  name: 'rightArithShift',\n  category: 'Bitwise',\n  syntax: [\n    'x >> y',\n    'rightArithShift(x, y)'\n  ],\n  description: 'Bitwise right arithmetic shift of a value x by y number of bits.',\n  examples: [\n    '8 >> 1',\n    '4 << 1',\n    '-12 >> 2'\n  ],\n  seealso: [\n    'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightLogShift'\n  ]\n}\n","export const rightLogShiftDocs = {\n  name: 'rightLogShift',\n  category: 'Bitwise',\n  syntax: [\n    'x >>> y',\n    'rightLogShift(x, y)'\n  ],\n  description: 'Bitwise right logical shift of a value x by y number of bits.',\n  examples: [\n    '8 >>> 1',\n    '4 << 1',\n    '-12 >>> 2'\n  ],\n  seealso: [\n    'bitAnd', 'bitNot', 'bitOr', 'bitXor', 'leftShift', 'rightArithShift'\n  ]\n}\n","export const bellNumbersDocs = {\n  name: 'bellNumbers',\n  category: 'Combinatorics',\n  syntax: [\n    'bellNumbers(n)'\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: [\n    'bellNumbers(3)',\n    'bellNumbers(8)'\n  ],\n  seealso: ['stirlingS2']\n}\n","export const catalanDocs = {\n  name: 'catalan',\n  category: 'Combinatorics',\n  syntax: [\n    'catalan(n)'\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: [\n    'catalan(3)',\n    'catalan(8)'\n  ],\n  seealso: ['bellNumbers']\n}\n","export const compositionDocs = {\n  name: 'composition',\n  category: 'Combinatorics',\n  syntax: [\n    'composition(n, k)'\n  ],\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: [\n    'composition(5, 3)'\n  ],\n  seealso: ['combinations']\n}\n","export const stirlingS2Docs = {\n  name: 'stirlingS2',\n  category: 'Combinatorics',\n  syntax: [\n    'stirlingS2(n, k)'\n  ],\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: [\n    'stirlingS2(5, 3)'\n  ],\n  seealso: ['bellNumbers']\n}\n","export const configDocs = {\n  name: 'config',\n  category: 'Core',\n  syntax: [\n    'config()',\n    'config(options)'\n  ],\n  description: 'Get configuration or change configuration.',\n  examples: [\n    'config()',\n    '1/3 + 1/4',\n    'config({number: \"Fraction\"})',\n    '1/3 + 1/4'\n  ],\n  seealso: []\n}\n","export const importDocs = {\n  name: 'import',\n  category: 'Core',\n  syntax: [\n    'import(functions)',\n    'import(functions, options)'\n  ],\n  description: 'Import functions or constants from an object.',\n  examples: [\n    'import({myFn: f(x)=x^2, myConstant: 32 })',\n    'myFn(2)',\n    'myConstant'\n  ],\n  seealso: []\n}\n","export const typedDocs = {\n  name: 'typed',\n  category: 'Core',\n  syntax: [\n    'typed(signatures)',\n    'typed(name, signatures)'\n  ],\n  description: 'Create a typed function.',\n  examples: [\n    'double = typed({ \"number\": f(x)=x+x, \"string\": f(x)=concat(x,x) })',\n    'double(2)',\n    'double(\"hello\")'\n  ],\n  seealso: []\n}\n","export const argDocs = {\n  name: 'arg',\n  category: 'Complex',\n  syntax: [\n    'arg(x)'\n  ],\n  description:\n      'Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).',\n  examples: [\n    'arg(2 + 2i)',\n    'atan2(3, 2)',\n    'arg(2 + 3i)'\n  ],\n  seealso: [\n    're',\n    'im',\n    'conj',\n    'abs'\n  ]\n}\n","export const conjDocs = {\n  name: 'conj',\n  category: 'Complex',\n  syntax: [\n    'conj(x)'\n  ],\n  description:\n      'Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.',\n  examples: [\n    'conj(2 + 3i)',\n    'conj(2 - 3i)',\n    'conj(-5.2i)'\n  ],\n  seealso: [\n    're',\n    'im',\n    'abs',\n    'arg'\n  ]\n}\n","export const reDocs = {\n  name: 're',\n  category: 'Complex',\n  syntax: [\n    're(x)'\n  ],\n  description: 'Get the real part of a complex number.',\n  examples: [\n    're(2 + 3i)',\n    'im(2 + 3i)',\n    're(-5.2i)',\n    're(2.4)'\n  ],\n  seealso: [\n    'im',\n    'conj',\n    'abs',\n    'arg'\n  ]\n}\n","export const imDocs = {\n  name: 'im',\n  category: 'Complex',\n  syntax: [\n    'im(x)'\n  ],\n  description: 'Get the imaginary part of a complex number.',\n  examples: [\n    'im(2 + 3i)',\n    're(2 + 3i)',\n    'im(-5.2i)',\n    'im(2.4)'\n  ],\n  seealso: [\n    're',\n    'conj',\n    'abs',\n    'arg'\n  ]\n}\n","export const evaluateDocs = {\n  name: 'evaluate',\n  category: 'Expression',\n  syntax: [\n    'evaluate(expression)',\n    'evaluate(expression, scope)',\n    'evaluate([expr1, expr2, expr3, ...])',\n    'evaluate([expr1, expr2, expr3, ...], scope)'\n  ],\n  description: 'Evaluate an expression or an array with expressions.',\n  examples: [\n    'evaluate(\"2 + 3\")',\n    'evaluate(\"sqrt(16)\")',\n    'evaluate(\"2 inch to cm\")',\n    'evaluate(\"sin(x * pi)\", { \"x\": 1/2 })',\n    'evaluate([\"width=2\", \"height=4\",\"width*height\"])'\n  ],\n  seealso: []\n}\n","export const helpDocs = {\n  name: 'help',\n  category: 'Expression',\n  syntax: [\n    'help(object)',\n    'help(string)'\n  ],\n  description: 'Display documentation on a function or data type.',\n  examples: [\n    'help(sqrt)',\n    'help(\"complex\")'\n  ],\n  seealso: []\n}\n","export const distanceDocs = {\n  name: 'distance',\n  category: 'Geometry',\n  syntax: [\n    'distance([x1, y1], [x2, y2])',\n    'distance([[x1, y1], [x2, y2]])'\n  ],\n  description: 'Calculates the Euclidean distance between two points.',\n  examples: [\n    'distance([0,0], [4,4])',\n    'distance([[0,0], [4,4]])'\n  ],\n  seealso: []\n}\n","export const intersectDocs = {\n  name: 'intersect',\n  category: 'Geometry',\n  syntax: [\n    'intersect(expr1, expr2, expr3, expr4)',\n    'intersect(expr1, expr2, expr3)'\n  ],\n  description: 'Computes the intersection point of lines and/or planes.',\n  examples: [\n    'intersect([0, 0], [10, 10], [10, 0], [0, 10])',\n    'intersect([1, 0, 1],  [4, -2, 2], [1, 1, 1, 6])'\n  ],\n  seealso: []\n}\n","export const andDocs = {\n  name: 'and',\n  category: 'Logical',\n  syntax: [\n    'x and y',\n    'and(x, y)'\n  ],\n  description: 'Logical and. Test whether two values are both defined with a nonzero/nonempty value.',\n  examples: [\n    'true and false',\n    'true and true',\n    '2 and 4'\n  ],\n  seealso: [\n    'not', 'or', 'xor'\n  ]\n}\n","export const notDocs = {\n  name: 'not',\n  category: 'Logical',\n  syntax: [\n    'not x',\n    'not(x)'\n  ],\n  description: 'Logical not. Flips the boolean value of given argument.',\n  examples: [\n    'not true',\n    'not false',\n    'not 2',\n    'not 0'\n  ],\n  seealso: [\n    'and', 'or', 'xor'\n  ]\n}\n","export const orDocs = {\n  name: 'or',\n  category: 'Logical',\n  syntax: [\n    'x or y',\n    'or(x, y)'\n  ],\n  description: 'Logical or. Test if at least one value is defined with a nonzero/nonempty value.',\n  examples: [\n    'true or false',\n    'false or false',\n    '0 or 4'\n  ],\n  seealso: [\n    'not', 'and', 'xor'\n  ]\n}\n","export const xorDocs = {\n  name: 'xor',\n  category: 'Logical',\n  syntax: [\n    'x xor y',\n    'xor(x, y)'\n  ],\n  description: 'Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.',\n  examples: [\n    'true xor false',\n    'false xor false',\n    'true xor true',\n    '0 xor 4'\n  ],\n  seealso: [\n    'not', 'and', 'or'\n  ]\n}\n","export const concatDocs = {\n  name: 'concat',\n  category: 'Matrix',\n  syntax: [\n    'concat(A, B, C, ...)',\n    'concat(A, B, C, ..., dim)'\n  ],\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: [\n    'A = [1, 2; 5, 6]',\n    'B = [3, 4; 7, 8]',\n    'concat(A, B)',\n    'concat(A, B, 1)',\n    'concat(A, B, 2)'\n  ],\n  seealso: [\n    'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const countDocs = {\n  name: 'count',\n  category: 'Matrix',\n  syntax: [\n    'count(x)'\n  ],\n  description: 'Count the number of elements of a matrix, array or string.',\n  examples: [\n    'a = [1, 2; 3, 4; 5, 6]',\n    'count(a)',\n    'size(a)',\n    'count(\"hello world\")'\n  ],\n  seealso: [\n    'size'\n  ]\n}\n","export const crossDocs = {\n  name: 'cross',\n  category: 'Matrix',\n  syntax: [\n    'cross(A, B)'\n  ],\n  description: 'Calculate the cross product for two vectors in three dimensional space.',\n  examples: [\n    'cross([1, 1, 0],  [0, 1, 1])',\n    'cross([3, -3, 1], [4, 9, 2])',\n    'cross([2, 3, 4],  [5, 6, 7])'\n  ],\n  seealso: [\n    'multiply',\n    'dot'\n  ]\n}\n","export const columnDocs = {\n  name: 'column',\n  category: 'Matrix',\n  syntax: [\n    'column(x, index)'\n  ],\n  description: 'Return a column from a matrix or array.',\n  examples: [\n    'A = [[1, 2], [3, 4]]',\n    'column(A, 1)',\n    'column(A, 2)'\n  ],\n  seealso: ['row', 'matrixFromColumns']\n}\n","export const ctransposeDocs = {\n  name: 'ctranspose',\n  category: 'Matrix',\n  syntax: [\n    'x\\'',\n    'ctranspose(x)'\n  ],\n  description: 'Complex Conjugate and Transpose a matrix',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'a\\'',\n    'ctranspose(a)'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'\n  ]\n}\n","export const detDocs = {\n  name: 'det',\n  category: 'Matrix',\n  syntax: [\n    'det(x)'\n  ],\n  description: 'Calculate the determinant of a matrix',\n  examples: [\n    'det([1, 2; 3, 4])',\n    'det([-2, 2, 3; -1, 1, 3; 2, 0, -1])'\n  ],\n  seealso: [\n    'concat', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const diagDocs = {\n  name: 'diag',\n  category: 'Matrix',\n  syntax: [\n    'diag(x)',\n    'diag(x, k)'\n  ],\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: [\n    'diag(1:3)',\n    'diag(1:3, 1)',\n    'a = [1, 2, 3; 4, 5, 6; 7, 8, 9]',\n    'diag(a)'\n  ],\n  seealso: [\n    'concat', 'det', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const diffDocs = {\n  name: 'diff',\n  category: 'Matrix',\n  syntax: [\n    'diff(arr)',\n    'diff(arr, dim)'\n  ],\n  description: [\n    'Create a new matrix or array with the difference of the passed matrix or array.',\n    'Dim parameter is optional and used to indicant the dimension of the array/matrix to apply the difference',\n    'If no dimension parameter is passed it is assumed as dimension 0',\n    'Dimension is zero-based in javascript and one-based in the parser',\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  examples: [\n    'A = [1, 2, 4, 7, 0]',\n    'diff(A)',\n    'diff(A, 1)',\n    'B = [[1, 2], [3, 4]]',\n    'diff(B)',\n    'diff(B, 1)',\n    'diff(B, 2)',\n    'diff(B, bignumber(2))',\n    'diff([[1, 2], matrix([3, 4])], 2)'\n  ],\n  seealso: ['subtract', 'partitionSelect']\n}\n","export const dotDocs = {\n  name: 'dot',\n  category: 'Matrix',\n  syntax: [\n    'dot(A, B)',\n    'A * B'\n  ],\n  description: 'Calculate the dot product of two vectors. ' +\n      'The dot product of A = [a1, a2, a3, ..., an] and B = [b1, b2, b3, ..., bn] ' +\n      'is defined as dot(A, B) = a1 * b1 + a2 * b2 + a3 * b3 + ... + an * bn',\n  examples: [\n    'dot([2, 4, 1], [2, 2, 3])',\n    '[2, 4, 1] * [2, 2, 3]'\n  ],\n  seealso: [\n    'multiply',\n    'cross'\n  ]\n}\n","export const getMatrixDataTypeDocs = {\n  name: 'getMatrixDataType',\n  category: 'Matrix',\n  syntax: [\n    'getMatrixDataType(x)'\n  ],\n  description: 'Find the data type of all elements in a matrix or array, ' +\n  'for example \"number\" if all items are a number ' +\n  'and \"Complex\" if all values are complex numbers. ' +\n  'If a matrix contains more than one data type, it will return \"mixed\".',\n  examples: [\n    'getMatrixDataType([1, 2, 3])',\n    'getMatrixDataType([[5 cm], [2 inch]])',\n    'getMatrixDataType([1, \"text\"])',\n    'getMatrixDataType([1, bignumber(4)])'\n  ],\n  seealso: ['matrix', 'sparse', 'typeOf']\n}\n","export const identityDocs = {\n  name: 'identity',\n  category: 'Matrix',\n  syntax: [\n    'identity(n)',\n    'identity(m, n)',\n    'identity([m, n])'\n  ],\n  description: 'Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.',\n  examples: [\n    'identity(3)',\n    'identity(3, 5)',\n    'a = [1, 2, 3; 4, 5, 6]',\n    'identity(size(a))'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const filterDocs = {\n  name: 'filter',\n  category: 'Matrix',\n  syntax: [\n    'filter(x, test)'\n  ],\n  description: 'Filter items in a matrix.',\n  examples: [\n    'isPositive(x) = x > 0',\n    'filter([6, -2, -1, 4, 3], isPositive)',\n    'filter([6, -2, 0, 1, 0], x != 0)'\n  ],\n  seealso: ['sort', 'map', 'forEach']\n}\n","export const flattenDocs = {\n  name: 'flatten',\n  category: 'Matrix',\n  syntax: [\n    'flatten(x)'\n  ],\n  description: 'Flatten a multi dimensional matrix into a single dimensional matrix.',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'size(a)',\n    'b = flatten(a)',\n    'size(b)'\n  ],\n  seealso: [\n    'concat', 'resize', 'size', 'squeeze'\n  ]\n}\n","export const forEachDocs = {\n  name: 'forEach',\n  category: 'Matrix',\n  syntax: [\n    'forEach(x, callback)'\n  ],\n  description: 'Iterates over all elements of a matrix/array, and executes the given callback function.',\n  examples: [\n    'numberOfPets = {}',\n    'addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;',\n    'forEach([\"Dog\",\"Cat\",\"Cat\"], addPet)',\n    'numberOfPets'\n  ],\n  seealso: ['map', 'sort', 'filter']\n}\n","export const invDocs = {\n  name: 'inv',\n  category: 'Matrix',\n  syntax: [\n    'inv(x)'\n  ],\n  description: 'Calculate the inverse of a matrix',\n  examples: [\n    'inv([1, 2; 3, 4])',\n    'inv(4)',\n    '1 / 4'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const pinvDocs = {\n  name: 'pinv',\n  category: 'Matrix',\n  syntax: [\n    'pinv(x)'\n  ],\n  description: 'Calculate the Moore–Penrose inverse of a matrix',\n  examples: [\n    'pinv([1, 2; 3, 4])',\n    'pinv([[1, 0], [0, 1], [0, 1]])',\n    'pinv(4)'\n  ],\n  seealso: [\n    'inv'\n  ]\n}\n","export const eigsDocs = {\n  name: 'eigs',\n  category: 'Matrix',\n  syntax: [\n    'eigs(x)'\n  ],\n  description: 'Calculate the eigenvalues and optionally eigenvectors of a square matrix',\n  examples: [\n    'eigs([[5, 2.3], [2.3, 1]])',\n    'eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })'\n  ],\n  seealso: [\n    'inv'\n  ]\n}\n","export const kronDocs = {\n  name: 'kron',\n  category: 'Matrix',\n  syntax: [\n    'kron(x, y)'\n  ],\n  description: 'Calculates the kronecker product of 2 matrices or vectors.',\n  examples: [\n    'kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])',\n    'kron([1,1], [2,3,4])'\n  ],\n  seealso: [\n    'multiply', 'dot', 'cross'\n  ]\n}\n","export const matrixFromFunctionDocs = {\n  name: 'matrixFromFunction',\n  category: 'Matrix',\n  syntax: [\n    'matrixFromFunction(size, fn)',\n    'matrixFromFunction(size, fn, format)',\n    'matrixFromFunction(size, fn, format, datatype)',\n    'matrixFromFunction(size, format, fn)',\n    'matrixFromFunction(size, format, datatype, fn)'\n  ],\n  description: 'Create a matrix by evaluating a generating function at each index.',\n  examples: [\n    'f(I) = I[1] - I[2]',\n    'matrixFromFunction([3,3], f)',\n    'g(I) = I[1] - I[2] == 1 ? 4 : 0',\n    'matrixFromFunction([100, 100], \"sparse\", g)',\n    'matrixFromFunction([5], random)'\n  ],\n  seealso: [\n    'matrix', 'matrixFromRows', 'matrixFromColumns', 'zeros'\n  ]\n}\n","export const matrixFromRowsDocs = {\n  name: 'matrixFromRows',\n  category: 'Matrix',\n  syntax: [\n    'matrixFromRows(...arr)',\n    'matrixFromRows(row1, row2)',\n    'matrixFromRows(row1, row2, row3)'\n  ],\n  description: 'Create a dense matrix from vectors as individual rows.',\n  examples: [\n    'matrixFromRows([1, 2, 3], [[4],[5],[6]])'\n  ],\n  seealso: [\n    'matrix', 'matrixFromColumns', 'matrixFromFunction', 'zeros'\n  ]\n}\n","export const matrixFromColumnsDocs = {\n  name: 'matrixFromColumns',\n  category: 'Matrix',\n  syntax: [\n    'matrixFromColumns(...arr)',\n    'matrixFromColumns(row1, row2)',\n    'matrixFromColumns(row1, row2, row3)'\n  ],\n  description: 'Create a dense matrix from vectors as individual columns.',\n  examples: [\n    'matrixFromColumns([1, 2, 3], [[4],[5],[6]])'\n  ],\n  seealso: [\n    'matrix', 'matrixFromRows', 'matrixFromFunction', 'zeros'\n  ]\n}\n","export const mapDocs = {\n  name: 'map',\n  category: 'Matrix',\n  syntax: [\n    'map(x, callback)'\n  ],\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: [\n    'map([1, 2, 3], square)'\n  ],\n  seealso: ['filter', 'forEach']\n}\n","export const onesDocs = {\n  name: 'ones',\n  category: 'Matrix',\n  syntax: [\n    'ones(m)',\n    'ones(m, n)',\n    'ones(m, n, p, ...)',\n    'ones([m])',\n    'ones([m, n])',\n    'ones([m, n, p, ...])'\n  ],\n  description: 'Create a matrix containing ones.',\n  examples: [\n    'ones(3)',\n    'ones(3, 5)',\n    'ones([2,3]) * 4.5',\n    'a = [1, 2, 3; 4, 5, 6]',\n    'ones(size(a))'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const partitionSelectDocs = {\n  name: 'partitionSelect',\n  category: 'Matrix',\n  syntax: [\n    'partitionSelect(x, k)',\n    'partitionSelect(x, k, compare)'\n  ],\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: [\n    'partitionSelect([5, 10, 1], 2)',\n    'partitionSelect([\"C\", \"B\", \"A\", \"D\"], 1, compareText)',\n    'arr = [5, 2, 1]',\n    'partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]',\n    'arr',\n    'partitionSelect(arr, 1, \\'desc\\') # returns 2, arr is now: [5, 2, 1]',\n    'arr'\n  ],\n  seealso: ['sort']\n}\n","export const rangeDocs = {\n  name: 'range',\n  category: 'Type',\n  syntax: [\n    'start:end',\n    'start:step:end',\n    'range(start, end)',\n    'range(start, end, step)',\n    'range(string)'\n  ],\n  description:\n      'Create a range. Lower bound of the range is included, upper bound is excluded.',\n  examples: [\n    '1:5',\n    '3:-1:-3',\n    'range(3, 7)',\n    'range(0, 12, 2)',\n    'range(\"4:10\")',\n    'range(1m, 1m, 3m)',\n    'a = [1, 2, 3, 4; 5, 6, 7, 8]',\n    'a[1:2, 1:2]'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'size', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const resizeDocs = {\n  name: 'resize',\n  category: 'Matrix',\n  syntax: [\n    'resize(x, size)',\n    'resize(x, size, defaultValue)'\n  ],\n  description: 'Resize a matrix.',\n  examples: [\n    'resize([1,2,3,4,5], [3])',\n    'resize([1,2,3], [5])',\n    'resize([1,2,3], [5], -1)',\n    'resize(2, [2, 3])',\n    'resize(\"hello\", [8], \"!\")'\n  ],\n  seealso: [\n    'size', 'subset', 'squeeze', 'reshape'\n  ]\n}\n","export const reshapeDocs = {\n  name: 'reshape',\n  category: 'Matrix',\n  syntax: [\n    'reshape(x, sizes)'\n  ],\n  description: 'Reshape a multi dimensional array to fit the specified dimensions.',\n  examples: [\n    'reshape([1, 2, 3, 4, 5, 6], [2, 3])',\n    'reshape([[1, 2], [3, 4]], [1, 4])',\n    'reshape([[1, 2], [3, 4]], [4])',\n    'reshape([1, 2, 3, 4], [-1, 2])'\n  ],\n  seealso: [\n    'size', 'squeeze', 'resize'\n  ]\n}\n","export const rotateDocs = {\n  name: 'rotate',\n  category: 'Matrix',\n  syntax: [\n    'rotate(w, theta)',\n    'rotate(w, theta, v)'\n  ],\n  description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' +\n    'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n  examples: [\n    'rotate([1, 0], pi / 2)',\n    'rotate(matrix([1, 0]), unit(\"35deg\"))',\n    'rotate([1, 0, 0], unit(\"90deg\"), [0, 0, 1])',\n    'rotate(matrix([1, 0, 0]), unit(\"90deg\"), matrix([0, 0, 1]))'\n  ],\n  seealso: [\n    'matrix', 'rotationMatrix'\n  ]\n}\n","export const rotationMatrixDocs = {\n  name: 'rotationMatrix',\n  category: 'Matrix',\n  syntax: [\n    'rotationMatrix(theta)',\n    'rotationMatrix(theta, v)',\n    'rotationMatrix(theta, v, format)'\n  ],\n  description: 'Returns a 2-D rotation matrix (2x2) for a given angle (in radians). ' +\n    'Returns a 2-D rotation matrix (3x3) of a given angle (in radians) around given axis.',\n  examples: [\n    'rotationMatrix(pi / 2)',\n    'rotationMatrix(unit(\"45deg\"), [0, 0, 1])',\n    'rotationMatrix(1, matrix([0, 0, 1]), \"sparse\")'\n  ],\n  seealso: [\n    'cos', 'sin'\n  ]\n}\n","export const rowDocs = {\n  name: 'row',\n  category: 'Matrix',\n  syntax: [\n    'row(x, index)'\n  ],\n  description: 'Return a row from a matrix or array.',\n  examples: [\n    'A = [[1, 2], [3, 4]]',\n    'row(A, 1)',\n    'row(A, 2)'\n  ],\n  seealso: ['column', 'matrixFromRows']\n}\n","export const sizeDocs = {\n  name: 'size',\n  category: 'Matrix',\n  syntax: [\n    'size(x)'\n  ],\n  description: 'Calculate the size of a matrix.',\n  examples: [\n    'size(2.3)',\n    'size(\"hello world\")',\n    'a = [1, 2; 3, 4; 5, 6]',\n    'size(a)',\n    'size(1:6)'\n  ],\n  seealso: [\n    'concat', 'count', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'squeeze', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const sortDocs = {\n  name: 'sort',\n  category: 'Matrix',\n  syntax: [\n    'sort(x)',\n    'sort(x, compare)'\n  ],\n  description: 'Sort the items in a matrix. Compare can be a string \"asc\", \"desc\", \"natural\", or a custom sort function.',\n  examples: [\n    'sort([5, 10, 1])',\n    'sort([\"C\", \"B\", \"A\", \"D\"], \"natural\")',\n    'sortByLength(a, b) = size(a)[1] - size(b)[1]',\n    'sort([\"Langdon\", \"Tom\", \"Sara\"], sortByLength)',\n    'sort([\"10\", \"1\", \"2\"], \"natural\")'\n  ],\n  seealso: ['map', 'filter', 'forEach']\n}\n","export const squeezeDocs = {\n  name: 'squeeze',\n  category: 'Matrix',\n  syntax: [\n    'squeeze(x)'\n  ],\n  description: 'Remove inner and outer singleton dimensions from a matrix.',\n  examples: [\n    'a = zeros(3,2,1)',\n    'size(squeeze(a))',\n    'b = zeros(1,1,3)',\n    'size(squeeze(b))'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'subset', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const subsetDocs = {\n  name: 'subset',\n  category: 'Matrix',\n  syntax: [\n    'value(index)',\n    'value(index) = replacement',\n    'subset(value, [index])',\n    'subset(value, [index], replacement)'\n  ],\n  description: 'Get or set a subset of the entries of a matrix or ' +\n      'characters of a string. ' +\n      'Indexes are one-based. There should be one index specification for ' +\n      'each dimension of the target. Each specification can be a single ' +\n      'index, a list of indices, or a range in colon notation `l:u`. ' +\n      'In a range, both the lower bound l and upper bound u are included; ' +\n      'and if a bound is omitted it defaults to the most extreme valid value. ' +\n      'The cartesian product of the indices specified in each dimension ' +\n      'determines the target of the operation.',\n  examples: [\n    'd = [1, 2; 3, 4]',\n    'e = []',\n    'e[1, 1:2] = [5, 6]',\n    'e[2, :] = [7, 8]',\n    'f = d * e',\n    'f[2, 1]',\n    'f[:, 1]',\n    'f[[1,2], [1,3]] = [9, 10; 11, 12]',\n    'f'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'trace', 'transpose', 'zeros'\n  ]\n}\n","export const traceDocs = {\n  name: 'trace',\n  category: 'Matrix',\n  syntax: [\n    'trace(A)'\n  ],\n  description: 'Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.',\n  examples: [\n    'A = [1, 2, 3; -1, 2, 3; 2, 0, 3]',\n    'trace(A)'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'transpose', 'zeros'\n  ]\n}\n","export const transposeDocs = {\n  name: 'transpose',\n  category: 'Matrix',\n  syntax: [\n    'x\\'',\n    'transpose(x)'\n  ],\n  description: 'Transpose a matrix',\n  examples: [\n    'a = [1, 2, 3; 4, 5, 6]',\n    'a\\'',\n    'transpose(a)'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'zeros'\n  ]\n}\n","export const zerosDocs = {\n  name: 'zeros',\n  category: 'Matrix',\n  syntax: [\n    'zeros(m)',\n    'zeros(m, n)',\n    'zeros(m, n, p, ...)',\n    'zeros([m])',\n    'zeros([m, n])',\n    'zeros([m, n, p, ...])'\n  ],\n  description: 'Create a matrix containing zeros.',\n  examples: [\n    'zeros(3)',\n    'zeros(3, 5)',\n    'a = [1, 2, 3; 4, 5, 6]',\n    'zeros(size(a))'\n  ],\n  seealso: [\n    'concat', 'det', 'diag', 'identity', 'inv', 'ones', 'range', 'size', 'squeeze', 'subset', 'trace', 'transpose'\n  ]\n}\n","export const fftDocs = {\n  name: 'fft',\n  category: 'Matrix',\n  syntax: [\n    'fft(x)'\n  ],\n  description: 'Calculate N-dimensional fourier transform',\n  examples: [\n    'fft([[1, 0], [1, 0]])'\n  ],\n  seealso: [\n    'ifft'\n  ]\n}\n","export const ifftDocs = {\n  name: 'ifft',\n  category: 'Matrix',\n  syntax: [\n    'ifft(x)'\n  ],\n  description: 'Calculate N-dimensional inverse fourier transform',\n  examples: [\n    'ifft([[2, 2], [0, 0]])'\n  ],\n  seealso: [\n    'fft'\n  ]\n}\n","export const sylvesterDocs = {\n  name: 'sylvester',\n  category: 'Algebra',\n  syntax: [\n    'sylvester(A,B,C)'\n  ],\n  description: 'Solves the real-valued Sylvester equation AX+XB=C for X',\n  examples: [\n    'sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])',\n    'A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]',\n    'sylvester(A, B, C)'\n  ],\n  seealso: [\n    'schur', 'lyap'\n  ]\n}\n","export const schurDocs = {\n  name: 'schur',\n  category: 'Algebra',\n  syntax: [\n    'schur(A)'\n  ],\n  description: 'Performs a real Schur decomposition of the real matrix A = UTU\\'',\n  examples: [\n    'schur([[1, 0], [-4, 3]])',\n    'A = [[1, 0], [-4, 3]]',\n    'schur(A)'\n  ],\n  seealso: [\n    'lyap', 'sylvester'\n  ]\n}\n","export const lyapDocs = {\n  name: 'lyap',\n  category: 'Algebra',\n  syntax: [\n    'lyap(A,Q)'\n  ],\n  description: 'Solves the Continuous-time Lyapunov equation AP+PA\\'+Q=0 for P',\n  examples: [\n    'lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])',\n    'A = [[-2, 0], [1, -4]]',\n    'Q = [[3, 1], [1, 3]]',\n    'lyap(A,Q)'\n  ],\n  seealso: [\n    'schur', 'sylvester'\n  ]\n}\n","export const solveODEDocs = {\n  name: 'solveODE',\n  category: 'Numeric',\n  syntax: [\n    'solveODE(func, tspan, y0)',\n    'solveODE(func, tspan, y0, options)'\n  ],\n  description: 'Numerical Integration of Ordinary Differential Equations.',\n  examples: [\n    'f(t,y) = y',\n    'tspan = [0, 4]',\n    'solveODE(f, tspan, 1)',\n    'solveODE(f, tspan, [1, 2])',\n    'solveODE(f, tspan, 1, { method:\"RK23\", maxStep:0.1 })'\n  ],\n  seealso: ['derivative', 'simplifyCore']\n}\n","export const combinationsDocs = {\n  name: 'combinations',\n  category: 'Probability',\n  syntax: [\n    'combinations(n, k)'\n  ],\n  description: 'Compute the number of combinations of n items taken k at a time',\n  examples: [\n    'combinations(7, 5)'\n  ],\n  seealso: ['combinationsWithRep', 'permutations', 'factorial']\n}\n","export const combinationsWithRepDocs = {\n  name: 'combinationsWithRep',\n  category: 'Probability',\n  syntax: [\n    'combinationsWithRep(n, k)'\n  ],\n  description: 'Compute the number of combinations of n items taken k at a time with replacements.',\n  examples: [\n    'combinationsWithRep(7, 5)'\n  ],\n  seealso: ['combinations', 'permutations', 'factorial']\n}\n","export const factorialDocs = {\n  name: 'factorial',\n  category: 'Probability',\n  syntax: [\n    'n!',\n    'factorial(n)'\n  ],\n  description: 'Compute the factorial of a value',\n  examples: [\n    '5!',\n    '5 * 4 * 3 * 2 * 1',\n    '3!'\n  ],\n  seealso: ['combinations', 'combinationsWithRep', 'permutations', 'gamma']\n}\n","export const gammaDocs = {\n  name: 'gamma',\n  category: 'Probability',\n  syntax: [\n    'gamma(n)'\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: [\n    'gamma(4)',\n    '3!',\n    'gamma(1/2)',\n    'sqrt(pi)'\n  ],\n  seealso: ['factorial']\n}\n","export const kldivergenceDocs = {\n  name: 'kldivergence',\n  category: 'Probability',\n  syntax: [\n    'kldivergence(x, y)'\n  ],\n  description: 'Calculate the Kullback-Leibler (KL) divergence  between two distributions.',\n  examples: [\n    'kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])'\n  ],\n  seealso: []\n}\n","export const lgammaDocs = {\n  name: 'lgamma',\n  category: 'Probability',\n  syntax: ['lgamma(n)'],\n  description:\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  examples: [\n    'lgamma(4)',\n    'lgamma(1/2)',\n    'lgamma(i)',\n    'lgamma(complex(1.1, 2))'\n  ],\n  seealso: ['gamma']\n}\n","export const multinomialDocs = {\n  name: 'multinomial',\n  category: 'Probability',\n  syntax: [\n    'multinomial(A)'\n  ],\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: [\n    'multinomial([1, 2, 1])'\n  ],\n  seealso: ['combinations', 'factorial']\n}\n","export const permutationsDocs = {\n  name: 'permutations',\n  category: 'Probability',\n  syntax: [\n    'permutations(n)',\n    'permutations(n, k)'\n  ],\n  description: 'Compute the number of permutations of n items taken k at a time',\n  examples: [\n    'permutations(5)',\n    'permutations(5, 3)'\n  ],\n  seealso: ['combinations', 'combinationsWithRep', 'factorial']\n}\n","export const pickRandomDocs = {\n  name: 'pickRandom',\n  category: 'Probability',\n  syntax: [\n    'pickRandom(array)',\n    'pickRandom(array, number)',\n    'pickRandom(array, weights)',\n    'pickRandom(array, number, weights)',\n    'pickRandom(array, weights, number)'\n  ],\n  description:\n      'Pick a random entry from a given array.',\n  examples: [\n    'pickRandom(0:10)',\n    'pickRandom([1, 3, 1, 6])',\n    'pickRandom([1, 3, 1, 6], 2)',\n    'pickRandom([1, 3, 1, 6], [2, 3, 2, 1])',\n    'pickRandom([1, 3, 1, 6], 2, [2, 3, 2, 1])',\n    'pickRandom([1, 3, 1, 6], [2, 3, 2, 1], 2)'\n  ],\n  seealso: ['random', 'randomInt']\n}\n","export const randomDocs = {\n  name: 'random',\n  category: 'Probability',\n  syntax: [\n    'random()',\n    'random(max)',\n    'random(min, max)',\n    'random(size)',\n    'random(size, max)',\n    'random(size, min, max)'\n  ],\n  description:\n      'Return a random number.',\n  examples: [\n    'random()',\n    'random(10, 20)',\n    'random([2, 3])'\n  ],\n  seealso: ['pickRandom', 'randomInt']\n}\n","export const randomIntDocs = {\n  name: 'randomInt',\n  category: 'Probability',\n  syntax: [\n    'randomInt(max)',\n    'randomInt(min, max)',\n    'randomInt(size)',\n    'randomInt(size, max)',\n    'randomInt(size, min, max)'\n  ],\n  description:\n      'Return a random integer number',\n  examples: [\n    'randomInt(10, 20)',\n    'randomInt([2, 3], 10)'\n  ],\n  seealso: ['pickRandom', 'random']\n}\n","export const compareDocs = {\n  name: 'compare',\n  category: 'Relational',\n  syntax: [\n    'compare(x, y)'\n  ],\n  description:\n      'Compare two values. ' +\n      'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n  examples: [\n    'compare(2, 3)',\n    'compare(3, 2)',\n    'compare(2, 2)',\n    'compare(5cm, 40mm)',\n    'compare(2, [1, 2, 3])'\n  ],\n  seealso: [\n    'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compareNatural', 'compareText'\n  ]\n}\n","export const compareNaturalDocs = {\n  name: 'compareNatural',\n  category: 'Relational',\n  syntax: [\n    'compareNatural(x, y)'\n  ],\n  description:\n      'Compare two values of any type in a deterministic, natural way. ' +\n      'Returns 1 when x > y, -1 when x < y, and 0 when x == y.',\n  examples: [\n    'compareNatural(2, 3)',\n    'compareNatural(3, 2)',\n    'compareNatural(2, 2)',\n    'compareNatural(5cm, 40mm)',\n    'compareNatural(\"2\", \"10\")',\n    'compareNatural(2 + 3i, 2 + 4i)',\n    'compareNatural([1, 2, 4], [1, 2, 3])',\n    'compareNatural([1, 5], [1, 2, 3])',\n    'compareNatural([1, 2], [1, 2])',\n    'compareNatural({a: 2}, {a: 4})'\n  ],\n  seealso: [\n    'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare', 'compareText'\n  ]\n}\n","export const compareTextDocs = {\n  name: 'compareText',\n  category: 'Relational',\n  syntax: [\n    'compareText(x, y)'\n  ],\n  description:\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  examples: [\n    'compareText(\"B\", \"A\")',\n    'compareText(\"A\", \"B\")',\n    'compareText(\"A\", \"A\")',\n    'compareText(\"2\", \"10\")',\n    'compare(\"2\", \"10\")',\n    'compare(2, 10)',\n    'compareNatural(\"2\", \"10\")',\n    'compareText(\"B\", [\"A\", \"B\", \"C\"])'\n  ],\n  seealso: [\n    'compare', 'compareNatural'\n  ]\n}\n","export const deepEqualDocs = {\n  name: 'deepEqual',\n  category: 'Relational',\n  syntax: [\n    'deepEqual(x, y)'\n  ],\n  description:\n      '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: [\n    'deepEqual([1,3,4], [1,3,4])',\n    'deepEqual([1,3,4], [1,3])'\n  ],\n  seealso: [\n    'equal', 'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare'\n  ]\n}\n","export const equalDocs = {\n  name: 'equal',\n  category: 'Relational',\n  syntax: [\n    'x == y',\n    'equal(x, y)'\n  ],\n  description:\n      'Check equality of two values. Returns true if the values are equal, and false if not.',\n  examples: [\n    '2+2 == 3',\n    '2+2 == 4',\n    'a = 3.2',\n    'b = 6-2.8',\n    'a == b',\n    '50cm == 0.5m'\n  ],\n  seealso: [\n    'unequal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual', 'equalText'\n  ]\n}\n","export const equalTextDocs = {\n  name: 'equalText',\n  category: 'Relational',\n  syntax: [\n    'equalText(x, y)'\n  ],\n  description:\n      'Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.',\n  examples: [\n    'equalText(\"Hello\", \"Hello\")',\n    'equalText(\"a\", \"A\")',\n    'equal(\"2e3\", \"2000\")',\n    'equalText(\"2e3\", \"2000\")',\n    'equalText(\"B\", [\"A\", \"B\", \"C\"])'\n  ],\n  seealso: [\n    'compare', 'compareNatural', 'compareText', 'equal'\n  ]\n}\n","export const largerDocs = {\n  name: 'larger',\n  category: 'Relational',\n  syntax: [\n    'x > y',\n    'larger(x, y)'\n  ],\n  description:\n      'Check if value x is larger than y. Returns true if x is larger than y, and false if not.',\n  examples: [\n    '2 > 3',\n    '5 > 2*2',\n    'a = 3.3',\n    'b = 6-2.8',\n    '(a > b)',\n    '(b < a)',\n    '5 cm > 2 inch'\n  ],\n  seealso: [\n    'equal', 'unequal', 'smaller', 'smallerEq', 'largerEq', 'compare'\n  ]\n}\n","export const largerEqDocs = {\n  name: 'largerEq',\n  category: 'Relational',\n  syntax: [\n    'x >= y',\n    'largerEq(x, y)'\n  ],\n  description:\n      '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: [\n    '2 >= 1+1',\n    '2 > 1+1',\n    'a = 3.2',\n    'b = 6-2.8',\n    '(a >= b)'\n  ],\n  seealso: [\n    'equal', 'unequal', 'smallerEq', 'smaller', 'compare'\n  ]\n}\n","export const smallerDocs = {\n  name: 'smaller',\n  category: 'Relational',\n  syntax: [\n    'x < y',\n    'smaller(x, y)'\n  ],\n  description:\n      'Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.',\n  examples: [\n    '2 < 3',\n    '5 < 2*2',\n    'a = 3.3',\n    'b = 6-2.8',\n    '(a < b)',\n    '5 cm < 2 inch'\n  ],\n  seealso: [\n    'equal', 'unequal', 'larger', 'smallerEq', 'largerEq', 'compare'\n  ]\n}\n","export const smallerEqDocs = {\n  name: 'smallerEq',\n  category: 'Relational',\n  syntax: [\n    'x <= y',\n    'smallerEq(x, y)'\n  ],\n  description:\n      '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: [\n    '2 <= 1+1',\n    '2 < 1+1',\n    'a = 3.2',\n    'b = 6-2.8',\n    '(a <= b)'\n  ],\n  seealso: [\n    'equal', 'unequal', 'larger', 'smaller', 'largerEq', 'compare'\n  ]\n}\n","export const unequalDocs = {\n  name: 'unequal',\n  category: 'Relational',\n  syntax: [\n    'x != y',\n    'unequal(x, y)'\n  ],\n  description:\n      'Check unequality of two values. Returns true if the values are unequal, and false if they are equal.',\n  examples: [\n    '2+2 != 3',\n    '2+2 != 4',\n    'a = 3.2',\n    'b = 6-2.8',\n    'a != b',\n    '50cm != 0.5m',\n    '5 cm != 2 inch'\n  ],\n  seealso: [\n    'equal', 'smaller', 'larger', 'smallerEq', 'largerEq', 'compare', 'deepEqual'\n  ]\n}\n","export const setCartesianDocs = {\n  name: 'setCartesian',\n  category: 'Set',\n  syntax: [\n    'setCartesian(set1, set2)'\n  ],\n  description:\n      '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: [\n    'setCartesian([1, 2], [3, 4])'\n  ],\n  seealso: [\n    'setUnion', 'setIntersect', 'setDifference', 'setPowerset'\n  ]\n}\n","export const setDifferenceDocs = {\n  name: 'setDifference',\n  category: 'Set',\n  syntax: [\n    'setDifference(set1, set2)'\n  ],\n  description:\n      '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: [\n    'setDifference([1, 2, 3, 4], [3, 4, 5, 6])',\n    'setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n  ],\n  seealso: [\n    'setUnion', 'setIntersect', 'setSymDifference'\n  ]\n}\n","export const setDistinctDocs = {\n  name: 'setDistinct',\n  category: 'Set',\n  syntax: [\n    'setDistinct(set)'\n  ],\n  description:\n      'Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.',\n  examples: [\n    'setDistinct([1, 1, 1, 2, 2, 3])'\n  ],\n  seealso: [\n    'setMultiplicity'\n  ]\n}\n","export const setIntersectDocs = {\n  name: 'setIntersect',\n  category: 'Set',\n  syntax: [\n    'setIntersect(set1, set2)'\n  ],\n  description:\n      'Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n  examples: [\n    'setIntersect([1, 2, 3, 4], [3, 4, 5, 6])',\n    'setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n  ],\n  seealso: [\n    'setUnion', 'setDifference'\n  ]\n}\n","export const setIsSubsetDocs = {\n  name: 'setIsSubset',\n  category: 'Set',\n  syntax: [\n    'setIsSubset(set1, set2)'\n  ],\n  description:\n      '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: [\n    'setIsSubset([1, 2], [3, 4, 5, 6])',\n    'setIsSubset([3, 4], [3, 4, 5, 6])'\n  ],\n  seealso: [\n    'setUnion', 'setIntersect', 'setDifference'\n  ]\n}\n","export const setMultiplicityDocs = {\n  name: 'setMultiplicity',\n  category: 'Set',\n  syntax: [\n    'setMultiplicity(element, set)'\n  ],\n  description:\n      '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: [\n    'setMultiplicity(1, [1, 2, 2, 4])',\n    'setMultiplicity(2, [1, 2, 2, 4])'\n  ],\n  seealso: [\n    'setDistinct', 'setSize'\n  ]\n}\n","export const setPowersetDocs = {\n  name: 'setPowerset',\n  category: 'Set',\n  syntax: [\n    'setPowerset(set)'\n  ],\n  description:\n      '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: [\n    'setPowerset([1, 2, 3])'\n  ],\n  seealso: [\n    'setCartesian'\n  ]\n}\n","export const setSizeDocs = {\n  name: 'setSize',\n  category: 'Set',\n  syntax: [\n    'setSize(set)',\n    'setSize(set, unique)'\n  ],\n  description:\n      '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: [\n    'setSize([1, 2, 2, 4])',\n    'setSize([1, 2, 2, 4], true)'\n  ],\n  seealso: [\n    'setUnion', 'setIntersect', 'setDifference'\n  ]\n}\n","export const setSymDifferenceDocs = {\n  name: 'setSymDifference',\n  category: 'Set',\n  syntax: [\n    'setSymDifference(set1, set2)'\n  ],\n  description:\n      'Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n  examples: [\n    'setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])',\n    'setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n  ],\n  seealso: [\n    'setUnion', 'setIntersect', 'setDifference'\n  ]\n}\n","export const setUnionDocs = {\n  name: 'setUnion',\n  category: 'Set',\n  syntax: [\n    'setUnion(set1, set2)'\n  ],\n  description:\n      'Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.',\n  examples: [\n    'setUnion([1, 2, 3, 4], [3, 4, 5, 6])',\n    'setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])'\n  ],\n  seealso: [\n    'setIntersect', 'setDifference'\n  ]\n}\n","export const zpk2tfDocs = {\n  name: 'zpk2tf',\n  category: 'Signal',\n  syntax: [\n    'zpk2tf(z, p, k)'\n  ],\n  description: 'Compute the transfer function of a zero-pole-gain model.',\n  examples: [\n    'zpk2tf([1, 2], [-1, -2], 1)',\n    'zpk2tf([1, 2], [-1, -2])',\n    'zpk2tf([1 - 3i, 2 + 2i], [-1, -2])'\n  ],\n  seealso: []\n}\n","export const freqzDocs = {\n  name: 'freqz',\n  category: 'Signal',\n  syntax: [\n    'freqz(b, a)',\n    'freqz(b, a, w)'\n  ],\n  description: 'Calculates the frequency response of a filter given its numerator and denominator coefficients.',\n  examples: [\n    'freqz([1, 2], [1, 2, 3])',\n    'freqz([1, 2], [1, 2, 3], [0, 1])',\n    'freqz([1, 2], [1, 2, 3], 512)'\n  ],\n  seealso: []\n}\n","export const erfDocs = {\n  name: 'erf',\n  category: 'Special',\n  syntax: [\n    'erf(x)'\n  ],\n  description: 'Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x',\n  examples: [\n    'erf(0.2)',\n    'erf(-0.5)',\n    'erf(4)'\n  ],\n  seealso: []\n}\n","export const zetaDocs = {\n  name: 'zeta',\n  category: 'Special',\n  syntax: [\n    'zeta(s)'\n  ],\n  description: 'Compute the Riemann Zeta Function using an infinite series and Riemanns Functional Equation for the entire complex plane',\n  examples: [\n    'zeta(0.2)',\n    'zeta(-0.5)',\n    'zeta(4)'\n  ],\n  seealso: []\n}\n","export const cumSumDocs = {\n  name: 'cumsum',\n  category: 'Statistics',\n  syntax: [\n    'cumsum(a, b, c, ...)',\n    'cumsum(A)'\n  ],\n  description: 'Compute the cumulative sum of all values.',\n  examples: [\n    'cumsum(2, 3, 4, 1)',\n    'cumsum([2, 3, 4, 1])',\n    'cumsum([1, 2; 3, 4])',\n    'cumsum([1, 2; 3, 4], 1)',\n    'cumsum([1, 2; 3, 4], 2)'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const madDocs = {\n  name: 'mad',\n  category: 'Statistics',\n  syntax: [\n    'mad(a, b, c, ...)',\n    'mad(A)'\n  ],\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: [\n    'mad(10, 20, 30)',\n    'mad([1, 2, 3])'\n  ],\n  seealso: [\n    'mean',\n    'median',\n    'std',\n    'abs'\n  ]\n}\n","export const maxDocs = {\n  name: 'max',\n  category: 'Statistics',\n  syntax: [\n    'max(a, b, c, ...)',\n    'max(A)',\n    'max(A, dimension)'\n  ],\n  description: 'Compute the maximum value of a list of values.',\n  examples: [\n    'max(2, 3, 4, 1)',\n    'max([2, 3, 4, 1])',\n    'max([2, 5; 4, 3])',\n    'max([2, 5; 4, 3], 1)',\n    'max([2, 5; 4, 3], 2)',\n    'max(2.7, 7.1, -4.5, 2.0, 4.1)',\n    'min(2.7, 7.1, -4.5, 2.0, 4.1)'\n  ],\n  seealso: [\n    'mean',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const meanDocs = {\n  name: 'mean',\n  category: 'Statistics',\n  syntax: [\n    'mean(a, b, c, ...)',\n    'mean(A)',\n    'mean(A, dimension)'\n  ],\n  description: 'Compute the arithmetic mean of a list of values.',\n  examples: [\n    'mean(2, 3, 4, 1)',\n    'mean([2, 3, 4, 1])',\n    'mean([2, 5; 4, 3])',\n    'mean([2, 5; 4, 3], 1)',\n    'mean([2, 5; 4, 3], 2)',\n    'mean([1.0, 2.7, 3.2, 4.0])'\n  ],\n  seealso: [\n    'max',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const medianDocs = {\n  name: 'median',\n  category: 'Statistics',\n  syntax: [\n    'median(a, b, c, ...)',\n    'median(A)'\n  ],\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: [\n    'median(5, 2, 7)',\n    'median([3, -1, 5, 7])'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'prod',\n    'std',\n    'sum',\n    'variance',\n    'quantileSeq'\n  ]\n}\n","export const minDocs = {\n  name: 'min',\n  category: 'Statistics',\n  syntax: [\n    'min(a, b, c, ...)',\n    'min(A)',\n    'min(A, dimension)'\n  ],\n  description: 'Compute the minimum value of a list of values.',\n  examples: [\n    'min(2, 3, 4, 1)',\n    'min([2, 3, 4, 1])',\n    'min([2, 5; 4, 3])',\n    'min([2, 5; 4, 3], 1)',\n    'min([2, 5; 4, 3], 2)',\n    'min(2.7, 7.1, -4.5, 2.0, 4.1)',\n    'max(2.7, 7.1, -4.5, 2.0, 4.1)'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'median',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const modeDocs = {\n  name: 'mode',\n  category: 'Statistics',\n  syntax: [\n    'mode(a, b, c, ...)',\n    'mode(A)',\n    'mode(A, a, b, B, c, ...)'\n  ],\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: [\n    'mode(2, 1, 4, 3, 1)',\n    'mode([1, 2.7, 3.2, 4, 2.7])',\n    'mode(1, 4, 6, 1, 6)'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'median',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const prodDocs = {\n  name: 'prod',\n  category: 'Statistics',\n  syntax: [\n    'prod(a, b, c, ...)',\n    'prod(A)'\n  ],\n  description: 'Compute the product of all values.',\n  examples: [\n    'prod(2, 3, 4)',\n    'prod([2, 3, 4])',\n    'prod([2, 5; 4, 3])'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'median',\n    'min',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const quantileSeqDocs = {\n  name: 'quantileSeq',\n  category: 'Statistics',\n  syntax: [\n    'quantileSeq(A, prob[, sorted])',\n    'quantileSeq(A, [prob1, prob2, ...][, sorted])',\n    'quantileSeq(A, N[, sorted])'\n  ],\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: [\n    'quantileSeq([3, -1, 5, 7], 0.5)',\n    'quantileSeq([3, -1, 5, 7], [1/3, 2/3])',\n    'quantileSeq([3, -1, 5, 7], 2)',\n    'quantileSeq([-1, 3, 5, 7], 0.5, true)'\n  ],\n  seealso: [\n    'mean',\n    'median',\n    'min',\n    'max',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const stdDocs = {\n  name: 'std',\n  category: 'Statistics',\n  syntax: [\n    'std(a, b, c, ...)',\n    'std(A)',\n    'std(A, dimension)',\n    'std(A, normalization)',\n    'std(A, dimension, normalization)'\n  ],\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: [\n    'std(2, 4, 6)',\n    'std([2, 4, 6, 8])',\n    'std([2, 4, 6, 8], \"uncorrected\")',\n    'std([2, 4, 6, 8], \"biased\")',\n    'std([1, 2, 3; 4, 5, 6])'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'median',\n    'prod',\n    'sum',\n    'variance'\n  ]\n}\n","export const sumDocs = {\n  name: 'sum',\n  category: 'Statistics',\n  syntax: [\n    'sum(a, b, c, ...)',\n    'sum(A)',\n    'sum(A, dimension)'\n  ],\n  description: 'Compute the sum of all values.',\n  examples: [\n    'sum(2, 3, 4, 1)',\n    'sum([2, 3, 4, 1])',\n    'sum([2, 5; 4, 3])'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum',\n    'variance'\n  ]\n}\n","export const varianceDocs = {\n  name: 'variance',\n  category: 'Statistics',\n  syntax: [\n    'variance(a, b, c, ...)',\n    'variance(A)',\n    'variance(A, dimension)',\n    'variance(A, normalization)',\n    'variance(A, dimension, normalization)'\n  ],\n  description: 'Compute the variance of all values. Optional parameter normalization can be \"unbiased\" (default), \"uncorrected\", or \"biased\".',\n  examples: [\n    'variance(2, 4, 6)',\n    'variance([2, 4, 6, 8])',\n    'variance([2, 4, 6, 8], \"uncorrected\")',\n    'variance([2, 4, 6, 8], \"biased\")',\n    'variance([1, 2, 3; 4, 5, 6])'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum'\n  ]\n}\n","export const corrDocs = {\n  name: 'corr',\n  category: 'Statistics',\n  syntax: [\n    'corr(A,B)'\n  ],\n  description: 'Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.',\n  examples: [\n    'corr([2, 4, 6, 8],[1, 2, 3, 6])',\n    'corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))'\n  ],\n  seealso: [\n    'max',\n    'mean',\n    'min',\n    'median',\n    'min',\n    'prod',\n    'std',\n    'sum'\n  ]\n}\n","export const acosDocs = {\n  name: 'acos',\n  category: 'Trigonometry',\n  syntax: [\n    'acos(x)'\n  ],\n  description: 'Compute the inverse cosine of a value in radians.',\n  examples: [\n    'acos(0.5)',\n    'acos(cos(2.3))'\n  ],\n  seealso: [\n    'cos',\n    'atan',\n    'asin'\n  ]\n}\n","export const acoshDocs = {\n  name: 'acosh',\n  category: 'Trigonometry',\n  syntax: [\n    'acosh(x)'\n  ],\n  description: 'Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.',\n  examples: [\n    'acosh(1.5)'\n  ],\n  seealso: [\n    'cosh',\n    'asinh',\n    'atanh'\n  ]\n}\n","export const acotDocs = {\n  name: 'acot',\n  category: 'Trigonometry',\n  syntax: [\n    'acot(x)'\n  ],\n  description: 'Calculate the inverse cotangent of a value.',\n  examples: [\n    'acot(0.5)',\n    'acot(cot(0.5))',\n    'acot(2)'\n  ],\n  seealso: [\n    'cot',\n    'atan'\n  ]\n}\n","export const acothDocs = {\n  name: 'acoth',\n  category: 'Trigonometry',\n  syntax: [\n    'acoth(x)'\n  ],\n  description: 'Calculate the hyperbolic arccotangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.',\n  examples: [\n    'acoth(2)',\n    'acoth(0.5)'\n  ],\n  seealso: [\n    'acsch',\n    'asech'\n  ]\n}\n","export const acscDocs = {\n  name: 'acsc',\n  category: 'Trigonometry',\n  syntax: [\n    'acsc(x)'\n  ],\n  description: 'Calculate the inverse cotangent of a value.',\n  examples: [\n    'acsc(2)',\n    'acsc(csc(0.5))',\n    'acsc(0.5)'\n  ],\n  seealso: [\n    'csc',\n    'asin',\n    'asec'\n  ]\n}\n","export const acschDocs = {\n  name: 'acsch',\n  category: 'Trigonometry',\n  syntax: [\n    'acsch(x)'\n  ],\n  description: 'Calculate the hyperbolic arccosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.',\n  examples: [\n    'acsch(0.5)'\n  ],\n  seealso: [\n    'asech',\n    'acoth'\n  ]\n}\n","export const asecDocs = {\n  name: 'asec',\n  category: 'Trigonometry',\n  syntax: [\n    'asec(x)'\n  ],\n  description: 'Calculate the inverse secant of a value.',\n  examples: [\n    'asec(0.5)',\n    'asec(sec(0.5))',\n    'asec(2)'\n  ],\n  seealso: [\n    'acos',\n    'acot',\n    'acsc'\n  ]\n}\n","export const asechDocs = {\n  name: 'asech',\n  category: 'Trigonometry',\n  syntax: [\n    'asech(x)'\n  ],\n  description: 'Calculate the inverse secant of a value.',\n  examples: [\n    'asech(0.5)'\n  ],\n  seealso: [\n    'acsch',\n    'acoth'\n  ]\n}\n","export const asinDocs = {\n  name: 'asin',\n  category: 'Trigonometry',\n  syntax: [\n    'asin(x)'\n  ],\n  description: 'Compute the inverse sine of a value in radians.',\n  examples: [\n    'asin(0.5)',\n    'asin(sin(0.5))'\n  ],\n  seealso: [\n    'sin',\n    'acos',\n    'atan'\n  ]\n}\n","export const asinhDocs = {\n  name: 'asinh',\n  category: 'Trigonometry',\n  syntax: [\n    'asinh(x)'\n  ],\n  description: 'Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.',\n  examples: [\n    'asinh(0.5)'\n  ],\n  seealso: [\n    'acosh',\n    'atanh'\n  ]\n}\n","export const atanDocs = {\n  name: 'atan',\n  category: 'Trigonometry',\n  syntax: [\n    'atan(x)'\n  ],\n  description: 'Compute the inverse tangent of a value in radians.',\n  examples: [\n    'atan(0.5)',\n    'atan(tan(0.5))'\n  ],\n  seealso: [\n    'tan',\n    'acos',\n    'asin'\n  ]\n}\n","export const atanhDocs = {\n  name: 'atanh',\n  category: 'Trigonometry',\n  syntax: [\n    'atanh(x)'\n  ],\n  description: 'Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.',\n  examples: [\n    'atanh(0.5)'\n  ],\n  seealso: [\n    'acosh',\n    'asinh'\n  ]\n}\n","export const atan2Docs = {\n  name: 'atan2',\n  category: 'Trigonometry',\n  syntax: [\n    'atan2(y, x)'\n  ],\n  description:\n      'Computes the principal value of the arc tangent of y/x in radians.',\n  examples: [\n    'atan2(2, 2) / pi',\n    'angle = 60 deg in rad',\n    'x = cos(angle)',\n    'y = sin(angle)',\n    'atan2(y, x)'\n  ],\n  seealso: [\n    'sin',\n    'cos',\n    'tan'\n  ]\n}\n","export const cosDocs = {\n  name: 'cos',\n  category: 'Trigonometry',\n  syntax: [\n    'cos(x)'\n  ],\n  description: 'Compute the cosine of x in radians.',\n  examples: [\n    'cos(2)',\n    'cos(pi / 4) ^ 2',\n    'cos(180 deg)',\n    'cos(60 deg)',\n    'sin(0.2)^2 + cos(0.2)^2'\n  ],\n  seealso: [\n    'acos',\n    'sin',\n    'tan'\n  ]\n}\n","export const coshDocs = {\n  name: 'cosh',\n  category: 'Trigonometry',\n  syntax: [\n    'cosh(x)'\n  ],\n  description: 'Compute the hyperbolic cosine of x in radians.',\n  examples: [\n    'cosh(0.5)'\n  ],\n  seealso: [\n    'sinh',\n    'tanh',\n    'coth'\n  ]\n}\n","export const cotDocs = {\n  name: 'cot',\n  category: 'Trigonometry',\n  syntax: [\n    'cot(x)'\n  ],\n  description: 'Compute the cotangent of x in radians. Defined as 1/tan(x)',\n  examples: [\n    'cot(2)',\n    '1 / tan(2)'\n  ],\n  seealso: [\n    'sec',\n    'csc',\n    'tan'\n  ]\n}\n","export const cothDocs = {\n  name: 'coth',\n  category: 'Trigonometry',\n  syntax: [\n    'coth(x)'\n  ],\n  description: 'Compute the hyperbolic cotangent of x in radians.',\n  examples: [\n    'coth(2)',\n    '1 / tanh(2)'\n  ],\n  seealso: [\n    'sech',\n    'csch',\n    'tanh'\n  ]\n}\n","export const cscDocs = {\n  name: 'csc',\n  category: 'Trigonometry',\n  syntax: [\n    'csc(x)'\n  ],\n  description: 'Compute the cosecant of x in radians. Defined as 1/sin(x)',\n  examples: [\n    'csc(2)',\n    '1 / sin(2)'\n  ],\n  seealso: [\n    'sec',\n    'cot',\n    'sin'\n  ]\n}\n","export const cschDocs = {\n  name: 'csch',\n  category: 'Trigonometry',\n  syntax: [\n    'csch(x)'\n  ],\n  description: 'Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)',\n  examples: [\n    'csch(2)',\n    '1 / sinh(2)'\n  ],\n  seealso: [\n    'sech',\n    'coth',\n    'sinh'\n  ]\n}\n","export const secDocs = {\n  name: 'sec',\n  category: 'Trigonometry',\n  syntax: [\n    'sec(x)'\n  ],\n  description: 'Compute the secant of x in radians. Defined as 1/cos(x)',\n  examples: [\n    'sec(2)',\n    '1 / cos(2)'\n  ],\n  seealso: [\n    'cot',\n    'csc',\n    'cos'\n  ]\n}\n","export const sechDocs = {\n  name: 'sech',\n  category: 'Trigonometry',\n  syntax: [\n    'sech(x)'\n  ],\n  description: 'Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)',\n  examples: [\n    'sech(2)',\n    '1 / cosh(2)'\n  ],\n  seealso: [\n    'coth',\n    'csch',\n    'cosh'\n  ]\n}\n","export const sinDocs = {\n  name: 'sin',\n  category: 'Trigonometry',\n  syntax: [\n    'sin(x)'\n  ],\n  description: 'Compute the sine of x in radians.',\n  examples: [\n    'sin(2)',\n    'sin(pi / 4) ^ 2',\n    'sin(90 deg)',\n    'sin(30 deg)',\n    'sin(0.2)^2 + cos(0.2)^2'\n  ],\n  seealso: [\n    'asin',\n    'cos',\n    'tan'\n  ]\n}\n","export const sinhDocs = {\n  name: 'sinh',\n  category: 'Trigonometry',\n  syntax: [\n    'sinh(x)'\n  ],\n  description: 'Compute the hyperbolic sine of x in radians.',\n  examples: [\n    'sinh(0.5)'\n  ],\n  seealso: [\n    'cosh',\n    'tanh'\n  ]\n}\n","export const tanDocs = {\n  name: 'tan',\n  category: 'Trigonometry',\n  syntax: [\n    'tan(x)'\n  ],\n  description: 'Compute the tangent of x in radians.',\n  examples: [\n    'tan(0.5)',\n    'sin(0.5) / cos(0.5)',\n    'tan(pi / 4)',\n    'tan(45 deg)'\n  ],\n  seealso: [\n    'atan',\n    'sin',\n    'cos'\n  ]\n}\n","export const tanhDocs = {\n  name: 'tanh',\n  category: 'Trigonometry',\n  syntax: [\n    'tanh(x)'\n  ],\n  description: 'Compute the hyperbolic tangent of x in radians.',\n  examples: [\n    'tanh(0.5)',\n    'sinh(0.5) / cosh(0.5)'\n  ],\n  seealso: [\n    'sinh',\n    'cosh'\n  ]\n}\n","export const toDocs = {\n  name: 'to',\n  category: 'Units',\n  syntax: [\n    'x to unit',\n    'to(x, unit)'\n  ],\n  description: 'Change the unit of a value.',\n  examples: [\n    '5 inch to cm',\n    '3.2kg to g',\n    '16 bytes in bits'\n  ],\n  seealso: []\n}\n","export const cloneDocs = {\n  name: 'clone',\n  category: 'Utils',\n  syntax: [\n    'clone(x)'\n  ],\n  description: 'Clone a variable. Creates a copy of primitive variables,and a deep copy of matrices',\n  examples: [\n    'clone(3.5)',\n    'clone(2 - 4i)',\n    'clone(45 deg)',\n    'clone([1, 2; 3, 4])',\n    'clone(\"hello world\")'\n  ],\n  seealso: []\n}\n","export const formatDocs = {\n  name: 'format',\n  category: 'Utils',\n  syntax: [\n    'format(value)',\n    'format(value, precision)'\n  ],\n  description: 'Format a value of any type as string.',\n  examples: [\n    'format(2.3)',\n    'format(3 - 4i)',\n    'format([])',\n    'format(pi, 3)'\n  ],\n  seealso: ['print']\n}\n","export const binDocs = {\n  name: 'bin',\n  category: 'Utils',\n  syntax: [\n    'bin(value)'\n  ],\n  description: 'Format a number as binary',\n  examples: [\n    'bin(2)'\n  ],\n  seealso: ['oct', 'hex']\n}\n","export const octDocs = {\n  name: 'oct',\n  category: 'Utils',\n  syntax: [\n    'oct(value)'\n  ],\n  description: 'Format a number as octal',\n  examples: [\n    'oct(56)'\n  ],\n  seealso: ['bin', 'hex']\n}\n","export const hexDocs = {\n  name: 'hex',\n  category: 'Utils',\n  syntax: [\n    'hex(value)'\n  ],\n  description: 'Format a number as hexadecimal',\n  examples: [\n    'hex(240)'\n  ],\n  seealso: ['bin', 'oct']\n}\n","export const isNaNDocs = {\n  name: 'isNaN',\n  category: 'Utils',\n  syntax: [\n    'isNaN(x)'\n  ],\n  description: 'Test whether a value is NaN (not a number)',\n  examples: [\n    'isNaN(2)',\n    'isNaN(0 / 0)',\n    'isNaN(NaN)',\n    'isNaN(Infinity)'\n  ],\n  seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isIntegerDocs = {\n  name: 'isInteger',\n  category: 'Utils',\n  syntax: [\n    'isInteger(x)'\n  ],\n  description: 'Test whether a value is an integer number.',\n  examples: [\n    'isInteger(2)',\n    'isInteger(3.5)',\n    'isInteger([3, 0.5, -2])'\n  ],\n  seealso: ['isNegative', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isNegativeDocs = {\n  name: 'isNegative',\n  category: 'Utils',\n  syntax: [\n    'isNegative(x)'\n  ],\n  description: 'Test whether a value is negative: smaller than zero.',\n  examples: [\n    'isNegative(2)',\n    'isNegative(0)',\n    'isNegative(-4)',\n    'isNegative([3, 0.5, -2])'\n  ],\n  seealso: ['isInteger', 'isNumeric', 'isPositive', 'isZero']\n}\n","export const isNumericDocs = {\n  name: 'isNumeric',\n  category: 'Utils',\n  syntax: [\n    'isNumeric(x)'\n  ],\n  description: 'Test whether a value is a numeric value. ' +\n    'Returns true when the input is a number, BigNumber, Fraction, or boolean.',\n  examples: [\n    'isNumeric(2)',\n    'isNumeric(\"2\")',\n    'hasNumericValue(\"2\")',\n    'isNumeric(0)',\n    'isNumeric(bignumber(500))',\n    'isNumeric(fraction(0.125))',\n    'isNumeric(2 + 3i)',\n    'isNumeric([2.3, \"foo\", false])'\n  ],\n  seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'hasNumericValue']\n}\n","export const hasNumericValueDocs = {\n  name: 'hasNumericValue',\n  category: 'Utils',\n  syntax: [\n    'hasNumericValue(x)'\n  ],\n  description: 'Test whether a value is an numeric value. ' +\n    'In case of a string, true is returned if the string contains a numeric value.',\n  examples: [\n    'hasNumericValue(2)',\n    'hasNumericValue(\"2\")',\n    'isNumeric(\"2\")',\n    'hasNumericValue(0)',\n    'hasNumericValue(bignumber(500))',\n    'hasNumericValue(fraction(0.125))',\n    'hasNumericValue(2 + 3i)',\n    'hasNumericValue([2.3, \"foo\", false])'\n  ],\n  seealso: ['isInteger', 'isZero', 'isNegative', 'isPositive', 'isNaN', 'isNumeric']\n}\n","export const isPositiveDocs = {\n  name: 'isPositive',\n  category: 'Utils',\n  syntax: [\n    'isPositive(x)'\n  ],\n  description: 'Test whether a value is positive: larger than zero.',\n  examples: [\n    'isPositive(2)',\n    'isPositive(0)',\n    'isPositive(-4)',\n    'isPositive([3, 0.5, -2])'\n  ],\n  seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n}\n","export const isPrimeDocs = {\n  name: 'isPrime',\n  category: 'Utils',\n  syntax: [\n    'isPrime(x)'\n  ],\n  description: 'Test whether a value is prime: has no divisors other than itself and one.',\n  examples: [\n    'isPrime(3)',\n    'isPrime(-2)',\n    'isPrime([2, 17, 100])'\n  ],\n  seealso: ['isInteger', 'isNumeric', 'isNegative', 'isZero']\n}\n","export const isZeroDocs = {\n  name: 'isZero',\n  category: 'Utils',\n  syntax: [\n    'isZero(x)'\n  ],\n  description: 'Test whether a value is zero.',\n  examples: [\n    'isZero(2)',\n    'isZero(0)',\n    'isZero(-4)',\n    'isZero([3, 0, -2, 0])'\n  ],\n  seealso: ['isInteger', 'isNumeric', 'isNegative', 'isPositive']\n}\n","export const printDocs = {\n  name: 'print',\n  category: 'Utils',\n  syntax: [\n    'print(template, values)',\n    'print(template, values, precision)'\n  ],\n  description: 'Interpolate values into a string template.',\n  examples: [\n    'print(\"Lucy is $age years old\", {age: 5})',\n    'print(\"The value of pi is $pi\", {pi: pi}, 3)',\n    'print(\"Hello, $user.name!\", {user: {name: \"John\"}})',\n    'print(\"Values: $1, $2, $3\", [6, 9, 4])'\n  ],\n  seealso: ['format']\n}\n","export const typeOfDocs = {\n  name: 'typeOf',\n  category: 'Utils',\n  syntax: [\n    'typeOf(x)'\n  ],\n  description: 'Get the type of a variable.',\n  examples: [\n    'typeOf(3.5)',\n    'typeOf(2 - 4i)',\n    'typeOf(45 deg)',\n    'typeOf(\"hello world\")'\n  ],\n  seealso: ['getMatrixDataType']\n}\n","export const numericDocs = {\n  name: 'numeric',\n  category: 'Utils',\n  syntax: [\n    'numeric(x)'\n  ],\n  description: 'Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.',\n  examples: [\n    'numeric(\"4\")',\n    'numeric(\"4\", \"number\")',\n    'numeric(\"4\", \"bigint\")',\n    'numeric(\"4\", \"BigNumber\")',\n    'numeric(\"4\", \"Fraction\")',\n    'numeric(4, \"Fraction\")',\n    'numeric(fraction(2, 5), \"number\")'\n  ],\n  seealso: ['number', 'bigint', 'fraction', 'bignumber', 'string', 'format']\n}\n","import { factory } from '../../utils/factory.js'\nimport { getSafeProperty } from '../../utils/customs.js'\nimport { embeddedDocs } from '../embeddedDocs/embeddedDocs.js'\nimport { hasOwnProperty } from '../../utils/object.js'\n\nconst name = 'help'\nconst dependencies = ['typed', 'mathWithTransform', 'Help']\n\nexport const createHelp = /* #__PURE__ */ factory(name, dependencies, ({ typed, mathWithTransform, Help }) => {\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 (search) {\n      let prop\n      let searchName = search\n\n      if (typeof search !== 'string') {\n        for (prop in mathWithTransform) {\n          // search in functions and constants\n          if (hasOwnProperty(mathWithTransform, prop) && (search === mathWithTransform[prop])) {\n            searchName = prop\n            break\n          }\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      const doc = getSafeProperty(embeddedDocs, searchName)\n      if (!doc) {\n        const searchText = typeof searchName === 'function' ? searchName.name : searchName\n        throw new Error('No documentation found on \"' + searchText + '\"')\n      }\n      return new Help(doc)\n    }\n  })\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'chain'\nconst dependencies = ['typed', 'Chain']\n\nexport const createChain = /* #__PURE__ */ factory(name, dependencies, ({ typed, Chain }) => {\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\n    any: function (value) {\n      return new Chain(value)\n    }\n  })\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { clone } from '../../utils/object.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'det'\nconst dependencies = ['typed', 'matrix', 'subtractScalar', 'multiply', 'divideScalar', 'isZero', 'unaryMinus']\n\nexport const createDet = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtractScalar, multiply, divideScalar, isZero, unaryMinus }) => {\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 (x) {\n      return clone(x)\n    },\n\n    'Array | Matrix': function det (x) {\n      let size\n      if (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 clone(x)\n\n        case 1:\n          // vector\n          if (size[0] === 1) {\n            return clone(x.valueOf()[0])\n          } if (size[0] === 0) {\n            return 1 // det of an empty matrix is per definition 1\n          } else {\n            throw new RangeError('Matrix must be square ' +\n            '(size: ' + format(size) + ')')\n          }\n\n        case 2:\n        {\n          // two-dimensional array\n          const rows = size[0]\n          const cols = size[1]\n          if (rows === cols) {\n            return _det(x.clone().valueOf(), rows, cols)\n          } if (cols === 0) {\n            return 1 // det of an empty matrix is per definition 1\n          } else {\n            throw new RangeError('Matrix must be square ' +\n              '(size: ' + format(size) + ')')\n          }\n        }\n\n        default:\n          // multi dimensional array\n          throw new RangeError('Matrix must be two dimensional ' +\n          '(size: ' + format(size) + ')')\n      }\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  function _det (matrix, rows, cols) {\n    if (rows === 1) {\n      // this is a 1 x 1 matrix\n      return 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 subtractScalar(\n        multiply(matrix[0][0], matrix[1][1]),\n        multiply(matrix[1][0], matrix[0][1])\n      )\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      let negated = false\n      const rowIndices = new Array(rows).fill(0).map((_, i) => i) // matrix index of row i\n      for (let k = 0; k < rows; k++) {\n        let k_ = rowIndices[k]\n        if (isZero(matrix[k_][k])) {\n          let _k\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          if (_k === rows) return matrix[k_][k] // some zero of the type\n        }\n        const piv = matrix[k_][k]\n        const piv_ = k === 0 ? 1 : matrix[rowIndices[k - 1]][k - 1]\n        for (let i = k + 1; i < rows; i++) {\n          const i_ = rowIndices[i]\n          for (let j = k + 1; j < rows; j++) {\n            matrix[i_][j] = divideScalar(subtractScalar(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_)\n          }\n        }\n      }\n      const det = matrix[rowIndices[rows - 1]][rows - 1]\n      return negated ? unaryMinus(det) : det\n    }\n  }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\n\nconst name = 'inv'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'divideScalar',\n  'addScalar',\n  'multiply',\n  'unaryMinus',\n  'det',\n  'identity',\n  'abs'\n]\n\nexport const createInv = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divideScalar, addScalar, multiply, unaryMinus, det, identity, abs }) => {\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 (x) {\n      const size = isMatrix(x) ? x.size() : arraySize(x)\n      switch (size.length) {\n        case 1:\n          // vector\n          if (size[0] === 1) {\n            if (isMatrix(x)) {\n              return matrix([\n                divideScalar(1, x.valueOf()[0])\n              ])\n            } else {\n              return [\n                divideScalar(1, x[0])\n              ]\n            }\n          } else {\n            throw new RangeError('Matrix must be square ' +\n            '(size: ' + format(size) + ')')\n          }\n\n        case 2:\n        // two dimensional array\n        {\n          const rows = size[0]\n          const cols = size[1]\n          if (rows === cols) {\n            if (isMatrix(x)) {\n              return matrix(\n                _inv(x.valueOf(), rows, cols),\n                x.storage()\n              )\n            } else {\n              // return an Array\n              return _inv(x, rows, cols)\n            }\n          } else {\n            throw new RangeError('Matrix must be square ' +\n              '(size: ' + format(size) + ')')\n          }\n        }\n\n        default:\n          // multi dimensional array\n          throw new RangeError('Matrix must be two dimensional ' +\n          '(size: ' + format(size) + ')')\n      }\n    },\n\n    any: function (x) {\n      // scalar\n      return divideScalar(1, x) // FIXME: create a BigNumber one when configured for bignumbers\n    }\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  function _inv (mat, rows, cols) {\n    let r, s, f, value, temp\n\n    if (rows === 1) {\n      // this is a 1 x 1 matrix\n      value = mat[0][0]\n      if (value === 0) {\n        throw Error('Cannot calculate inverse, determinant is zero')\n      }\n      return [[\n        divideScalar(1, value)\n      ]]\n    } else if (rows === 2) {\n      // this is a 2 x 2 matrix\n      const d = det(mat)\n      if (d === 0) {\n        throw Error('Cannot calculate inverse, determinant is zero')\n      }\n      return [\n        [\n          divideScalar(mat[1][1], d),\n          divideScalar(unaryMinus(mat[0][1]), d)\n        ],\n        [\n          divideScalar(unaryMinus(mat[1][0]), d),\n          divideScalar(mat[0][0], d)\n        ]\n      ]\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\n      // make a copy of the matrix (only the arrays, not of the elements)\n      const A = mat.concat()\n      for (r = 0; r < rows; r++) {\n        A[r] = A[r].concat()\n      }\n\n      // create an identity matrix which in the end will contain the\n      // matrix inverse\n      const B = identity(rows).valueOf()\n\n      // loop over all columns, and perform row reductions\n      for (let c = 0; c < cols; c++) {\n        // Pivoting: Swap row c with row r, where row r contains the largest element A[r][c]\n        let ABig = abs(A[c][c])\n        let rBig = c\n        r = c + 1\n        while (r < rows) {\n          if (abs(A[r][c]) > ABig) {\n            ABig = abs(A[r][c])\n            rBig = r\n          }\n          r++\n        }\n        if (ABig === 0) {\n          throw Error('Cannot calculate inverse, determinant is zero')\n        }\n        r = rBig\n        if (r !== c) {\n          temp = A[c]; A[c] = A[r]; A[r] = temp\n          temp = B[c]; B[c] = B[r]; B[r] = temp\n        }\n\n        // eliminate non-zero values on the other rows at column c\n        const Ac = A[c]\n        const Bc = B[c]\n        for (r = 0; r < rows; r++) {\n          const Ar = A[r]\n          const Br = B[r]\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])\n\n              // add (f * row c) to row r to eliminate the value\n              // at column c\n              for (s = c; s < cols; s++) {\n                Ar[s] = addScalar(Ar[s], multiply(f, Ac[s]))\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            for (s = c; s < cols; s++) {\n              Ar[s] = divideScalar(Ar[s], f)\n            }\n            for (s = 0; s < cols; s++) {\n              Br[s] = divideScalar(Br[s], f)\n            }\n          }\n        }\n      }\n      return B\n    }\n  }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\nimport { clone } from '../../utils/object.js'\n\nconst name = 'pinv'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'inv',\n  'deepEqual',\n  'equal',\n  'dotDivide',\n  'dot',\n  'ctranspose',\n  'divideScalar',\n  'multiply',\n  'add',\n  'Complex'\n]\n\nexport const createPinv = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  matrix,\n  inv,\n  deepEqual,\n  equal,\n  dotDivide,\n  dot,\n  ctranspose,\n  divideScalar,\n  multiply,\n  add,\n  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 (x) {\n      const size = isMatrix(x) ? x.size() : arraySize(x)\n      switch (size.length) {\n        case 1:\n          // vector\n          if (_isZeros(x)) return ctranspose(x) // null vector\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          const rows = size[0]\n          const cols = size[1]\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/)) {\n                // Expected\n              } else {\n                throw err\n              }\n            }\n          }\n          if (isMatrix(x)) {\n            return matrix(\n              _pinv(x.valueOf(), rows, cols),\n              x.storage()\n            )\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 ' +\n          '(size: ' + format(size) + ')')\n      }\n    },\n\n    any: function (x) {\n      // scalar\n      if (equal(x, 0)) return clone(x) // zero\n      return divideScalar(1, x)\n    }\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  function _pinv (mat, rows, cols) {\n    const { C, F } = _rankFact(mat, rows, cols) // TODO: Use SVD instead (may improve precision)\n    const Cpinv = multiply(inv(multiply(ctranspose(C), C)), ctranspose(C))\n    const Fpinv = multiply(ctranspose(F), inv(multiply(F, ctranspose(F))))\n    return multiply(Fpinv, Cpinv)\n  }\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  function _rref (mat, rows, cols) {\n    const M = clone(mat)\n    let lead = 0\n    for (let r = 0; r < rows; r++) {\n      if (cols <= lead) {\n        return M\n      }\n      let i = r\n      while (_isZero(M[i][lead])) {\n        i++\n        if (rows === i) {\n          i = r\n          lead++\n          if (cols === lead) {\n            return M\n          }\n        }\n      }\n\n      [M[i], M[r]] = [M[r], M[i]]\n\n      let val = M[r][lead]\n      for (let j = 0; j < cols; j++) {\n        M[r][j] = dotDivide(M[r][j], val)\n      }\n\n      for (let i = 0; i < rows; i++) {\n        if (i === r) continue\n        val = M[i][lead]\n        for (let j = 0; j < cols; j++) {\n          M[i][j] = add(M[i][j], multiply(-1, multiply(val, M[r][j])))\n        }\n      }\n      lead++\n    }\n    return M\n  }\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  function _rankFact (mat, rows, cols) {\n    const rref = _rref(mat, rows, cols)\n    const C = mat.map((_, i) => _.filter((_, j) => j < rows && !_isZero(dot(rref[j], rref[j]))))\n    const F = rref.filter((_, i) => !_isZero(dot(rref[i], rref[i])))\n    return { C, F }\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})\n","import { factory } from '../../utils/factory.js'\nimport { format } from '../../utils/string.js'\nimport { createComplexEigs } from './eigs/complexEigs.js'\nimport { createRealSymmetric } from './eigs/realSymmetric.js'\nimport { typeOf, isNumber, isBigNumber, isComplex, isFraction } from '../../utils/is.js'\n\nconst name = 'eigs'\n\n// The absolute state of math.js's dependency system:\nconst dependencies = ['config', 'typed', 'matrix', 'addScalar', 'equal', 'subtract', 'abs', 'atan', 'cos', 'sin', 'multiplyScalar', 'divideScalar', 'inv', 'bignumber', 'multiply', 'add', 'larger', 'column', 'flatten', 'number', 'complex', 'sqrt', 'diag', 'size', 'reshape', 'qr', 'usolve', 'usolveAll', 'im', 're', 'smaller', 'matrixFromColumns', 'dot']\nexport const createEigs = /* #__PURE__ */ factory(name, dependencies, ({ config, typed, matrix, addScalar, subtract, equal, abs, atan, cos, sin, multiplyScalar, divideScalar, inv, bignumber, multiply, add, larger, column, flatten, number, complex, sqrt, diag, size, reshape, qr, usolve, usolveAll, im, re, smaller, matrixFromColumns, dot }) => {\n  const doRealSymmetric = createRealSymmetric({ config, addScalar, subtract, column, flatten, equal, abs, atan, cos, sin, multiplyScalar, inv, bignumber, complex, multiply, add })\n  const doComplexEigs = createComplexEigs({ config, addScalar, subtract, multiply, multiplyScalar, flatten, divideScalar, sqrt, abs, bignumber, diag, size, reshape, qr, inv, usolve, usolveAll, equal, complex, larger, smaller, matrixFromColumns, dot })\n\n  /**\n   * Compute eigenvalues and optionally eigenvectors of a square matrix.\n   * The eigenvalues are sorted by their absolute value, ascending, and\n   * returned as a vector in the `values` property of the returned project.\n   * An eigenvalue with algebraic multiplicity k will be listed k times, so\n   * that the returned `values` vector always has length equal to the size\n   * of the input matrix.\n   *\n   * The `eigenvectors` property of the return value provides the eigenvectors.\n   * It is an array of plain objects: the `value` property of each gives the\n   * associated eigenvalue, and the `vector` property gives the eigenvector\n   * itself. Note that the same `value` property will occur as many times in\n   * the list provided by `eigenvectors` as the geometric multiplicity of\n   * that value.\n   *\n   * If the algorithm fails to converge, it will throw an error –\n   * in that case, however, you may still find useful information\n   * in `err.values` and `err.vectors`.\n   *\n   * Note that the 'precision' option does not directly specify the _accuracy_\n   * of the returned eigenvalues. Rather, it determines how small an entry\n   * of the iterative approximations to an upper triangular matrix must be\n   * in order to be considered zero. The actual accuracy of the returned\n   * eigenvalues may be greater or less than the precision, depending on the\n   * conditioning of the matrix and how far apart or close the actual\n   * eigenvalues are. Note that currently, relatively simple, \"traditional\"\n   * methods of eigenvalue computation are being used; this is not a modern,\n   * high-precision eigenvalue computation. That said, it should typically\n   * produce fairly reasonable results.\n   *\n   * Syntax:\n   *\n   *     math.eigs(x, [prec])\n   *     math.eigs(x, {options})\n   *\n   * Examples:\n   *\n   *     const { eigs, multiply, column, transpose, matrixFromColumns } = math\n   *     const H = [[5, 2.3], [2.3, 1]]\n   *     const ans = eigs(H) // returns {values: [E1,E2...sorted], eigenvectors: [{value: E1, vector: v2}, {value: e, vector: v2}, ...]\n   *     const E = ans.values\n   *     const V = ans.eigenvectors\n   *     multiply(H, V[0].vector)) // returns multiply(E[0], V[0].vector))\n   *     const U = matrixFromColumns(...V.map(obj => obj.vector))\n   *     const UTxHxU = multiply(transpose(U), H, U) // diagonalizes H if possible\n   *     E[0] == UTxHxU[0][0]  // returns true always\n   *\n   *     // Compute only approximate eigenvalues:\n   *     const {values} = eigs(H, {eigenvectors: false, precision: 1e-6})\n   *\n   * See also:\n   *\n   *     inv\n   *\n   * @param {Array | Matrix} x  Matrix to be diagonalized\n   *\n   * @param {number | BigNumber | OptsObject} [opts] Object with keys `precision`, defaulting to config.relTol, and `eigenvectors`, defaulting to true and specifying whether to compute eigenvectors. If just a number, specifies precision.\n   * @return {{values: Array|Matrix, eigenvectors?: Array<EVobj>}} Object containing an array of eigenvalues and an array of {value: number|BigNumber, vector: Array|Matrix} objects. The eigenvectors property is undefined if eigenvectors were not requested.\n   *\n   */\n  return typed('eigs', {\n\n    // The conversion to matrix in the first two implementations,\n    // just to convert back to an array right away in\n    // computeValuesAndVectors, is unfortunate, and should perhaps be\n    // streamlined. It is done because the Matrix object carries some\n    // type information about its entries, and so constructing the matrix\n    // is a roundabout way of doing type detection.\n    Array: function (x) { return doEigs(matrix(x)) },\n    'Array, number|BigNumber': function (x, prec) {\n      return doEigs(matrix(x), { precision: prec })\n    },\n    'Array, Object' (x, opts) { return doEigs(matrix(x), opts) },\n    Matrix: function (mat) {\n      return doEigs(mat, { matricize: true })\n    },\n    'Matrix, number|BigNumber': function (mat, prec) {\n      return doEigs(mat, { precision: prec, matricize: true })\n    },\n    'Matrix, Object': function (mat, opts) {\n      const useOpts = { matricize: true }\n      Object.assign(useOpts, opts)\n      return doEigs(mat, useOpts)\n    }\n  })\n\n  function doEigs (mat, opts = {}) {\n    const computeVectors = 'eigenvectors' in opts ? opts.eigenvectors : true\n    const prec = opts.precision ?? config.relTol\n    const result = computeValuesAndVectors(mat, prec, computeVectors)\n    if (opts.matricize) {\n      result.values = matrix(result.values)\n      if (computeVectors) {\n        result.eigenvectors = result.eigenvectors.map(({ value, vector }) =>\n          ({ value, vector: matrix(vector) }))\n      }\n    }\n    if (computeVectors) {\n      Object.defineProperty(result, 'vectors', {\n        enumerable: false, // to make sure that the eigenvectors can still be\n        // converted to string.\n        get: () => {\n          throw new Error('eigs(M).vectors replaced with eigs(M).eigenvectors')\n        }\n      })\n    }\n    return result\n  }\n\n  function computeValuesAndVectors (mat, prec, computeVectors) {\n    const arr = mat.toArray() // NOTE: arr is guaranteed to be unaliased\n    // and so safe to modify in place\n    const asize = mat.size()\n\n    if (asize.length !== 2 || asize[0] !== asize[1]) {\n      throw new RangeError(`Matrix must be square (size: ${format(asize)})`)\n    }\n\n    const N = asize[0]\n\n    if (isReal(arr, N, prec)) {\n      coerceReal(arr, N) // modifies arr by side effect\n\n      if (isSymmetric(arr, N, prec)) {\n        const type = coerceTypes(mat, arr, N) // modifies arr by side effect\n        return doRealSymmetric(arr, N, prec, type, computeVectors)\n      }\n    }\n\n    const type = coerceTypes(mat, arr, N) // modifies arr by side effect\n    return doComplexEigs(arr, N, prec, type, computeVectors)\n  }\n\n  /** @return {boolean} */\n  function isSymmetric (arr, N, prec) {\n    for (let i = 0; i < N; i++) {\n      for (let 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\n  /** @return {boolean} */\n  function isReal (arr, N, prec) {\n    for (let i = 0; i < N; i++) {\n      for (let 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 (let i = 0; i < N; i++) {\n      for (let j = 0; j < N; j++) {\n        arr[i][j] = re(arr[i][j])\n      }\n    }\n  }\n\n  /** @return {'number' | 'BigNumber' | 'Complex'} */\n  function coerceTypes (mat, arr, N) {\n    /** @type {string} */\n    const type = mat.datatype()\n\n    if (type === 'number' || type === 'BigNumber' || type === 'Complex') {\n      return type\n    }\n\n    let hasNumber = false\n    let hasBig = false\n    let hasComplex = false\n\n    for (let i = 0; i < N; i++) {\n      for (let j = 0; j < N; j++) {\n        const el = arr[i][j]\n\n        if (isNumber(el) || isFraction(el)) {\n          hasNumber = true\n        } else if (isBigNumber(el)) {\n          hasBig = true\n        } else if (isComplex(el)) {\n          hasComplex = true\n        } else {\n          throw TypeError('Unsupported type in Matrix: ' + 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 (let i = 0; i < N; i++) {\n        for (let 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 (let i = 0; i < N; i++) {\n        for (let j = 0; j < N; j++) {\n          arr[i][j] = bignumber(arr[i][j])\n        }\n      }\n\n      return 'BigNumber'\n    }\n\n    if (hasNumber) {\n      for (let i = 0; i < N; i++) {\n        for (let j = 0; j < N; j++) {\n          arr[i][j] = number(arr[i][j])\n        }\n      }\n\n      return 'number'\n    } else {\n      throw TypeError('Matrix contains unsupported types only.')\n    }\n  }\n})\n","import { clone } from '../../../utils/object.js'\n\nexport function createRealSymmetric ({ config, addScalar, subtract, abs, atan, cos, sin, multiplyScalar, inv, bignumber, multiply, add }) {\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, prec = config.relTol, type, computeVectors) {\n    if (type === 'number') {\n      return diag(arr, prec, computeVectors)\n    }\n\n    if (type === 'BigNumber') {\n      return diagBig(arr, prec, computeVectors)\n    }\n\n    throw TypeError('Unsupported data type: ' + type)\n  }\n\n  // diagonalization implementation for number (efficient)\n  function diag (x, precision, computeVectors) {\n    const N = x.length\n    const e0 = Math.abs(precision / N)\n    let psi\n    let Sij\n    if (computeVectors) {\n      Sij = new Array(N)\n      // Sij is Identity Matrix\n      for (let i = 0; i < N; i++) {\n        Sij[i] = Array(N).fill(0)\n        Sij[i][i] = 1.0\n      }\n    }\n    // initial error\n    let Vab = getAij(x)\n    while (Math.abs(Vab[1]) >= Math.abs(e0)) {\n      const i = Vab[0][0]\n      const j = Vab[0][1]\n      psi = getTheta(x[i][i], x[j][j], x[i][j])\n      x = x1(x, psi, i, j)\n      if (computeVectors) Sij = Sij1(Sij, psi, i, j)\n      Vab = getAij(x)\n    }\n    const Ei = Array(N).fill(0) // eigenvalues\n    for (let i = 0; i < N; i++) {\n      Ei[i] = x[i][i]\n    }\n    return sorting(clone(Ei), Sij, computeVectors)\n  }\n\n  // diagonalization implementation for bigNumber\n  function diagBig (x, precision, computeVectors) {\n    const N = x.length\n    const e0 = abs(precision / N)\n    let psi\n    let Sij\n    if (computeVectors) {\n      Sij = new Array(N)\n      // Sij is Identity Matrix\n      for (let i = 0; i < N; i++) {\n        Sij[i] = Array(N).fill(0)\n        Sij[i][i] = 1.0\n      }\n    }\n    // initial error\n    let Vab = getAijBig(x)\n    while (abs(Vab[1]) >= abs(e0)) {\n      const i = Vab[0][0]\n      const j = Vab[0][1]\n      psi = getThetaBig(x[i][i], x[j][j], x[i][j])\n      x = x1Big(x, psi, i, j)\n      if (computeVectors) Sij = Sij1Big(Sij, psi, i, j)\n      Vab = getAijBig(x)\n    }\n    const Ei = Array(N).fill(0) // eigenvalues\n    for (let i = 0; i < N; i++) {\n      Ei[i] = x[i][i]\n    }\n    // return [clone(Ei), clone(Sij)]\n    return sorting(clone(Ei), Sij, computeVectors)\n  }\n\n  // get angle\n  function getTheta (aii, ajj, aij) {\n    const denom = (ajj - aii)\n    if (Math.abs(denom) <= config.relTol) {\n      return Math.PI / 4.0\n    } else {\n      return 0.5 * Math.atan(2.0 * aij / (ajj - aii))\n    }\n  }\n\n  // get angle\n  function getThetaBig (aii, ajj, aij) {\n    const denom = subtract(ajj, aii)\n    if (abs(denom) <= config.relTol) {\n      return bignumber(-1).acos().div(4)\n    } else {\n      return multiplyScalar(0.5, atan(multiply(2.0, aij, inv(denom))))\n    }\n  }\n\n  // update eigvec\n  function Sij1 (Sij, theta, i, j) {\n    const N = Sij.length\n    const c = Math.cos(theta)\n    const s = Math.sin(theta)\n    const Ski = Array(N).fill(0)\n    const Skj = Array(N).fill(0)\n    for (let 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    for (let k = 0; k < N; k++) {\n      Sij[k][i] = Ski[k]\n      Sij[k][j] = Skj[k]\n    }\n    return Sij\n  }\n  // update eigvec for overlap\n  function Sij1Big (Sij, theta, i, j) {\n    const N = Sij.length\n    const c = cos(theta)\n    const s = sin(theta)\n    const Ski = Array(N).fill(bignumber(0))\n    const Skj = Array(N).fill(bignumber(0))\n    for (let 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    for (let k = 0; k < N; k++) {\n      Sij[k][i] = Ski[k]\n      Sij[k][j] = Skj[k]\n    }\n    return Sij\n  }\n\n  // update matrix\n  function x1Big (Hij, theta, i, j) {\n    const N = Hij.length\n    const c = bignumber(cos(theta))\n    const s = bignumber(sin(theta))\n    const c2 = multiplyScalar(c, c)\n    const s2 = multiplyScalar(s, s)\n    const Aki = Array(N).fill(bignumber(0))\n    const Akj = Array(N).fill(bignumber(0))\n    // 2cs Hij\n    const csHij = multiply(bignumber(2), c, s, Hij[i][j])\n    //  Aii\n    const Aii = addScalar(subtract(multiplyScalar(c2, Hij[i][i]), csHij), multiplyScalar(s2, Hij[j][j]))\n    const Ajj = add(multiplyScalar(s2, Hij[i][i]), csHij, multiplyScalar(c2, Hij[j][j]))\n    // 0  to i\n    for (let 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    }\n    // Modify Hij\n    Hij[i][i] = Aii\n    Hij[j][j] = Ajj\n    Hij[i][j] = bignumber(0)\n    Hij[j][i] = bignumber(0)\n    // 0  to i\n    for (let k = 0; k < N; k++) {\n      if (k !== i && k !== j) {\n        Hij[i][k] = Aki[k]\n        Hij[k][i] = Aki[k]\n        Hij[j][k] = Akj[k]\n        Hij[k][j] = Akj[k]\n      }\n    }\n    return Hij\n  }\n\n  // update matrix\n  function x1 (Hij, theta, i, j) {\n    const N = Hij.length\n    const c = Math.cos(theta)\n    const s = Math.sin(theta)\n    const c2 = c * c\n    const s2 = s * s\n    const Aki = Array(N).fill(0)\n    const Akj = Array(N).fill(0)\n    //  Aii\n    const Aii = c2 * Hij[i][i] - 2 * c * s * Hij[i][j] + s2 * Hij[j][j]\n    const Ajj = s2 * Hij[i][i] + 2 * c * s * Hij[i][j] + c2 * Hij[j][j]\n    // 0  to i\n    for (let 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    }\n    // Modify Hij\n    Hij[i][i] = Aii\n    Hij[j][j] = Ajj\n    Hij[i][j] = 0\n    Hij[j][i] = 0\n    // 0  to i\n    for (let k = 0; k < N; k++) {\n      if (k !== i && k !== j) {\n        Hij[i][k] = Aki[k]\n        Hij[k][i] = Aki[k]\n        Hij[j][k] = Akj[k]\n        Hij[k][j] = Akj[k]\n      }\n    }\n    return Hij\n  }\n\n  // get max off-diagonal value from Upper Diagonal\n  function getAij (Mij) {\n    const N = Mij.length\n    let maxMij = 0\n    let maxIJ = [0, 1]\n    for (let i = 0; i < N; i++) {\n      for (let 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    return [maxIJ, maxMij]\n  }\n\n  // get max off-diagonal value from Upper Diagonal\n  function getAijBig (Mij) {\n    const N = Mij.length\n    let maxMij = 0\n    let maxIJ = [0, 1]\n    for (let i = 0; i < N; i++) {\n      for (let 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    return [maxIJ, maxMij]\n  }\n\n  // sort results\n  function sorting (E, S, computeVectors) {\n    const N = E.length\n    const values = Array(N)\n    let vecs\n    if (computeVectors) {\n      vecs = Array(N)\n      for (let k = 0; k < N; k++) {\n        vecs[k] = Array(N)\n      }\n    }\n    for (let i = 0; i < N; i++) {\n      let minID = 0\n      let minE = E[0]\n      for (let j = 0; j < E.length; j++) {\n        if (abs(E[j]) < abs(minE)) {\n          minID = j\n          minE = E[minID]\n        }\n      }\n      values[i] = E.splice(minID, 1)[0]\n      if (computeVectors) {\n        for (let k = 0; k < N; k++) {\n          vecs[i][k] = S[k][minID]\n          S[k].splice(minID, 1)\n        }\n      }\n    }\n    if (!computeVectors) return { values }\n    const eigenvectors = vecs.map((vector, i) => ({ value: values[i], vector }))\n    return { values, eigenvectors }\n  }\n\n  return main\n}\n","import { clone } from '../../../utils/object.js'\n\nexport function createComplexEigs ({ addScalar, subtract, flatten, multiply, multiplyScalar, divideScalar, sqrt, abs, bignumber, diag, size, reshape, inv, qr, usolve, usolveAll, equal, complex, larger, smaller, matrixFromColumns, dot }) {\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 = true) {\n    // TODO check if any row/col are zero except the diagonal\n\n    // make sure corresponding rows and columns have similar magnitude\n    // important because of numerical stability\n    // MODIFIES arr by side effect!\n    const R = balance(arr, N, prec, type, findVectors)\n\n    // R is the row transformation matrix\n    // arr = A' = R A R^-1, A is the original matrix\n    // (if findVectors is false, R is undefined)\n    // (And so to return to original matrix: A = R^-1 arr R)\n\n    // TODO if magnitudes of elements vary over many orders,\n    // move greatest elements to the top left corner\n\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    reduceToHessenberg(arr, N, prec, type, findVectors, R)\n    // still true that original A = R^-1 arr R)\n\n    // find eigenvalues\n    const { values, C } = iterateUntilTriangular(arr, N, prec, type, findVectors)\n\n    // 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^-1 arr C and the relationship between current arr\n    // and original A is unchanged.)\n\n    if (findVectors) {\n      const eigenvectors = findEigenvectors(arr, N, C, R, values, prec, type)\n      return { values, eigenvectors }\n    }\n\n    return { values }\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  function balance (arr, N, prec, type, findVectors) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    const realzero = big ? bignumber(0) : 0\n    const one = big ? bignumber(1) : cplx ? complex(1) : 1\n    const realone = big ? bignumber(1) : 1\n\n    // base of the floating-point arithmetic\n    const radix = big ? bignumber(10) : 2\n    const radixSq = multiplyScalar(radix, radix)\n\n    // the diagonal transformation matrix R\n    let Rdiag\n    if (findVectors) {\n      Rdiag = Array(N).fill(one)\n    }\n\n    // this isn't the only time we loop thru the matrix...\n    let last = false\n\n    while (!last) {\n      // ...haha I'm joking! unless...\n      last = true\n\n      for (let i = 0; i < N; i++) {\n        // compute the taxicab norm of i-th column and row\n        // TODO optimize for complex numbers\n        let colNorm = realzero\n        let rowNorm = realzero\n\n        for (let j = 0; j < N; j++) {\n          if (i === j) continue\n          colNorm = addScalar(colNorm, abs(arr[j][i]))\n          rowNorm = addScalar(rowNorm, abs(arr[i][j]))\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\n          let f = realone\n          let c = colNorm\n\n          const rowDivRadix = divideScalar(rowNorm, radix)\n          const rowMulRadix = multiplyScalar(rowNorm, radix)\n\n          while (smaller(c, rowDivRadix)) {\n            c = multiplyScalar(c, radixSq)\n            f = multiplyScalar(f, radix)\n          }\n          while (larger(c, rowMulRadix)) {\n            c = divideScalar(c, radixSq)\n            f = divideScalar(f, radix)\n          }\n\n          // check whether balancing is needed\n          // condition = (c + rowNorm) / f < 0.95 * (colNorm + rowNorm)\n          const condition = smaller(divideScalar(addScalar(c, rowNorm), f), multiplyScalar(addScalar(colNorm, rowNorm), 0.95))\n\n          // apply balancing similarity transformation\n          if (condition) {\n            // we should loop once again to check whether\n            // another rebalancing is needed\n            last = false\n\n            const g = divideScalar(1, f)\n\n            for (let j = 0; j < N; j++) {\n              if (i === j) {\n                continue\n              }\n              arr[i][j] = multiplyScalar(arr[i][j], g)\n              arr[j][i] = multiplyScalar(arr[j][i], f)\n            }\n\n            // keep track of transformations\n            if (findVectors) {\n              Rdiag[i] = multiplyScalar(Rdiag[i], g)\n            }\n          }\n        }\n      }\n    }\n\n    // return the diagonal row transformation matrix\n    return findVectors ? diag(Rdiag) : null\n  }\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  function reduceToHessenberg (arr, N, prec, type, findVectors, R) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n\n    if (big) { prec = bignumber(prec) }\n\n    for (let i = 0; i < N - 2; i++) {\n      // Find the largest subdiag element in the i-th col\n\n      let maxIndex = 0\n      let max = zero\n\n      for (let j = i + 1; j < N; j++) {\n        const el = arr[j][i]\n        if (smaller(abs(max), abs(el))) {\n          max = el\n          maxIndex = j\n        }\n      }\n\n      // This col is pivoted, no need to do anything\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        const tmp1 = arr[maxIndex]\n        arr[maxIndex] = arr[i + 1]\n        arr[i + 1] = tmp1\n\n        // Interchange maxIndex-th and (i+1)-th column\n        for (let j = 0; j < N; j++) {\n          const tmp2 = arr[j][maxIndex]\n          arr[j][maxIndex] = arr[j][i + 1]\n          arr[j][i + 1] = tmp2\n        }\n\n        // keep track of transformations\n        if (findVectors) {\n          const tmp3 = R[maxIndex]\n          R[maxIndex] = R[i + 1]\n          R[i + 1] = tmp3\n        }\n      }\n\n      // Reduce following rows and columns\n      for (let j = i + 2; j < N; j++) {\n        const n = divideScalar(arr[j][i], max)\n\n        if (n === 0) {\n          continue\n        }\n\n        // from j-th row subtract n-times (i+1)th row\n        for (let k = 0; k < N; k++) {\n          arr[j][k] = subtract(arr[j][k], multiplyScalar(n, arr[i + 1][k]))\n        }\n\n        // to (i+1)th column add n-times j-th column\n        for (let k = 0; k < N; k++) {\n          arr[k][i + 1] = addScalar(arr[k][i + 1], multiplyScalar(n, arr[k][j]))\n        }\n\n        // keep track of transformations\n        if (findVectors) {\n          for (let k = 0; k < N; k++) {\n            R[j][k] = subtract(R[j][k], multiplyScalar(n, R[i + 1][k]))\n          }\n        }\n      }\n    }\n\n    return R\n  }\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  function iterateUntilTriangular (A, N, prec, type, findVectors) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n    if (big) { prec = bignumber(prec) }\n\n    // The Francis Algorithm\n    // The core idea of this algorithm is that doing successive\n    // A' = QtAQ 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    let arr = clone(A)\n\n    // the list of converged eigenvalues\n    const lambdas = []\n\n    // size of arr, which will get smaller as eigenvalues converge\n    let n = N\n\n    // the diagonal of the block-diagonal matrix that turns\n    // converged 2x2 matrices into upper triangular matrices\n    const Sdiag = []\n\n    // N×N matrix describing the overall transformation done during the QR algorithm\n    let Qtotal = findVectors ? diag(Array(N).fill(one)) : undefined\n\n    // nxn matrix describing the QR transformations done since last convergence\n    let Qpartial = findVectors ? diag(Array(n).fill(one)) : undefined\n\n    // last eigenvalue converged before this many steps\n    let lastConvergenceBefore = 0\n\n    while (lastConvergenceBefore <= 100) {\n      lastConvergenceBefore += 1\n\n      // TODO if the convergence is slow, do something clever\n\n      // Perform the factorization\n\n      const k = arr[n - 1][n - 1] // TODO this is apparently a somewhat\n      // old-fashioned choice; ideally set close to an eigenvalue, or\n      // perhaps better yet switch to the implicit QR version that is sometimes\n      // specifically called the \"Francis algorithm\" that is alluded to\n      // in the following TODO. (Or perhaps we switch to an independently\n      // optimized third-party package for the linear algebra operations...)\n\n      for (let i = 0; i < n; i++) {\n        arr[i][i] = subtract(arr[i][i], k)\n      }\n\n      // TODO do an implicit QR transformation\n      const { Q, R } = qr(arr)\n      arr = multiply(R, Q)\n\n      for (let i = 0; i < n; i++) {\n        arr[i][i] = addScalar(arr[i][i], k)\n      }\n\n      // keep track of transformations\n      if (findVectors) {\n        Qpartial = multiply(Qpartial, Q)\n      }\n\n      // The rightmost diagonal element converged to an eigenvalue\n      if (n === 1 || smaller(abs(arr[n - 1][n - 2]), prec)) {\n        lastConvergenceBefore = 0\n        lambdas.push(arr[n - 1][n - 1])\n\n        // keep track of transformations\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        }\n\n        // reduce the matrix size\n        n -= 1\n        arr.pop()\n        for (let i = 0; i < n; i++) {\n          arr[i].pop()\n        }\n\n      // The rightmost diagonal 2x2 block converged\n      } else if (n === 2 || smaller(abs(arr[n - 2][n - 3]), prec)) {\n        lastConvergenceBefore = 0\n        const ll = eigenvalues2x2(\n          arr[n - 2][n - 2], arr[n - 2][n - 1],\n          arr[n - 1][n - 2], arr[n - 1][n - 1]\n        )\n        lambdas.push(...ll)\n\n        // keep track of transformations\n        if (findVectors) {\n          Sdiag.unshift(jordanBase2x2(\n            arr[n - 2][n - 2], arr[n - 2][n - 1],\n            arr[n - 1][n - 2], arr[n - 1][n - 1],\n            ll[0], ll[1], prec, type\n          ))\n          inflateMatrix(Qpartial, N)\n          Qtotal = multiply(Qtotal, Qpartial)\n          if (n > 2) {\n            Qpartial = diag(Array(n - 2).fill(one))\n          }\n        }\n\n        // reduce the matrix size\n        n -= 2\n        arr.pop()\n        arr.pop()\n        for (let i = 0; i < n; i++) {\n          arr[i].pop()\n          arr[i].pop()\n        }\n      }\n\n      if (n === 0) {\n        break\n      }\n    }\n\n    // standard sorting\n    lambdas.sort((a, b) => +subtract(abs(a), abs(b)))\n\n    // the algorithm didn't converge\n    if (lastConvergenceBefore > 100) {\n      const err = Error('The eigenvalues failed to converge. Only found these eigenvalues: ' + lambdas.join(', '))\n      err.values = lambdas\n      err.vectors = []\n      throw err\n    }\n\n    // combine the overall QR transformation Qtotal with the subsequent\n    // transformation S that turns the diagonal 2x2 blocks to upper triangular\n    const C = findVectors ? multiply(Qtotal, blockDiag(Sdiag, N)) : undefined\n\n    return { values: lambdas, 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  function findEigenvectors (A, N, C, R, values, prec, type) {\n    const Cinv = inv(C)\n    const U = multiply(Cinv, A, C)\n\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n    const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n    // turn values into a kind of \"multiset\"\n    // this way it is easier to find eigenvectors\n    const uniqueValues = []\n    const multiplicities = []\n\n    for (const lambda of values) {\n      const i = indexOf(uniqueValues, lambda, equal)\n\n      if (i === -1) {\n        uniqueValues.push(lambda)\n        multiplicities.push(1)\n      } else {\n        multiplicities[i] += 1\n      }\n    }\n\n    // find eigenvectors by solving U − lambdaE = 0\n    // TODO replace with an iterative eigenvector algorithm\n    // (this one might fail for imprecise eigenvalues)\n\n    const vectors = []\n    const len = uniqueValues.length\n    const b = Array(N).fill(zero)\n    const E = diag(Array(N).fill(one))\n\n    for (let i = 0; i < len; i++) {\n      const lambda = uniqueValues[i]\n      const S = subtract(U, multiply(lambda, E)) // the characteristic matrix\n\n      let solutions = usolveAll(S, b)\n      solutions.shift() // ignore the null vector\n\n      // looks like we missed something, try inverse iteration\n      // But if that fails, just presume that the original matrix truly\n      // was defective.\n      while (solutions.length < multiplicities[i]) {\n        const approxVec = inverseIterate(S, N, solutions, prec, type)\n        if (approxVec === null) { break } // no more vectors were found\n        solutions.push(approxVec)\n      }\n\n      // Transform back into original array coordinates\n      const correction = multiply(inv(R), C)\n      solutions = solutions.map(v => multiply(correction, v))\n\n      vectors.push(\n        ...solutions.map(v => ({ value: lambda, vector: flatten(v) })))\n    }\n\n    return vectors\n  }\n\n  /**\n   * Compute the eigenvalues of an 2x2 matrix\n   * @return {[number,number]}\n   */\n  function eigenvalues2x2 (a, b, c, d) {\n    // lambda_+- = 1/2 trA +- 1/2 sqrt( tr^2 A - 4 detA )\n    const trA = addScalar(a, d)\n    const detA = subtract(multiplyScalar(a, d), multiplyScalar(b, c))\n    const x = multiplyScalar(trA, 0.5)\n    const y = multiplyScalar(sqrt(subtract(multiplyScalar(trA, trA), multiplyScalar(4, detA))), 0.5)\n\n    return [addScalar(x, y), subtract(x, y)]\n  }\n\n  /**\n   * For an 2x2 matrix compute the transformation matrix S,\n   * so that SAS^-1 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  function jordanBase2x2 (a, b, c, d, l1, l2, prec, type) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    const zero = big ? bignumber(0) : cplx ? complex(0) : 0\n    const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n    // matrix is already upper triangular\n    // return an identity matrix\n    if (smaller(abs(c), prec)) {\n      return [[one, zero], [zero, one]]\n    }\n\n    // matrix is diagonalizable\n    // return its eigenvectors as columns\n    if (larger(abs(subtract(l1, l2)), prec)) {\n      return [[subtract(l1, d), subtract(l2, d)], [c, c]]\n    }\n\n    // matrix is not diagonalizable\n    // compute diagonal elements of N = A - lambdaI\n    const na = subtract(a, l1)\n    const nd = subtract(d, l1)\n\n    // col(N,2) = 0  implies  S = ( col(N,1), e_1 )\n    // col(N,2) != 0 implies  S = ( col(N,2), e_2 )\n\n    if (smaller(abs(b), prec) && smaller(abs(nd), prec)) {\n      return [[na, one], [c, zero]]\n    } else {\n      return [[b, zero], [nd, one]]\n    }\n  }\n\n  /**\n   * Enlarge the matrix from nxn to NxN, setting the new\n   * elements to 1 on diagonal and 0 elsewhere\n   */\n  function inflateMatrix (arr, N) {\n    // add columns\n    for (let i = 0; i < arr.length; i++) {\n      arr[i].push(...Array(N - arr[i].length).fill(0))\n    }\n\n    // add rows\n    for (let i = arr.length; i < N; i++) {\n      arr.push(Array(N).fill(0))\n      arr[i][i] = 1\n    }\n\n    return arr\n  }\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  function blockDiag (arr, N) {\n    const M = []\n    for (let i = 0; i < N; i++) {\n      M[i] = Array(N).fill(0)\n    }\n\n    let I = 0\n    for (const sub of arr) {\n      const n = sub.length\n\n      for (let i = 0; i < n; i++) {\n        for (let j = 0; j < n; j++) {\n          M[I + i][I + j] = sub[i][j]\n        }\n      }\n\n      I += n\n    }\n\n    return M\n  }\n\n  /**\n   * Finds the index of an element in an array using a custom equality function\n   * @template T\n   * @param {Array<T>} 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  function indexOf (arr, el, fn) {\n    for (let i = 0; i < arr.length; i++) {\n      if (fn(arr[i], el)) {\n        return i\n      }\n    }\n    return -1\n  }\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  function inverseIterate (A, N, orthog, prec, type) {\n    const largeNum = type === 'BigNumber' ? bignumber(1000) : 1000\n\n    let b // the vector\n\n    // you better choose a random vector before I count to five\n    let i = 0\n    for (; i < 5; ++i) {\n      b = randomOrthogonalVector(N, orthog, type)\n      try {\n        b = usolve(A, b)\n      } catch {\n        // That direction didn't work, likely because the original matrix\n        // was defective. But still make the full number of tries...\n        continue\n      }\n      if (larger(norm(b), largeNum)) { break }\n    }\n    if (i >= 5) {\n      return null // couldn't find any orthogonal vector in the image\n    }\n\n    // you better converge before I count to ten\n    i = 0\n    while (true) {\n      const c = usolve(A, b)\n\n      if (smaller(norm(orthogonalComplement(b, [c])), prec)) { break }\n      if (++i >= 10) { return null }\n\n      b = normalize(c)\n    }\n\n    return b\n  }\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  function randomOrthogonalVector (N, orthog, type) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n\n    // generate random vector with the correct type\n    let v = Array(N).fill(0).map(_ => 2 * Math.random() - 1)\n    if (big) { v = v.map(n => bignumber(n)) }\n    if (cplx) { v = v.map(n => complex(n)) }\n\n    // project to orthogonal complement\n    v = orthogonalComplement(v, orthog)\n\n    // normalize\n    return normalize(v, type)\n  }\n\n  /**\n   * Project vector v to the orthogonal complement of an array of vectors\n   */\n  function orthogonalComplement (v, orthog) {\n    const vectorShape = size(v)\n    for (let w of orthog) {\n      w = reshape(w, vectorShape) // make sure this is just a vector computation\n      // v := v − (w, v)/|w|^2 w\n      v = subtract(v, multiply(divideScalar(dot(w, v), dot(w, w)), w))\n    }\n\n    return v\n  }\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  function norm (v) {\n    return abs(sqrt(dot(v, v)))\n  }\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  function normalize (v, type) {\n    const big = type === 'BigNumber'\n    const cplx = type === 'Complex'\n    const one = big ? bignumber(1) : cplx ? complex(1) : 1\n\n    return multiply(divideScalar(one, norm(v)), v)\n  }\n\n  return complexEigs\n}\n","import { isSparseMatrix } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'expm'\nconst dependencies = ['typed', 'abs', 'add', 'identity', 'inv', 'multiply']\n\nexport const createExpm = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, identity, inv, multiply }) => {\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\n    Matrix: function (A) {\n      // Check matrix size\n      const size = A.size()\n\n      if (size.length !== 2 || size[0] !== size[1]) {\n        throw new RangeError('Matrix must be square ' +\n          '(size: ' + format(size) + ')')\n      }\n\n      const n = size[0]\n\n      // Desired accuracy of the approximant (The actual accuracy\n      // will be affected by round-off error)\n      const eps = 1e-15\n\n      // 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\n      // Compute infinity-norm of A, ||A||, to see how \"big\" it is\n      const infNorm = infinityNorm(A)\n\n      // Find the optimal scaling factor and number of terms in the\n      // Padé approximant to reach the desired accuracy\n      const params = findParams(infNorm, eps)\n      const q = params.q\n      const j = params.j\n\n      // 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\n      // Scale A by 1 / 2^j\n      const Apos = multiply(A, Math.pow(2, -j))\n\n      // The i=0 term is just the identity matrix\n      let N = identity(n)\n      let D = identity(n)\n\n      // Initialization (i=0)\n      let factor = 1\n\n      // Initialization (i=1)\n      let AposToI = Apos // Cloning not necessary\n      let alternate = -1\n\n      for (let i = 1; i <= q; i++) {\n        if (i > 1) {\n          AposToI = multiply(AposToI, Apos)\n          alternate = -alternate\n        }\n        factor = factor * (q - i + 1) / ((2 * q - i + 1) * i)\n\n        N = add(N, multiply(factor, AposToI))\n        D = add(D, multiply(factor * alternate, AposToI))\n      }\n\n      let R = multiply(inv(D), N)\n\n      // Square j times\n      for (let i = 0; i < j; i++) {\n        R = multiply(R, R)\n      }\n\n      return isSparseMatrix(A)\n        ? A.createSparseMatrix(R)\n        : R\n    }\n\n  })\n\n  function infinityNorm (A) {\n    const n = A.size()[0]\n    let infNorm = 0\n    for (let i = 0; i < n; i++) {\n      let rowSum = 0\n      for (let j = 0; j < n; j++) {\n        rowSum += abs(A.get([i, j]))\n      }\n      infNorm = Math.max(rowSum, infNorm)\n    }\n    return infNorm\n  }\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  function findParams (infNorm, eps) {\n    const maxSearchSize = 30\n    for (let k = 0; k < maxSearchSize; k++) {\n      for (let q = 0; q <= k; q++) {\n        const j = k - q\n        if (errorEstimate(infNorm, q, j) < eps) {\n          return { q, j }\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  /**\n   * Returns the estimated error of the Pade approximant for the given\n   * parameters.\n   */\n  function errorEstimate (infNorm, q, j) {\n    let qfac = 1\n    for (let i = 2; i <= q; i++) {\n      qfac *= i\n    }\n    let twoqfac = qfac\n    for (let i = q + 1; i <= 2 * q; i++) {\n      twoqfac *= i\n    }\n    const twoqp1fac = twoqfac * (2 * q + 1)\n\n    return 8.0 *\n      Math.pow(infNorm / Math.pow(2, j), 2 * q) *\n      qfac * qfac / (twoqfac * twoqp1fac)\n  }\n})\n","import { isMatrix } from '../../utils/is.js'\nimport { format } from '../../utils/string.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'sqrtm'\nconst dependencies = ['typed', 'abs', 'add', 'multiply', 'map', 'sqrt', 'subtract', 'inv', 'size', 'max', 'identity']\n\nexport const createSqrtm = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, add, multiply, map, sqrt, subtract, inv, size, max, identity }) => {\n  const _maxIterations = 1e3\n  const _tolerance = 1e-6\n\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  function _denmanBeavers (A) {\n    let error\n    let iterations = 0\n\n    let Y = A\n    let Z = identity(size(A))\n\n    do {\n      const Yk = Y\n      Y = multiply(0.5, add(Yk, inv(Z)))\n      Z = multiply(0.5, add(Z, inv(Yk)))\n\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  /**\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   *     math.sqrtm(A)\n   *\n   * Examples:\n   *\n   *     math.sqrtm([[33, 24], [48, 57]]) // returns [[5, 2], [4, 7]]\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  return typed(name, {\n    'Array | Matrix': function (A) {\n      const size = isMatrix(A) ? A.size() : arraySize(A)\n      switch (size.length) {\n        case 1:\n          // Single element Array | Matrix\n          if (size[0] === 1) {\n            return map(A, sqrt)\n          } else {\n            throw new RangeError('Matrix must be square ' +\n            '(size: ' + format(size) + ')')\n          }\n\n        case 2:\n        {\n          // Two-dimensional Array | Matrix\n          const rows = size[0]\n          const cols = size[1]\n          if (rows === cols) {\n            return _denmanBeavers(A)\n          } else {\n            throw new RangeError('Matrix must be square ' +\n              '(size: ' + format(size) + ')')\n          }\n        }\n        default:\n          // Multi dimensional array\n          throw new RangeError('Matrix must be at most two dimensional ' +\n          '(size: ' + format(size) + ')')\n      }\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'sylvester'\nconst dependencies = [\n  'typed',\n  'schur',\n  'matrixFromColumns',\n  'matrix',\n  'multiply',\n  'range',\n  'concat',\n  'transpose',\n  'index',\n  'subset',\n  'add',\n  'subtract',\n  'identity',\n  'lusolve',\n  'abs'\n]\n\nexport const createSylvester = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    schur,\n    matrixFromColumns,\n    matrix,\n    multiply,\n    range,\n    concat,\n    transpose,\n    index,\n    subset,\n    add,\n    subtract,\n    identity,\n    lusolve,\n    abs\n  }\n) => {\n  /**\n   *\n   * Solves the real-valued Sylvester equation AX+XB=C for X, where A, B and C are\n   * matrices of appropriate dimensions, being A and B squared. Notice that other\n   * equivalent definitions for the Sylvester equation exist and this function\n   * assumes the one presented in the original publication of the the Bartels-\n   * Stewart algorithm, which is implemented by this function.\n   * https://en.wikipedia.org/wiki/Sylvester_equation\n   *\n   * Syntax:\n   *\n   *     math.sylvester(A, B, C)\n   *\n   * Examples:\n   *\n   *     const A = [[-1, -2], [1, 1]]\n   *     const B = [[2, -1], [1, -2]]\n   *     const C = [[-3, 2], [3, 0]]\n   *     math.sylvester(A, B, C)      // returns DenseMatrix [[-0.25, 0.25], [1.5, -1.25]]\n   *\n   * See also:\n   *\n   *     schur, lyap\n   *\n   * @param {Matrix | Array} A  Matrix A\n   * @param {Matrix | Array} B  Matrix B\n   * @param {Matrix | Array} C  Matrix C\n   * @return {Matrix | Array}   Matrix X, solving the Sylvester equation\n   */\n  return typed(name, {\n    'Matrix, Matrix, Matrix': _sylvester,\n    'Array, Matrix, Matrix': function (A, B, C) {\n      return _sylvester(matrix(A), B, C)\n    },\n    'Array, Array, Matrix': function (A, B, C) {\n      return _sylvester(matrix(A), matrix(B), C)\n    },\n    'Array, Matrix, Array': function (A, B, C) {\n      return _sylvester(matrix(A), B, matrix(C))\n    },\n    'Matrix, Array, Matrix': function (A, B, C) {\n      return _sylvester(A, matrix(B), C)\n    },\n    'Matrix, Array, Array': function (A, B, C) {\n      return _sylvester(A, matrix(B), matrix(C))\n    },\n    'Matrix, Matrix, Array': function (A, B, C) {\n      return _sylvester(A, B, matrix(C))\n    },\n    'Array, Array, Array': function (A, B, C) {\n      return _sylvester(matrix(A), matrix(B), matrix(C)).toArray()\n    }\n  })\n  function _sylvester (A, B, C) {\n    const n = B.size()[0]\n    const m = A.size()[0]\n\n    const sA = schur(A)\n    const F = sA.T\n    const U = sA.U\n    const sB = schur(multiply(-1, B))\n    const G = sB.T\n    const V = sB.U\n    const D = multiply(multiply(transpose(U), C), V)\n    const all = range(0, m)\n    const y = []\n\n    const hc = (a, b) => concat(a, b, 1)\n    const vc = (a, b) => concat(a, b, 0)\n\n    for (let k = 0; k < n; k++) {\n      if (k < (n - 1) && abs(subset(G, index(k + 1, k))) > 1e-5) {\n        let RHS = vc(subset(D, index(all, k)), subset(D, index(all, k + 1)))\n        for (let j = 0; j < k; j++) {\n          RHS = add(RHS,\n            vc(multiply(y[j], subset(G, index(j, k))), multiply(y[j], subset(G, index(j, k + 1))))\n          )\n        }\n        const gkk = multiply(identity(m), multiply(-1, subset(G, index(k, k))))\n        const gmk = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k))))\n        const gkm = multiply(identity(m), multiply(-1, subset(G, index(k, k + 1))))\n        const gmm = multiply(identity(m), multiply(-1, subset(G, index(k + 1, k + 1))))\n        const LHS = vc(\n          hc(add(F, gkk), gmk),\n          hc(gkm, add(F, gmm))\n        )\n        const yAux = lusolve(LHS, RHS)\n        y[k] = yAux.subset(index(range(0, m), 0))\n        y[k + 1] = yAux.subset(index(range(m, 2 * m), 0))\n        k++\n      } else {\n        let RHS = subset(D, index(all, k))\n        for (let j = 0; j < k; j++) { RHS = add(RHS, multiply(y[j], subset(G, index(j, k)))) }\n        const gkk = subset(G, index(k, k))\n        const LHS = subtract(F, multiply(gkk, identity(m)))\n\n        y[k] = lusolve(LHS, RHS)\n      }\n    }\n    const Y = matrix(matrixFromColumns(...y))\n    const X = multiply(U, multiply(Y, transpose(V)))\n\n    return X\n  }\n})\n","import { factory } from '../../../utils/factory.js'\n\nconst name = 'schur'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'identity',\n  'multiply',\n  'qr',\n  'norm',\n  'subtract'\n]\n\nexport const createSchur = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    matrix,\n    identity,\n    multiply,\n    qr,\n    norm,\n    subtract\n  }\n) => {\n  /**\n   *\n   * Performs a real Schur decomposition of the real matrix A = UTU' where U is orthogonal\n   * and T is upper quasi-triangular.\n   * https://en.wikipedia.org/wiki/Schur_decomposition\n   *\n   * Syntax:\n   *\n   *     math.schur(A)\n   *\n   * Examples:\n   *\n   *     const A = [[1, 0], [-4, 3]]\n   *     math.schur(A) // returns {T: [[3, 4], [0, 1]], R: [[0, 1], [-1, 0]]}\n   *\n   * See also:\n   *\n   *     sylvester, lyap, qr\n   *\n   * @param {Array | Matrix} A  Matrix A\n   * @return {{U: Array | Matrix, T: Array | Matrix}} Object containing both matrix U and T of the Schur Decomposition A=UTU'\n   */\n  return typed(name, {\n    Array: function (X) {\n      const r = _schur(matrix(X))\n      return {\n        U: r.U.valueOf(),\n        T: r.T.valueOf()\n      }\n    },\n\n    Matrix: function (X) {\n      return _schur(X)\n    }\n  })\n  function _schur (X) {\n    const n = X.size()[0]\n    let A = X\n    let U = identity(n)\n    let k = 0\n    let A0\n    do {\n      A0 = A\n      const QR = qr(A)\n      const Q = QR.Q\n      const R = QR.R\n      A = multiply(R, Q)\n      U = multiply(U, Q)\n      if ((k++) > 100) { break }\n    } while (norm(subtract(A, A0)) > 1e-4)\n    return { U, T: A }\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'lyap'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'sylvester',\n  'multiply',\n  'transpose'\n]\n\nexport const createLyap = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    matrix,\n    sylvester,\n    multiply,\n    transpose\n  }\n) => {\n  /**\n   *\n   * Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P, where\n   * Q is an input matrix. When Q is symmetric, P is also symmetric. Notice\n   * that different equivalent definitions exist for the Continuous-time\n   * Lyapunov equation.\n   * https://en.wikipedia.org/wiki/Lyapunov_equation\n   *\n   * Syntax:\n   *\n   *     math.lyap(A, Q)\n   *\n   * Examples:\n   *\n   *     const A = [[-2, 0], [1, -4]]\n   *     const Q = [[3, 1], [1, 3]]\n   *     const P = math.lyap(A, Q)\n   *\n   * See also:\n   *\n   *     sylvester, schur\n   *\n   * @param {Matrix | Array} A  Matrix A\n   * @param {Matrix | Array} Q  Matrix Q\n   * @return {Matrix | Array} Matrix P solution to the Continuous-time Lyapunov equation AP+PA'=Q\n   */\n  return typed(name, {\n    'Matrix, Matrix': function (A, Q) {\n      return sylvester(A, transpose(A), multiply(-1, Q))\n    },\n    'Array, Matrix': function (A, Q) {\n      return sylvester(matrix(A), transpose(matrix(A)), multiply(-1, Q))\n    },\n    'Matrix, Array': function (A, Q) {\n      return sylvester(A, transpose(matrix(A)), matrix(multiply(-1, Q)))\n    },\n    'Array, Array': function (A, Q) {\n      return sylvester(matrix(A), transpose(matrix(A)), matrix(multiply(-1, Q))).toArray()\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\nimport { extend } from '../../utils/object.js'\nimport { createMatAlgo11xS0s } from '../../type/matrix/utils/matAlgo11xS0s.js'\nimport { createMatAlgo14xDs } from '../../type/matrix/utils/matAlgo14xDs.js'\n\nconst name = 'divide'\nconst dependencies = [\n  'typed',\n  'matrix',\n  'multiply',\n  'equalScalar',\n  'divideScalar',\n  'inv'\n]\n\nexport const createDivide = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, multiply, equalScalar, divideScalar, inv }) => {\n  const matAlgo11xS0s = createMatAlgo11xS0s({ typed, equalScalar })\n  const matAlgo14xDs = createMatAlgo14xDs({ 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 | bigint | Fraction | Complex | Unit | Array | Matrix} x   Numerator\n   * @param  {number | BigNumber | bigint | Fraction | Complex | Array | Matrix} y          Denominator\n   * @return {number | BigNumber | bigint | Fraction | Complex | Unit | Array | Matrix}                      Quotient, `x / y`\n   */\n  return typed('divide', extend({\n    // we extend the signatures of divideScalar with signatures dealing with matrices\n\n    'Array | Matrix, Array | Matrix': function (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\n    'DenseMatrix, any': function (x, y) {\n      return matAlgo14xDs(x, y, divideScalar, false)\n    },\n\n    'SparseMatrix, any': function (x, y) {\n      return matAlgo11xS0s(x, y, divideScalar, false)\n    },\n\n    'Array, any': function (x, y) {\n      // use matrix implementation\n      return matAlgo14xDs(matrix(x), y, divideScalar, false).valueOf()\n    },\n\n    'any, Array | Matrix': function (x, y) {\n      return multiply(x, inv(y))\n    }\n  }, divideScalar.signatures))\n})\n","import { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'distance'\nconst dependencies = [\n  'typed',\n  'addScalar',\n  'subtractScalar',\n  'divideScalar',\n  'multiplyScalar',\n  'deepEqual',\n  'sqrt',\n  'abs'\n]\n\nexport const createDistance = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, subtractScalar, multiplyScalar, divideScalar, deepEqual, sqrt, abs }) => {\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    *\n    *    math.distance([x1,y1], [x2,y2])\n    *    math.distance({pointOneX, pointOneY}, {pointTwoX, pointTwoY})\n    *    math.distance([x1,y1,z1], [x2,y2,z2])\n    *    math.distance({pointOneX, pointOneY, pointOneZ}, {pointTwoX, pointTwoY, pointTwoZ})\n    *    math.distance([x1,y1,z1,a1], [x2,y2,z2,a2])\n    *    math.distance([[x1,y1], [x2,y2], [x3,y3]])\n    *    math.distance([[x1,y1,z1], [x2,y2,z2], [x3,y3,z3]])\n    *    math.distance([pointX,pointY], [a,b,c])\n    *    math.distance([pointX,pointY], [lineOnePtX,lineOnePtY], [lineTwoPtX,lineTwoPtY])\n    *    math.distance({pointX, pointY}, {lineOnePtX, lineOnePtY}, {lineTwoPtX, lineTwoPtY})\n    *    math.distance([pointX,pointY,pointZ], [x0, y0, z0, a, b, c])\n    *    math.distance({pointX, pointY, pointZ}, {x0, y0, z0, a, b, c})\n    *\n    * Examples:\n    *    math.distance([0,0], [4,4])                     // Returns 5.656854249492381\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.7416573867739413\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([0, 0], [3, 0], [0, 4])        // Returns 2.4\n    *    math.distance(\n    *     {pointX: 0, pointY: 0},\n    *     {lineOnePtX: 3, lineOnePtY: 0},\n    *     {lineTwoPtX: 0, lineTwoPtY: 4})                // Returns 2.4\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 (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)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument') }\n        if (!_2d(y)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument') }\n        if (!_2d(z)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument') }\n        if (deepEqual(y, z)) { throw new TypeError('LinePoint1 should not be same with LinePoint2') }\n        const xCoeff = subtractScalar(z[1], y[1])\n        const yCoeff = subtractScalar(y[0], z[0])\n        const constant = subtractScalar(multiplyScalar(z[0], y[1]), multiplyScalar(y[0], z[1]))\n\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 (x, y, z) {\n      if (Object.keys(x).length === 2 && Object.keys(y).length === 2 && Object.keys(z).length === 2) {\n        if (!_2d(x)) { throw new TypeError('Values of pointX and pointY should be numbers or BigNumbers') }\n        if (!_2d(y)) { throw new TypeError('Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers') }\n        if (!_2d(z)) { throw new TypeError('Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers') }\n        if (deepEqual(_objectToArray(y), _objectToArray(z))) { throw new TypeError('LinePoint1 should not be same with LinePoint2') }\n        if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y &&\n          'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) {\n          const xCoeff = subtractScalar(z.lineTwoPtY, y.lineOnePtY)\n          const yCoeff = subtractScalar(y.lineOnePtX, z.lineTwoPtX)\n          const constant = subtractScalar(multiplyScalar(z.lineTwoPtX, y.lineOnePtY), multiplyScalar(y.lineOnePtX, z.lineTwoPtY))\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 (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        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        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        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 (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        if (!_3d(y)) {\n          throw new TypeError('Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers')\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        if (!_parametricLine(y)) {\n          throw new TypeError('Values of x0, y0, z0, a, b and c should be numbers or BigNumbers')\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        if (!_2d(y)) {\n          throw new TypeError('Values of pointTwoX and pointTwoY should be numbers or BigNumbers')\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        if (!_3d(y)) {\n          throw new TypeError('Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers')\n        }\n        if ('pointOneX' in x && 'pointOneY' in x && 'pointOneZ' in x &&\n          'pointTwoX' in y && 'pointTwoY' in y && 'pointTwoZ' in y\n        ) {\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 (arr) {\n      if (!_pairwise(arr)) { throw new TypeError('Incorrect array format entered for pairwise distance calculation') }\n\n      return _distancePairwise(arr)\n    }\n  })\n\n  function _isNumber (a) {\n    // distance supports numbers and bignumbers\n    return (typeof a === 'number' || 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    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    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    return a.every(_isNumber)\n  }\n\n  function _parametricLine (a) {\n    if (a.constructor !== Array) {\n      a = _objectToArray(a)\n    }\n    return _isNumber(a[0]) && _isNumber(a[1]) && _isNumber(a[2]) &&\n      _isNumber(a[3]) && _isNumber(a[4]) && _isNumber(a[5])\n  }\n\n  function _objectToArray (o) {\n    const keys = Object.keys(o)\n    const a = []\n    for (let i = 0; i < keys.length; i++) {\n      a.push(o[keys[i]])\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(aI => aI.length !== 2 || !_isNumber(aI[0]) || !_isNumber(aI[1]))) {\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(aI => aI.length !== 3 || !_isNumber(aI[0]) || !_isNumber(aI[1]) || !_isNumber(aI[2]))) {\n        return false\n      }\n    } else {\n      return false\n    }\n    return true\n  }\n\n  function _distancePointLine2D (x, y, a, b, c) {\n    const num = abs(addScalar(addScalar(multiplyScalar(a, x), multiplyScalar(b, y)), c))\n    const 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    let num = [subtractScalar(multiplyScalar(subtractScalar(y0, y), c), multiplyScalar(subtractScalar(z0, z), b)),\n      subtractScalar(multiplyScalar(subtractScalar(z0, z), a), multiplyScalar(subtractScalar(x0, x), c)),\n      subtractScalar(multiplyScalar(subtractScalar(x0, x), b), multiplyScalar(subtractScalar(y0, y), a))]\n    num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2])))\n    const 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    const vectorSize = x.length\n    let result = 0\n    let diff = 0\n    for (let i = 0; i < vectorSize; i++) {\n      diff = subtractScalar(x[i], y[i])\n      result = addScalar(multiplyScalar(diff, diff), result)\n    }\n    return sqrt(result)\n  }\n\n  function _distancePairwise (a) {\n    const result = []\n    let pointA = []\n    let pointB = []\n    for (let i = 0; i < a.length - 1; i++) {\n      for (let 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        result.push(_euclideanDistance(pointA, pointB))\n      }\n    }\n    return result\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'intersect'\nconst dependencies = [\n  'typed', 'config', 'abs', 'add', 'addScalar', 'matrix', 'multiply', 'multiplyScalar', 'divideScalar', 'subtract', 'smaller', 'equalScalar', 'flatten', 'isZero', 'isNumeric'\n]\n\nexport const createIntersect = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, abs, add, addScalar, matrix, multiply, multiplyScalar, divideScalar, subtract, smaller, equalScalar, flatten, isZero, isNumeric }) => {\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\n    'Array, Array, Array, Array': _AAAA,\n\n    'Matrix, Matrix, Matrix': function (x, y, plane) {\n      const arr = _AAA(x.valueOf(), y.valueOf(), plane.valueOf())\n      return arr === null ? null : matrix(arr)\n    },\n\n    'Matrix, Matrix, Matrix, Matrix': function (w, x, y, z) {\n      // TODO: output matrix type should match input matrix type\n      const arr = _AAAA(w.valueOf(), x.valueOf(), y.valueOf(), z.valueOf())\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)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument') }\n    if (!_3d(y)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument') }\n    if (!_4d(plane)) { throw new TypeError('Array with 4 numbers expected as third argument') }\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)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for first argument') }\n      if (!_2d(x)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for second argument') }\n      if (!_2d(y)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for third argument') }\n      if (!_2d(z)) { throw new TypeError('Array with 2 numbers or BigNumbers expected for fourth argument') }\n\n      return _intersect2d(w, x, y, z)\n    } else if (w.length === 3) {\n      if (!_3d(w)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for first argument') }\n      if (!_3d(x)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for second argument') }\n      if (!_3d(y)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for third argument') }\n      if (!_3d(z)) { throw new TypeError('Array with 3 numbers or BigNumbers expected for fourth argument') }\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\n  /** Coerce row and column 2-dim arrays to 1-dim array */\n  function _coerceArr (arr) {\n    // row matrix\n    if (arr.length === 1) return arr[0]\n\n    // column matrix\n    if (arr.length > 1 && Array.isArray(arr[0])) {\n      if (arr.every(el => Array.isArray(el) && el.length === 1)) 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    const o1 = p1a\n    const o2 = p2a\n    const d1 = subtract(o1, p1b)\n    const d2 = subtract(o2, p2b)\n    const det = subtract(multiplyScalar(d1[0], d2[1]), multiplyScalar(d2[0], d1[1]))\n    if (isZero(det)) return null\n    if (smaller(abs(det), config.relTol)) {\n      return null\n    }\n    const d20o11 = multiplyScalar(d2[0], o1[1])\n    const d21o10 = multiplyScalar(d2[1], o1[0])\n    const d20o21 = multiplyScalar(d2[0], o2[1])\n    const d21o20 = multiplyScalar(d2[1], o2[0])\n    const 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    const add1 = multiplyScalar(subtract(a, b), subtract(c, d))\n    const add2 = multiplyScalar(subtract(e, f), subtract(g, h))\n    const 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    const d1343 = _intersect3dHelper(x1, x3, x4, x3, y1, y3, y4, y3, z1, z3, z4, z3)\n    const d4321 = _intersect3dHelper(x4, x3, x2, x1, y4, y3, y2, y1, z4, z3, z2, z1)\n    const d1321 = _intersect3dHelper(x1, x3, x2, x1, y1, y3, y2, y1, z1, z3, z2, z1)\n    const d4343 = _intersect3dHelper(x4, x3, x4, x3, y4, y3, y4, y3, z4, z3, z4, z3)\n    const d2121 = _intersect3dHelper(x2, x1, x2, x1, y2, y1, y2, y1, z2, z1, z2, z1)\n    const numerator = subtract(multiplyScalar(d1343, d4321), multiplyScalar(d1321, d4343))\n    const denominator = subtract(multiplyScalar(d2121, d4343), multiplyScalar(d4321, d4321))\n    if (isZero(denominator)) return null\n    const ta = divideScalar(numerator, denominator)\n    const tb = divideScalar(addScalar(d1343, multiplyScalar(ta, d4321)), d4343)\n\n    const pax = addScalar(x1, multiplyScalar(ta, subtract(x2, x1)))\n    const pay = addScalar(y1, multiplyScalar(ta, subtract(y2, y1)))\n    const paz = addScalar(z1, multiplyScalar(ta, subtract(z2, z1)))\n    const pbx = addScalar(x3, multiplyScalar(tb, subtract(x4, x3)))\n    const pby = addScalar(y3, multiplyScalar(tb, subtract(y4, y3)))\n    const pbz = addScalar(z3, multiplyScalar(tb, subtract(z4, z3)))\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    const x1x = multiplyScalar(x1, x)\n    const x2x = multiplyScalar(x2, x)\n    const y1y = multiplyScalar(y1, y)\n    const y2y = multiplyScalar(y2, y)\n    const z1z = multiplyScalar(z1, z)\n    const z2z = multiplyScalar(z2, z)\n\n    const numerator = subtract(subtract(subtract(c, x1x), y1y), z1z)\n    const denominator = subtract(subtract(subtract(addScalar(addScalar(x2x, y2y), z2z), x1x), y1y), z1z)\n\n    const t = divideScalar(numerator, denominator)\n\n    const px = addScalar(x1, multiplyScalar(t, subtract(x2, x1)))\n    const py = addScalar(y1, multiplyScalar(t, subtract(y2, y1)))\n    const pz = addScalar(z1, multiplyScalar(t, subtract(z2, z1)))\n    return [px, py, pz]\n    // TODO: Add cases when line is parallel to the plane:\n    //       (a) no intersection,\n    //       (b) line contained in plane\n  }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'sum'\nconst dependencies = ['typed', 'config', 'add', 'numeric']\n\nexport const createSum = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, add, numeric }) => {\n  /**\n   * Compute the sum of a matrix or a list with values.\n   * In case of a multidimensional 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   *     math.sum(A, dimension)\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 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\n    // sum([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': _nsumDim,\n\n    // sum(a, b, c, d, ...)\n    '...': function (args) {\n      if (containsCollections(args)) {\n        throw new TypeError('Scalar values expected in function sum')\n      }\n\n      return _sum(args)\n    }\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  function _sum (array) {\n    let sum\n\n    deepForEach(array, function (value) {\n      try {\n        sum = (sum === undefined) ? value : add(sum, value)\n      } catch (err) {\n        throw improveErrorMessage(err, 'sum', value)\n      }\n    })\n\n    // make sure returning numeric value: parse a string into a numeric value\n    if (sum === undefined) {\n      sum = numeric(0, config.number)\n    }\n    if (typeof sum === 'string') {\n      sum = numeric(sum, safeNumberType(sum, config))\n    }\n\n    return sum\n  }\n\n  function _nsumDim (array, dim) {\n    try {\n      const sum = reduce(array, dim, add)\n      return sum\n    } catch (err) {\n      throw improveErrorMessage(err, 'sum')\n    }\n  }\n})\n","import { containsCollections } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\nimport { _switch } from '../../utils/switch.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\nimport { arraySize } from '../../utils/array.js'\nimport { IndexError } from '../../error/IndexError.js'\n\nconst name = 'cumsum'\nconst dependencies = ['typed', 'add', 'unaryPlus']\n\nexport const createCumSum = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, unaryPlus }) => {\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) {\n      return matrix.create(_cumsum(matrix.valueOf()))\n    },\n\n    // sum([a, b, c, d, ...], dim)\n    'Array, number | BigNumber': _ncumSumDim,\n    'Matrix, number | BigNumber': function (matrix, dim) {\n      return matrix.create(_ncumSumDim(matrix.valueOf(), dim))\n    },\n\n    // cumsum(a, b, c, d, ...)\n    '...': function (args) {\n      if (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  /**\n     * Recursively calculate the cumulative sum of an n-dimensional array\n     * @param {Array} array\n     * @return {number} cumsum\n     * @private\n     */\n  function _cumsum (array) {\n    try {\n      return _cumsummap(array)\n    } catch (err) {\n      throw improveErrorMessage(err, name)\n    }\n  }\n\n  function _cumsummap (array) {\n    if (array.length === 0) {\n      return []\n    }\n\n    const sums = [unaryPlus(array[0])] // unaryPlus converts to number if need be\n    for (let 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    return sums\n  }\n\n  function _ncumSumDim (array, dim) {\n    const size = arraySize(array)\n    if (dim < 0 || (dim >= size.length)) {\n      // TODO: would be more clear when throwing a DimensionError here\n      throw new IndexError(dim, size.length)\n    }\n\n    try {\n      return _cumsumDimensional(array, dim)\n    } catch (err) {\n      throw improveErrorMessage(err, name)\n    }\n  }\n\n  /* Possible TODO: Refactor _reduce in collection.js to be able to work here as well */\n  function _cumsumDimensional (mat, dim) {\n    let i, ret, tran\n\n    if (dim <= 0) {\n      const initialValue = mat[0][0]\n      if (!Array.isArray(initialValue)) {\n        return _cumsummap(mat)\n      } else {\n        tran = _switch(mat)\n        ret = []\n        for (i = 0; i < tran.length; i++) {\n          ret[i] = _cumsumDimensional(tran[i], dim - 1)\n        }\n        return ret\n      }\n    } else {\n      ret = []\n      for (i = 0; i < mat.length; i++) {\n        ret[i] = _cumsumDimensional(mat[i], dim - 1)\n      }\n      return ret\n    }\n  }\n})\n","import { containsCollections, deepForEach, reduce } from '../../utils/collection.js'\nimport { arraySize } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'mean'\nconst dependencies = ['typed', 'add', 'divide']\n\nexport const createMean = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide }) => {\n  /**\n   * Compute the mean value of matrix or a list with values.\n   * In case of a multidimensional 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, dimension)\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\n    // mean([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': _nmeanDim,\n\n    // mean(a, b, c, d, ...)\n    '...': function (args) {\n      if (containsCollections(args)) {\n        throw new TypeError('Scalar values expected in function mean')\n      }\n\n      return _mean(args)\n    }\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  function _nmeanDim (array, dim) {\n    try {\n      const sum = reduce(array, dim, add)\n      const s = Array.isArray(array) ? arraySize(array) : array.size()\n      return divide(sum, s[dim])\n    } catch (err) {\n      throw improveErrorMessage(err, 'mean')\n    }\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  function _mean (array) {\n    let sum\n    let num = 0\n\n    deepForEach(array, function (value) {\n      try {\n        sum = sum === undefined ? value : add(sum, value)\n        num++\n      } catch (err) {\n        throw 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    return divide(sum, num)\n  }\n})\n","import { containsCollections } from '../../utils/collection.js'\nimport { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'median'\nconst dependencies = ['typed', 'add', 'divide', 'compare', 'partitionSelect']\n\nexport const createMedian = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide, compare, partitionSelect }) => {\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 = flatten(array.valueOf())\n\n      const num = array.length\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        const mid = num / 2 - 1\n        const right = partitionSelect(array, mid + 1)\n\n        // array now partitioned at mid + 1, take max of left part\n        let left = array[mid]\n        for (let 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        const m = partitionSelect(array, (num - 1) / 2)\n\n        return middle(m)\n      }\n    } catch (err) {\n      throw improveErrorMessage(err, 'median')\n    }\n  }\n\n  // helper function to type check the middle value of the array\n  const middle = typed({\n    'number | BigNumber | Complex | Unit': function (value) {\n      return value\n    }\n  })\n\n  // helper function to type check the two middle value of the array\n  const middle2 = typed({\n    'number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit': function (left, right) {\n      return divide(add(left, right), 2)\n    }\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  return typed(name, {\n    // median([a, b, c, d, ...])\n    'Array | Matrix': _median,\n\n    // median([a, b, c, d, ...], dim)\n    'Array | Matrix, number | BigNumber': function (array, dim) {\n      // TODO: implement median(A, dim)\n      throw new Error('median(A, dim) is not yet supported')\n      // return reduce(arguments[0], arguments[1], ...)\n    },\n\n    // median(a, b, c, d, ...)\n    '...': function (args) {\n      if (containsCollections(args)) {\n        throw new TypeError('Scalar values expected in function median')\n      }\n\n      return _median(args)\n    }\n  })\n})\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst name = 'mad'\nconst dependencies = ['typed', 'abs', 'map', 'median', 'subtract']\n\nexport const createMad = /* #__PURE__ */ factory(name, dependencies, ({ typed, abs, map, median, subtract }) => {\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\n    // mad(a, b, c, d, ...)\n    '...': function (args) {\n      return _mad(args)\n    }\n  })\n\n  function _mad (array) {\n    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      const 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.includes('median')) {\n        throw new TypeError(err.message.replace('median', 'mad'))\n      } else {\n        throw improveErrorMessage(err, 'mad')\n      }\n    }\n  }\n})\n","import { deepForEach } from '../../utils/collection.js'\nimport { isBigNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { improveErrorMessage } from './utils/improveErrorMessage.js'\n\nconst DEFAULT_NORMALIZATION = 'unbiased'\n\nconst name = 'variance'\nconst dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']\n\nexport const createVariance = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, subtract, multiply, divide, apply, isNaN }) => {\n  /**\n   * Compute the variance of a matrix or a  list with values.\n   * In case of a multidimensional 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 (array) {\n      return _var(array, DEFAULT_NORMALIZATION)\n    },\n\n    // variance([a, b, c, d, ...], normalization)\n    'Array | Matrix, string': _var,\n\n    // variance([a, b, c, c, ...], dim)\n    'Array | Matrix, number | BigNumber': function (array, dim) {\n      return _varDim(array, dim, DEFAULT_NORMALIZATION)\n    },\n\n    // variance([a, b, c, c, ...], dim, normalization)\n    'Array | Matrix, number | BigNumber, string': _varDim,\n\n    // variance(a, b, c, d, ...)\n    '...': function (args) {\n      return _var(args, DEFAULT_NORMALIZATION)\n    }\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  function _var (array, normalization) {\n    let sum\n    let num = 0\n\n    if (array.length === 0) {\n      throw new SyntaxError('Function variance requires one or more parameters (0 provided)')\n    }\n\n    // calculate the mean and number of elements\n    deepForEach(array, function (value) {\n      try {\n        sum = sum === undefined ? value : add(sum, value)\n        num++\n      } catch (err) {\n        throw improveErrorMessage(err, 'variance', value)\n      }\n    })\n    if (num === 0) throw new Error('Cannot calculate variance of an empty array')\n\n    const mean = divide(sum, num)\n\n    // calculate the variance\n    sum = undefined\n    deepForEach(array, function (value) {\n      const 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        const zero = 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 + '\". ' +\n        '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      return apply(array, dim, (x) => _var(x, normalization))\n    } catch (err) {\n      throw improveErrorMessage(err, 'variance')\n    }\n  }\n})\n","import { isNumber } from '../../utils/is.js'\nimport { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { createApply } from '../matrix/apply.js'\n\nconst name = 'quantileSeq'\nconst dependencies = ['typed', '?bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']\n\nexport const createQuantileSeq = /* #__PURE__ */ factory(name, dependencies, ({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger }) => {\n  const apply = createApply({ typed, isInteger })\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 multidimensional 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  return typed(name, {\n    'Array | Matrix, number | BigNumber': (data, p) => _quantileSeqProbNumber(data, p, false),\n    'Array | Matrix, number | BigNumber, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbNumber),\n    'Array | Matrix, number | BigNumber, boolean': _quantileSeqProbNumber,\n    'Array | Matrix, number | BigNumber, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbNumber),\n    'Array | Matrix, Array | Matrix': (data, p) => _quantileSeqProbCollection(data, p, false),\n    'Array | Matrix, Array | Matrix, number': (data, prob, dim) => _quantileSeqDim(data, prob, false, dim, _quantileSeqProbCollection),\n    'Array | Matrix, Array | Matrix, boolean': _quantileSeqProbCollection,\n    'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => _quantileSeqDim(data, prob, sorted, dim, _quantileSeqProbCollection)\n  })\n\n  function _quantileSeqDim (data, prob, sorted, dim, fn) {\n    return apply(data, dim, x => fn(x, prob, sorted))\n  }\n\n  function _quantileSeqProbNumber (data, probOrN, sorted) {\n    let probArr\n    const dataArr = data.valueOf()\n    if (smaller(probOrN, 0)) {\n      throw new Error('N/prob must be non-negative')\n    }\n    if (smallerEq(probOrN, 1)) {\n      // quantileSeq([a, b, c, d, ...], prob[,sorted])\n      return isNumber(probOrN)\n        ? _quantileSeq(dataArr, probOrN, sorted)\n        : bignumber(_quantileSeq(dataArr, probOrN, sorted))\n    }\n    if (larger(probOrN, 1)) {\n      // quantileSeq([a, b, c, d, ...], N[,sorted])\n      if (!isInteger(probOrN)) {\n        throw new Error('N must be a positive integer')\n      }\n\n      // largest possible Array length is 2^32-1\n      // 2^32 < 10^15, thus safe conversion guaranteed\n      if (larger(probOrN, 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      const nPlusOne = add(probOrN, 1)\n      probArr = []\n\n      for (let i = 0; smaller(i, probOrN); i++) {\n        const prob = divide(i + 1, nPlusOne)\n        probArr.push(_quantileSeq(dataArr, prob, sorted))\n      }\n\n      return isNumber(probOrN) ? probArr : bignumber(probArr)\n    }\n  }\n\n  /**\n   * Calculate the prob order quantile of an n-dimensional array.\n   *\n   * @param {Array, Matrix} array\n   * @param {Array, Matrix} prob\n   * @param {Boolean} sorted\n   * @return {Number, BigNumber, Unit} prob order quantile\n   * @private\n   */\n\n  function _quantileSeqProbCollection (data, probOrN, sorted) {\n    const dataArr = data.valueOf()\n    // quantileSeq([a, b, c, d, ...], [prob1, prob2, ...][,sorted])\n    const probOrNArr = probOrN.valueOf()\n    const probArr = []\n    for (let i = 0; i < probOrNArr.length; ++i) {\n      probArr.push(_quantileSeq(dataArr, probOrNArr[i], sorted))\n    }\n    return probArr\n  }\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  function _quantileSeq (array, prob, sorted) {\n    const flat = flatten(array)\n    const len = flat.length\n    if (len === 0) {\n      throw new Error('Cannot calculate quantile of an empty sequence')\n    }\n\n    const index = isNumber(prob) ? prob * (len - 1) : prob.times(len - 1)\n    const integerPart = isNumber(prob) ? Math.floor(index) : index.floor().toNumber()\n    const fracPart = isNumber(prob) ? index % 1 : index.minus(integerPart)\n\n    if (isInteger(index)) {\n      return sorted\n        ? flat[index]\n        : partitionSelect(\n          flat,\n          isNumber(prob) ? index : index.valueOf()\n        )\n    }\n    let left\n    let right\n    if (sorted) {\n      left = flat[integerPart]\n      right = flat[integerPart + 1]\n    } else {\n      right = partitionSelect(flat, integerPart + 1)\n\n      // max of partition is kth largest\n      left = flat[integerPart]\n      for (let i = 0; i < integerPart; ++i) {\n        if (compare(flat[i], left) > 0) {\n          left = flat[i]\n        }\n      }\n    }\n    // Q(prob) = (1-f)*A[floor(index)] + f*A[floor(index)+1]\n    return add(multiply(left, subtract(1, fracPart)), multiply(right, fracPart))\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\nconst name = 'std'\nconst dependencies = ['typed', 'map', 'sqrt', 'variance']\n\nexport const createStd = /* #__PURE__ */ factory(name, dependencies, ({ typed, map, sqrt, variance }) => {\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\n    // std([a, b, c, d, ...], normalization)\n    'Array | Matrix, string': _std,\n\n    // std([a, b, c, c, ...], dim)\n    'Array | Matrix, number | BigNumber': _std,\n\n    // std([a, b, c, c, ...], dim, normalization)\n    'Array | Matrix, number | BigNumber, string': _std,\n\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      const v = variance.apply(null, arguments)\n      if (isCollection(v)) {\n        return map(v, sqrt)\n      } else {\n        return sqrt(v)\n      }\n    } catch (err) {\n      if (err instanceof TypeError && err.message.includes(' variance')) {\n        throw new TypeError(err.message.replace(' variance', ' std'))\n      } else {\n        throw err\n      }\n    }\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'corr'\nconst dependencies = ['typed', 'matrix', 'mean', 'sqrt', 'sum', 'add', 'subtract', 'multiply', 'pow', 'divide']\n\nexport const createCorr = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, sqrt, sum, add, subtract, multiply, pow, divide }) => {\n  /**\n   * Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.\n   *\n   * Syntax:\n   *\n   *     math.corr(A, B)\n   *\n   * Examples:\n   *\n   *     math.corr([1, 2, 3, 4, 5], [4, 5, 6, 7, 8])     // returns 1\n   *     math.corr([1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8])     //returns 0.9569941688503644\n   *     math.corr([[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]],[[1, 2.2, 3, 4.8, 5], [4, 5.3, 6.6, 7, 8]])   // returns [1,1]\n   *\n   * See also:\n   *\n   *     median, mean, min, max, sum, prod, std, variance\n   *\n   * @param {Array | Matrix} A The first array or matrix to compute correlation coefficient\n   * @param {Array | Matrix} B The second array or matrix to compute correlation coefficient\n   * @return {*} The correlation coefficient\n   */\n  return typed(name, {\n    'Array, Array': function (A, B) {\n      return _corr(A, B)\n    },\n    'Matrix, Matrix': function (A, B) {\n      const res = _corr(A.toArray(), B.toArray())\n      return Array.isArray(res) ? matrix(res) : res\n    }\n  })\n  /**\n   * Calculate the correlation coefficient between two arrays or matrices.\n   * @param {Array | Matrix} A\n   * @param {Array | Matrix} B\n   * @return {*} correlation coefficient\n   * @private\n   */\n  function _corr (A, B) {\n    const correlations = []\n    if (Array.isArray(A[0]) && Array.isArray(B[0])) {\n      if (A.length !== B.length) {\n        throw new SyntaxError('Dimension mismatch. Array A and B must have the same length.')\n      }\n      for (let i = 0; i < A.length; i++) {\n        if (A[i].length !== B[i].length) {\n          throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.')\n        }\n        correlations.push(correlation(A[i], B[i]))\n      }\n      return correlations\n    } else {\n      if (A.length !== B.length) {\n        throw new SyntaxError('Dimension mismatch. Array A and B must have the same number of elements.')\n      }\n      return correlation(A, B)\n    }\n  }\n  function correlation (A, B) {\n    const n = A.length\n    const sumX = sum(A)\n    const sumY = sum(B)\n    const sumXY = A.reduce((acc, x, index) => add(acc, multiply(x, B[index])), 0)\n    const sumXSquare = sum(A.map(x => pow(x, 2)))\n    const sumYSquare = sum(B.map(y => pow(y, 2)))\n    const numerator = subtract(multiply(n, sumXY), multiply(sumX, sumY))\n    const denominator = sqrt(multiply(subtract(multiply(n, sumXSquare), pow(sumX, 2)), subtract(multiply(n, sumYSquare), pow(sumY, 2))))\n    return divide(numerator, denominator)\n  }\n})\n","/** @param {number} i\n *  @param {number} n\n *  @returns {number} product of i to n\n */\nexport function product (i, n) {\n  if (n < i) {\n    return 1\n  }\n\n  if (n === i) {\n    return n\n  }\n\n  const half = (n + i) >> 1 // divide (n + i) by 2 and truncate to integer\n  return product(i, half) * product(half + 1, n)\n}\n","import { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nexport function combinationsNumber (n, k) {\n  if (!isInteger(n) || n < 0) {\n    throw new TypeError('Positive integer value expected in function combinations')\n  }\n  if (!isInteger(k) || k < 0) {\n    throw new TypeError('Positive integer value expected in function combinations')\n  }\n  if (k > n) {\n    throw new TypeError('k must be less than or equal to n')\n  }\n\n  const nMinusk = n - k\n\n  let answer = 1\n  const firstnumerator = (k < nMinusk) ? nMinusk + 1 : k + 1\n  let nextdivisor = 2\n  const lastdivisor = (k < nMinusk) ? k : nMinusk\n  // balance multiplications and divisions to try to keep intermediate values\n  // in exact-integer range as long as possible\n  for (let nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) {\n    answer *= nextnumerator\n    while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) {\n      answer /= nextdivisor\n      ++nextdivisor\n    }\n  }\n  // for big n, k, floating point may have caused weirdness in remainder\n  if (nextdivisor <= lastdivisor) {\n    answer /= product(nextdivisor, lastdivisor)\n  }\n  return answer\n}\ncombinationsNumber.signature = 'number, number'\n","import { factory } from '../../utils/factory.js'\nimport { combinationsNumber } from '../../plain/number/combinations.js'\n\nconst name = 'combinations'\nconst dependencies = ['typed']\n\nexport const createCombinations = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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': combinationsNumber,\n\n    'BigNumber, BigNumber': function (n, k) {\n      const BigNumber = n.constructor\n      let result, i\n      const nMinusk = n.minus(k)\n      const one = new BigNumber(1)\n\n      if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n        throw new TypeError('Positive integer value expected in function combinations')\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      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    }\n\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 */\nfunction isPositiveInteger (n) {\n  return n.isInteger() && n.gte(0)\n}\n","import { factory } from '../../utils/factory.js'\nimport { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nconst name = 'combinationsWithRep'\nconst dependencies = ['typed']\n\nexport const createCombinationsWithRep = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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 (n, k) {\n      if (!isInteger(n) || n < 0) {\n        throw new TypeError('Positive integer value expected in function combinationsWithRep')\n      }\n      if (!isInteger(k) || k < 0) {\n        throw new TypeError('Positive integer value expected in function combinationsWithRep')\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        const prodrange = product(n, n + k - 1)\n        return prodrange / product(1, k)\n      }\n      const prodrange = product(k + 1, n + k - 1)\n      return prodrange / product(1, n - 1)\n    },\n\n    'BigNumber, BigNumber': function (n, k) {\n      const BigNumber = n.constructor\n      let result, i\n      const one = new BigNumber(1)\n      const nMinusOne = n.minus(one)\n\n      if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n        throw new TypeError('Positive integer value expected in function combinationsWithRep')\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      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/**\n * Test whether BigNumber n is a positive integer\n * @param {BigNumber} n\n * @returns {boolean} isPositiveInteger\n */\nfunction isPositiveInteger (n) {\n  return n.isInteger() && n.gte(0)\n}\n","/* eslint-disable no-loss-of-precision */\n\nimport { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\n\nexport function gammaNumber (n) {\n  let x\n\n  if (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 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) { // Extended Stirling Approx\n    const twoN = n * n\n    const threeN = twoN * n\n    const fourN = threeN * n\n    const fiveN = fourN * n\n    return Math.sqrt(2 * Math.PI / n) * Math.pow((n / Math.E), n) *\n      (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) -\n        571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) +\n        5246819 / (75246796800 * fiveN * n))\n  }\n\n  --n\n  x = gammaP[0]\n  for (let i = 1; i < gammaP.length; ++i) {\n    x += gammaP[i] / (n + i)\n  }\n\n  const t = n + gammaG + 0.5\n  return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x\n}\ngammaNumber.signature = 'number'\n\n// TODO: comment on the variables g and p\n\nexport const gammaG = 4.7421875\n\nexport const gammaP = [\n  0.99999999999999709182,\n  57.156235665862923517,\n  -59.597960355475491248,\n  14.136097974741747174,\n  -0.49191381609762019978,\n  0.33994649984811888699e-4,\n  0.46523628927048575665e-4,\n  -0.98374475304879564677e-4,\n  0.15808870322491248884e-3,\n  -0.21026444172410488319e-3,\n  0.21743961811521264320e-3,\n  -0.16431810653676389022e-3,\n  0.84418223983852743293e-4,\n  -0.26190838401581408670e-4,\n  0.36899182659531622704e-5\n]\n\n// lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code\n\n// log(2 * pi) / 2\nexport const lnSqrt2PI = 0.91893853320467274178\n\nexport const lgammaG = 5 // Lanczos parameter \"g\"\nexport const lgammaN = 7 // Range of coefficients \"n\"\n\nexport const lgammaSeries = [\n  1.000000000190015,\n  76.18009172947146,\n  -86.50532032941677,\n  24.01409824083091,\n  -1.231739572450155,\n  0.1208650973866179e-2,\n  -0.5395239384953e-5\n]\n\nexport function 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  }\n\n  // Compute the logarithm of the Gamma function using the Lanczos method\n\n  n = n - 1\n  const base = n + lgammaG + 0.5 // Base of the Lanczos exponential\n  let sum = lgammaSeries[0]\n\n  // We start with the terms that have the smallest coefficients and largest denominator\n  for (let 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}\nlgammaNumber.signature = 'number'\n","import { factory } from '../../utils/factory.js'\nimport { gammaG, gammaNumber, gammaP } from '../../plain/number/index.js'\n\nconst name = 'gamma'\nconst dependencies = ['typed', 'config', 'multiplyScalar', 'pow', 'BigNumber', 'Complex']\n\nexport const createGamma = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, multiplyScalar, pow, BigNumber, Complex }) => {\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   * To avoid confusion with the matrix Gamma function, this function does\n   * not apply to matrices.\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 | BigNumber | Complex} n   A real or complex number\n   * @return {number | BigNumber | Complex}    The gamma of `n`\n   */\n\n  function gammaComplex (n) {\n    if (n.im === 0) {\n      return gammaNumber(n.re)\n    }\n\n    // Lanczos approximation doesn't work well with real part lower than 0.5\n    // So reflection formula is required\n    if (n.re < 0.5) { // 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      const t = new Complex(1 - n.re, -n.im)\n      const r = new Complex(Math.PI * n.re, Math.PI * n.im)\n\n      return new Complex(Math.PI).div(r.sin()).div(gammaComplex(t))\n    }\n\n    // Lanczos approximation\n    // z -= 1\n    n = new Complex(n.re - 1, n.im)\n\n    // x = gammaPval[0]\n    let x = new Complex(gammaP[0], 0)\n    // for (i, gammaPval) in enumerate(gammaP):\n    for (let i = 1; i < gammaP.length; ++i) {\n      // x += gammaPval / (z + i)\n      const gammaPval = new Complex(gammaP[i], 0)\n      x = x.add(gammaPval.div(n.add(i)))\n    }\n    // t = z + gammaG + 0.5\n    const t = new Complex(n.re + gammaG + 0.5, n.im)\n\n    // y = sqrt(2 * pi) * t ** (z + 0.5) * exp(-t) * x\n    const twoPiSqrt = Math.sqrt(2 * Math.PI)\n    const tpow = t.pow(n.add(0.5))\n    const expt = t.neg().exp()\n\n    // y = [x] * [sqrt(2 * pi)] * [t ** (z + 0.5)] * [exp(-t)]\n    return x.mul(twoPiSqrt).mul(tpow).mul(expt)\n  }\n\n  return typed(name, {\n    number: gammaNumber,\n    Complex: gammaComplex,\n    BigNumber: function (n) {\n      if (n.isInteger()) {\n        return (n.isNegative() || n.isZero())\n          ? new BigNumber(Infinity)\n          : 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  })\n\n  /**\n   * Calculate factorial for a BigNumber\n   * @param {BigNumber} n\n   * @returns {BigNumber} Returns the factorial of 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    const precision = config.precision + (Math.log(n.toNumber()) | 0)\n    const Big = BigNumber.clone({ precision })\n\n    if (n % 2 === 1) {\n      return n.times(bigFactorial(new BigNumber(n - 1)))\n    }\n\n    let p = n\n    let prod = new Big(n)\n    let 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})\n","/* eslint-disable no-loss-of-precision */\n\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\n\nimport { lgammaNumber, lnSqrt2PI } from '../../plain/number/index.js'\nimport { factory } from '../../utils/factory.js'\nimport { copysign } from '../../utils/number.js'\n\nconst name = 'lgamma'\nconst dependencies = ['Complex', 'typed']\n\nexport const createLgamma = /* #__PURE__ */ factory(name, dependencies, ({ Complex, 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  const SMALL_RE = 7\n  const SMALL_IM = 7\n\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  const coeffs = [\n    -2.955065359477124183e-2, 6.4102564102564102564e-3, -1.9175269175269175269e-3, 8.4175084175084175084e-4,\n    -5.952380952380952381e-4, 7.9365079365079365079e-4, -2.7777777777777777778e-3, 8.3333333333333333333e-2\n  ]\n\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  return typed(name, {\n    number: lgammaNumber,\n    Complex: lgammaComplex,\n    BigNumber: function () {\n      throw new Error(\"mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber\")\n    }\n  })\n\n  function lgammaComplex (n) {\n    const TWOPI = 6.2831853071795864769252842 // 2*pi\n    const LOGPI = 1.1447298858494001741434262 // log(pi)\n\n    const REFLECTION = 0.1\n\n    if (n.isNaN()) {\n      return new Complex(NaN, NaN)\n    } else if (n.im === 0) {\n      return new Complex(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      const tmp = copysign(TWOPI, n.im) * Math.floor(0.5 * n.re + 0.25)\n      const a = n.mul(Math.PI).sin().log()\n      const b = lgammaComplex(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\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\n    // left part\n\n    // x (log(x) - 1) + 1/2 (log(2PI) - log(x))\n    // => (x - 0.5) * log(x) - x + log(2PI) / 2\n    const leftPart = z.sub(0.5).mul(z.log()).sub(z).add(lnSqrt2PI)\n\n    // right part\n\n    const rz = new Complex(1, 0).div(z)\n    const rzz = rz.div(z)\n\n    let a = coeffs[0]\n    let b = coeffs[1]\n    const r = 2 * rzz.re\n    const s = rzz.re * rzz.re + rzz.im * rzz.im\n\n    for (let i = 2; i < 8; i++) {\n      const tmp = b\n      b = -s * a + coeffs[i]\n      a = r * a + tmp\n    }\n\n    const rightPart = rz.mul(rzz.mul(a).add(b))\n\n    // 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\n    let signflips = 0\n    let sb = 0\n    let shiftprod = z\n\n    z = z.add(1)\n    while (z.re <= SMALL_RE) {\n      shiftprod = shiftprod.mul(z)\n\n      const nsb = shiftprod.im < 0 ? 1 : 0\n      if (nsb !== 0 && sb === 0) signflips++\n      sb = nsb\n\n      z = z.add(1)\n    }\n\n    return lgammaStirling(z)\n      .sub(shiftprod.log())\n      .sub(new Complex(0, signflips * 2 * Math.PI * 1))\n  }\n})\n","import { deepMap } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'factorial'\nconst dependencies = ['typed', 'gamma']\n\nexport const createFactorial = /* #__PURE__ */ factory(name, dependencies, ({ typed, gamma }) => {\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 (n) {\n      if (n < 0) {\n        throw new Error('Value must be non-negative')\n      }\n\n      return gamma(n + 1)\n    },\n\n    BigNumber: function (n) {\n      if (n.isNegative()) {\n        throw new Error('Value must be non-negative')\n      }\n\n      return gamma(n.plus(1))\n    },\n\n    'Array | Matrix': typed.referToSelf(self => n => deepMap(n, self))\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'kldivergence'\nconst dependencies = ['typed', 'matrix', 'divide', 'sum', 'multiply', 'map', 'dotDivide', 'log', 'isNumeric']\n\nexport const createKldivergence = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, divide, sum, multiply, map, dotDivide, log, isNumeric }) => {\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 (q, p) {\n      return _kldiv(matrix(q), matrix(p))\n    },\n\n    'Matrix, Array': function (q, p) {\n      return _kldiv(q, matrix(p))\n    },\n\n    'Array, Matrix': function (q, p) {\n      return _kldiv(matrix(q), p)\n    },\n\n    'Matrix, Matrix': function (q, p) {\n      return _kldiv(q, p)\n    }\n\n  })\n\n  function _kldiv (q, p) {\n    const plength = p.size().length\n    const qlength = q.size().length\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    }\n\n    // Before calculation, apply normalization\n    const sumq = sum(q)\n    if (sumq === 0) {\n      throw new Error('Sum of elements in first object must be non zero')\n    }\n\n    const sump = sum(p)\n    if (sump === 0) {\n      throw new Error('Sum of elements in second object must be non zero')\n    }\n    const qnorm = divide(q, sum(q))\n    const pnorm = divide(p, sum(p))\n\n    const result = sum(multiply(qnorm, map(dotDivide(qnorm, pnorm), x => log(x))))\n    if (isNumeric(result)) {\n      return result\n    } else {\n      return Number.NaN\n    }\n  }\n})\n","import { deepForEach } from '../../utils/collection.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'multinomial'\nconst dependencies = ['typed', 'add', 'divide', 'multiply', 'factorial', 'isInteger', 'isPositive']\n\nexport const createMultinomial = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide, multiply, factorial, isInteger, isPositive }) => {\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 (a) {\n      let sum = 0\n      let denom = 1\n\n      deepForEach(a, function (ai) {\n        if (!isInteger(ai) || !isPositive(ai)) {\n          throw new TypeError('Positive integer value expected in function multinomial')\n        }\n        sum = add(sum, ai)\n        denom = multiply(denom, factorial(ai))\n      })\n\n      return divide(factorial(sum), denom)\n    }\n  })\n})\n","import { isInteger } from '../../utils/number.js'\nimport { product } from '../../utils/product.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'permutations'\nconst dependencies = ['typed', 'factorial']\n\nexport const createPermutations = /* #__PURE__ */ factory(name, dependencies, ({ typed, factorial }) => {\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 (n, k) {\n      if (!isInteger(n) || n < 0) {\n        throw new TypeError('Positive integer value expected in function permutations')\n      }\n      if (!isInteger(k) || k < 0) {\n        throw new TypeError('Positive integer value expected in function permutations')\n      }\n      if (k > n) {\n        throw new TypeError('second argument k must be less than or equal to first argument n')\n      }\n      // Permute n objects, k at a time\n      return product((n - k) + 1, n)\n    },\n\n    'BigNumber, BigNumber': function (n, k) {\n      let result, i\n\n      if (!isPositiveInteger(n) || !isPositiveInteger(k)) {\n        throw new TypeError('Positive integer value expected in function permutations')\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      const one = n.mul(0).add(1)\n      result = one\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    }\n\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 */\nfunction isPositiveInteger (n) {\n  return n.isInteger() && n.gte(0)\n}\n","import seedrandom from 'seedrandom'\n\nconst singletonRandom = /* #__PURE__ */ seedrandom(Date.now())\n\nexport function createRng (randomSeed) {\n  let random\n\n  // create a new random generator with given seed\n  function setSeed (seed) {\n    random = seed === null ? singletonRandom : seedrandom(String(seed))\n  }\n\n  // initialize a seeded pseudo random number generator with config's random seed\n  setSeed(randomSeed)\n\n  // wrapper function so the rng can be updated via generator\n  function rng () {\n    return random()\n  }\n\n  return rng\n}\n","import { flatten } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isMatrix, isNumber } from '../../utils/is.js'\nimport { createRng } from './util/seededRNG.js'\n\nconst name = 'pickRandom'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createPickRandom = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n  // seeded pseudo random number generator\n  let rng = createRng(config.randomSeed)\n\n  if (on) {\n    on('config', function (curr, prev) {\n      if (curr.randomSeed !== prev.randomSeed) {\n        rng = createRng(curr.randomSeed)\n      }\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 undefined.\n   *                                   Returns an array with the configured number of elements when number is defined.\n   */\n  return typed(name, {\n    'Array | Matrix': function (possibles) {\n      return _pickRandom(possibles, {})\n    },\n\n    'Array | Matrix, Object': function (possibles, options) {\n      return _pickRandom(possibles, options)\n    },\n\n    'Array | Matrix, number': function (possibles, number) {\n      return _pickRandom(possibles, { number })\n    },\n\n    'Array | Matrix, Array | Matrix': function (possibles, weights) {\n      return _pickRandom(possibles, { weights })\n    },\n\n    'Array | Matrix, Array | Matrix, number': function (possibles, weights, number) {\n      return _pickRandom(possibles, { number, weights })\n    },\n\n    'Array | Matrix, number, Array | Matrix': function (possibles, number, weights) {\n      return _pickRandom(possibles, { number, 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  function _pickRandom (possibles, { number, weights, elementWise = true }) {\n    const single = (typeof number === 'undefined')\n    if (single) {\n      number = 1\n    }\n\n    const createMatrix = isMatrix(possibles)\n      ? possibles.create\n      : isMatrix(weights)\n        ? weights.create\n        : null\n\n    possibles = possibles.valueOf() // get Array\n    if (weights) {\n      weights = weights.valueOf() // get Array\n    }\n\n    if (elementWise === true) {\n      possibles = flatten(possibles)\n      weights = flatten(weights)\n    }\n\n    let 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 (let i = 0, len = weights.length; i < len; i++) {\n        if (!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    const length = possibles.length\n\n    const result = []\n    let pick\n\n    while (result.length < number) {\n      if (typeof weights === 'undefined') {\n        pick = possibles[Math.floor(rng() * length)]\n      } else {\n        let randKey = rng() * totalWeights\n\n        for (let 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\n      ? result[0]\n      : createMatrix\n        ? createMatrix(result)\n        : result\n  }\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 */\nexport function randomMatrix (size, random) {\n  const data = []\n  size = size.slice(0)\n\n  if (size.length > 1) {\n    for (let i = 0, length = size.shift(); i < length; i++) {\n      data.push(randomMatrix(size, random))\n    }\n  } else {\n    for (let i = 0, length = size.shift(); i < length; i++) {\n      data.push(random())\n    }\n  }\n\n  return data\n}\n","import { factory } from '../../utils/factory.js'\nimport { isMatrix } from '../../utils/is.js'\nimport { createRng } from './util/seededRNG.js'\nimport { randomMatrix } from './util/randomMatrix.js'\n\nconst name = 'random'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createRandom = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n  // seeded pseudo random number generator\n  let rng = createRng(config.randomSeed)\n\n  if (on) {\n    on('config', function (curr, prev) {\n      if (curr.randomSeed !== prev.randomSeed) {\n        rng = createRng(curr.randomSeed)\n      }\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  return typed(name, {\n    '': () => _random(0, 1),\n    number: (max) => _random(0, max),\n    'number, number': (min, max) => _random(min, max),\n    'Array | Matrix': (size) => _randomMatrix(size, 0, 1),\n    'Array | Matrix, number': (size, max) => _randomMatrix(size, 0, max),\n    'Array | Matrix, number, number': (size, min, max) => _randomMatrix(size, min, max)\n  })\n\n  function _randomMatrix (size, min, max) {\n    const res = randomMatrix(size.valueOf(), () => _random(min, max))\n    return isMatrix(size) ? size.create(res) : res\n  }\n\n  function _random (min, max) {\n    return min + rng() * (max - min)\n  }\n})\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?\nexport const createRandomNumber = /* #__PURE__ */ factory(name, ['typed', 'config', '?on'], ({ typed, config, on, matrix }) => {\n  // seeded pseudo random number generator1\n  let rng = createRng(config.randomSeed)\n\n  if (on) {\n    on('config', function (curr, prev) {\n      if (curr.randomSeed !== prev.randomSeed) {\n        rng = createRng(curr.randomSeed)\n      }\n    })\n  }\n\n  return typed(name, {\n    '': () => _random(0, 1),\n    number: (max) => _random(0, max),\n    'number, number': (min, max) => _random(min, max)\n  })\n\n  function _random (min, max) {\n    return min + rng() * (max - min)\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { randomMatrix } from './util/randomMatrix.js'\nimport { createRng } from './util/seededRNG.js'\nimport { isMatrix } from '../../utils/is.js'\n\nconst name = 'randomInt'\nconst dependencies = ['typed', 'config', '?on']\n\nexport const createRandomInt = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, on }) => {\n  // seeded pseudo random number generator\n  let rng = createRng(config.randomSeed)\n\n  if (on) {\n    on('config', function (curr, prev) {\n      if (curr.randomSeed !== prev.randomSeed) {\n        rng = createRng(curr.randomSeed)\n      }\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  return typed(name, {\n    '': () => _randomInt(0, 1),\n    number: (max) => _randomInt(0, max),\n    'number, number': (min, max) => _randomInt(min, max),\n    'Array | Matrix': (size) => _randomIntMatrix(size, 0, 1),\n    'Array | Matrix, number': (size, max) => _randomIntMatrix(size, 0, max),\n    'Array | Matrix, number, number': (size, min, max) => _randomIntMatrix(size, min, max)\n  })\n\n  function _randomIntMatrix (size, min, max) {\n    const res = randomMatrix(size.valueOf(), () => _randomInt(min, max))\n    return isMatrix(size) ? size.create(res) : res\n  }\n\n  function _randomInt (min, max) {\n    return Math.floor(min + rng() * (max - min))\n  }\n})\n","import { factory } from '../../utils/factory.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'stirlingS2'\nconst dependencies = [\n  'typed',\n  'addScalar',\n  'subtractScalar',\n  'multiplyScalar',\n  'divideScalar',\n  'pow',\n  'factorial',\n  'combinations',\n  'isNegative',\n  'isInteger',\n  'number',\n  '?bignumber',\n  'larger'\n]\n\nexport const createStirlingS2 = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    addScalar,\n    subtractScalar,\n    multiplyScalar,\n    divideScalar,\n    pow,\n    factorial,\n    combinations,\n    isNegative,\n    isInteger,\n    number,\n    bignumber,\n    larger\n  }\n) => {\n  const smallCache = []\n  const 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  return typed(name, {\n    'number | BigNumber, number | BigNumber': function (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      const big = !(isNumber(n) && isNumber(k))\n      const cache = big ? bigCache : smallCache\n      const make = big ? bignumber : number\n      const nn = number(n)\n      const nk = number(k)\n      /* See if we already have the value: */\n      if (cache[nn] && cache[nn].length > nk) {\n        return cache[nn][nk]\n      }\n      /* Fill the cache */\n      for (let m = 0; m <= nn; ++m) {\n        if (!cache[m]) {\n          cache[m] = [m === 0 ? make(1) : make(0)]\n        }\n        if (m === 0) continue\n        const row = cache[m]\n        const prev = cache[m - 1]\n        for (let 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      return cache[nn][nk]\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'bellNumbers'\nconst dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2']\n\nexport const createBellNumbers = /* #__PURE__ */ factory(name, dependencies, ({ typed, addScalar, isNegative, isInteger, stirlingS2 }) => {\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 (n) {\n      if (!isInteger(n) || isNegative(n)) {\n        throw new TypeError('Non-negative integer value expected in function bellNumbers')\n      }\n\n      // Sum (k=0, n) S(n,k).\n      let result = 0\n      for (let i = 0; i <= n; i++) {\n        result = addScalar(result, stirlingS2(n, i))\n      }\n\n      return result\n    }\n  })\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'catalan'\nconst dependencies = [\n  'typed',\n  'addScalar',\n  'divideScalar',\n  'multiplyScalar',\n  'combinations',\n  'isNegative',\n  'isInteger'\n]\n\nexport const createCatalan = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    addScalar,\n    divideScalar,\n    multiplyScalar,\n    combinations,\n    isNegative,\n    isInteger\n  }\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 (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})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'composition'\nconst dependencies = [\n  'typed',\n  'addScalar',\n  'combinations',\n  'isNegative',\n  'isPositive',\n  'isInteger',\n  'larger'\n]\n\nexport const createComposition = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    typed,\n    addScalar,\n    combinations,\n    isPositive,\n    isNegative,\n    isInteger,\n    larger\n  }\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 (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})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'leafCount'\nconst dependencies = [\n  'parse',\n  'typed'\n]\n\nexport const createLeafCount = /* #__PURE__ */ factory(name, dependencies, ({\n  parse,\n  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    let count = 0\n    node.forEach(n => { count += countLeaves(n) })\n    return count || 1\n  }\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   *     math.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  return typed(name, {\n    Node: function (expr) {\n      return countLeaves(expr)\n    }\n  })\n})\n","import { isConstantNode, isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'\nexport { isConstantNode, isSymbolNode as isVariableNode } from '../../../utils/is.js'\n\nexport function isNumericNode (x) {\n  return isConstantNode(x) || (isOperatorNode(x) && x.isUnary() && isConstantNode(x.args[0]))\n}\n\nexport function isConstantExpression (x) {\n  if (isConstantNode(x)) { // Basic Constant types\n    return true\n  }\n  if ((isFunctionNode(x) || isOperatorNode(x)) && x.args.every(isConstantExpression)) { // Can be constant depending on arguments\n    return true\n  }\n  if (isParenthesisNode(x) && isConstantExpression(x.content)) { // Parenthesis are transparent\n    return true\n  }\n  return false // Probably missing some edge cases\n}\n","import { isFunctionNode, isOperatorNode, isParenthesisNode } from '../../../utils/is.js'\nimport { factory } from '../../../utils/factory.js'\nimport { hasOwnProperty } from '../../../utils/object.js'\n\nconst name = 'simplifyUtil'\nconst dependencies = [\n  'FunctionNode',\n  'OperatorNode',\n  'SymbolNode'\n]\n\nexport const createUtil = /* #__PURE__ */ factory(name, dependencies, ({ FunctionNode, OperatorNode, 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  const T = true\n  const F = false\n\n  const defaultName = 'defaultF'\n  const defaultContext = {\n    /*      */ add: { trivial: T, total: T, commutative: T, associative: T },\n    /**/ unaryPlus: { trivial: T, total: T, commutative: T, associative: T },\n    /* */ subtract: { trivial: F, total: T, commutative: F, associative: F },\n    /* */ multiply: { trivial: T, total: T, commutative: T, associative: T },\n    /*   */ divide: { trivial: F, total: T, commutative: F, associative: F },\n    /*    */ paren: { trivial: T, total: T, commutative: T, associative: F },\n    /* */ defaultF: { trivial: F, total: T, commutative: F, associative: F }\n  }\n  const realContext = { divide: { total: F }, log: { total: F } }\n  const positiveContext = {\n    subtract: { total: F },\n    abs: { trivial: T },\n    log: { total: T }\n  }\n\n  function hasProperty (nodeOrName, property, context = defaultContext) {\n    let name = defaultName\n    if (typeof nodeOrName === 'string') {\n      name = nodeOrName\n    } else if (isOperatorNode(nodeOrName)) {\n      name = nodeOrName.fn.toString()\n    } else if (isFunctionNode(nodeOrName)) {\n      name = nodeOrName.name\n    } else if (isParenthesisNode(nodeOrName)) {\n      name = 'paren'\n    }\n    if (hasOwnProperty(context, name)) {\n      const properties = context[name]\n      if (hasOwnProperty(properties, property)) {\n        return properties[property]\n      }\n      if (hasOwnProperty(defaultContext, name)) {\n        return defaultContext[name][property]\n      }\n    }\n    if (hasOwnProperty(context, defaultName)) {\n      const properties = context[defaultName]\n      if (hasOwnProperty(properties, property)) {\n        return properties[property]\n      }\n      return defaultContext[defaultName][property]\n    }\n    /* name not found in context and context has no global default */\n    /* So use default context. */\n    if (hasOwnProperty(defaultContext, name)) {\n      const properties = defaultContext[name]\n      if (hasOwnProperty(properties, property)) {\n        return properties[property]\n      }\n    }\n    return defaultContext[defaultName][property]\n  }\n\n  function isCommutative (node, context = defaultContext) {\n    return hasProperty(node, 'commutative', context)\n  }\n\n  function isAssociative (node, context = defaultContext) {\n    return hasProperty(node, 'associative', context)\n  }\n\n  /**\n   * Merge the given contexts, with primary overriding secondary\n   * wherever they might conflict\n   */\n  function mergeContext (primary, secondary) {\n    const merged = { ...primary }\n    for (const prop in secondary) {\n      if (hasOwnProperty(primary, prop)) {\n        merged[prop] = { ...secondary[prop], ...primary[prop] }\n      } else {\n        merged[prop] = secondary[prop]\n      }\n    }\n    return merged\n  }\n\n  /**\n   * Flatten all associative operators in an expression tree.\n   * Assumes parentheses have already been removed.\n   */\n  function flatten (node, context) {\n    if (!node.args || node.args.length === 0) {\n      return node\n    }\n    node.args = allChildren(node, context)\n    for (let i = 0; i < node.args.length; i++) {\n      flatten(node.args[i], context)\n    }\n  }\n\n  /**\n   * Get the children of a node as if it has been flattened.\n   * TODO implement for FunctionNodes\n   */\n  function allChildren (node, context) {\n    let op\n    const children = []\n    const findChildren = function (node) {\n      for (let i = 0; i < node.args.length; i++) {\n        const child = node.args[i]\n        if (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  /**\n   *  Unflatten all flattened operators to a right-heavy binary tree.\n   */\n  function unflattenr (node, context) {\n    if (!node.args || node.args.length === 0) {\n      return\n    }\n    const makeNode = createMakeNodeFunction(node)\n    const l = node.args.length\n    for (let i = 0; i < l; i++) {\n      unflattenr(node.args[i], context)\n    }\n    if (l > 2 && isAssociative(node, context)) {\n      let curnode = node.args.pop()\n      while (node.args.length > 0) {\n        curnode = makeNode([node.args.pop(), curnode])\n      }\n      node.args = curnode.args\n    }\n  }\n\n  /**\n   *  Unflatten all flattened operators to a left-heavy binary tree.\n   */\n  function unflattenl (node, context) {\n    if (!node.args || node.args.length === 0) {\n      return\n    }\n    const makeNode = createMakeNodeFunction(node)\n    const l = node.args.length\n    for (let i = 0; i < l; i++) {\n      unflattenl(node.args[i], context)\n    }\n    if (l > 2 && isAssociative(node, context)) {\n      let curnode = node.args.shift()\n      while (node.args.length > 0) {\n        curnode = makeNode([curnode, node.args.shift()])\n      }\n      node.args = curnode.args\n    }\n  }\n\n  function createMakeNodeFunction (node) {\n    if (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,\n    hasProperty,\n    isCommutative,\n    isAssociative,\n    mergeContext,\n    flatten,\n    allChildren,\n    unflattenr,\n    unflattenl,\n    defaultContext,\n    realContext,\n    positiveContext\n  }\n})\n","import { isParenthesisNode } from '../../utils/is.js'\nimport { isConstantNode, isVariableNode, isNumericNode, isConstantExpression } from './simplify/wildcards.js'\nimport { factory } from '../../utils/factory.js'\nimport { createUtil } from './simplify/util.js'\nimport { hasOwnProperty } from '../../utils/object.js'\nimport { createEmptyMap, createMap } from '../../utils/map.js'\n\nconst name = 'simplify'\nconst dependencies = [\n  'config',\n  'typed',\n  'parse',\n  'add',\n  'subtract',\n  'multiply',\n  'divide',\n  'pow',\n  'isZero',\n  'equal',\n  'resolve',\n  'simplifyConstant',\n  'simplifyCore',\n  '?fraction',\n  '?bignumber',\n  'mathWithTransform',\n  'matrix',\n  'AccessorNode',\n  'ArrayNode',\n  'ConstantNode',\n  'FunctionNode',\n  'IndexNode',\n  'ObjectNode',\n  'OperatorNode',\n  'ParenthesisNode',\n  'SymbolNode'\n]\n\nexport const createSimplify = /* #__PURE__ */ factory(name, dependencies, (\n  {\n    config,\n    typed,\n    parse,\n    add,\n    subtract,\n    multiply,\n    divide,\n    pow,\n    isZero,\n    equal,\n    resolve,\n    simplifyConstant,\n    simplifyCore,\n    fraction,\n    bignumber,\n    mathWithTransform,\n    matrix,\n    AccessorNode,\n    ArrayNode,\n    ConstantNode,\n    FunctionNode,\n    IndexNode,\n    ObjectNode,\n    OperatorNode,\n    ParenthesisNode,\n    SymbolNode\n  }\n) => {\n  const { hasProperty, isCommutative, isAssociative, mergeContext, flatten, unflattenr, unflattenl, createMakeNodeFunction, defaultContext, realContext, positiveContext } =\n    createUtil({ FunctionNode, OperatorNode, SymbolNode })\n\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 [Node]\n   * - 'c' - Matches a constant literal (5 or 3.2) [ConstantNode]\n   * - 'cl' - Matches a constant literal; same as c [ConstantNode]\n   * - 'cd' - Matches a decimal literal (5 or -3.2) [ConstantNode or unaryMinus wrapping a ConstantNode]\n   * - 'ce' - Matches a constant expression (-5 or √3) [Expressions consisting of only ConstantNodes, functions, and operators]\n   * - 'v' - Matches a variable; anything not matched by c (-5 or x) [Node that is not a ConstantNode]\n   * - 'vl' - Matches a variable literal (x or y) [SymbolNode]\n   * - 'vd' - Matches a non-decimal expression; anything not matched by cd (x or √3) [Node that is not a ConstantNode or unaryMinus that is wrapping a ConstantNode]\n   * - 've' - Matches a variable expression; anything not matched by ce (x or 2x) [Expressions that contain a SymbolNode or other non-constant term]\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. Note that since\n   * the `simplifyCore` function is in the default list of rules, by default\n   * simplify will convert any function calls in the expression that have\n   * operator equivalents to their operator forms.\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   *     math.simplify(expr)\n   *     math.simplify(expr, rules)\n   *     math.simplify(expr, rules)\n   *     math.simplify(expr, rules, scope)\n   *     math.simplify(expr, rules, scope, options)\n   *     math.simplify(expr, scope)\n   *     math.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 {SimplifyRule[]} [rules]\n   *            Optional list with custom rules\n   * @param {Object} [scope] Optional scope with variables\n   * @param {SimplifyOptions} [options] Optional configuration settings\n   * @return {Node} Returns the simplified form of `expr`\n   */\n  typed.addConversion({ from: 'Object', to: 'Map', convert: createMap })\n  const simplify = typed('simplify', {\n    Node: _simplify,\n    'Node, Map': (expr, scope) => _simplify(expr, false, scope),\n    'Node, Map, Object':\n      (expr, scope, options) => _simplify(expr, false, scope, options),\n    'Node, Array': _simplify,\n    'Node, Array, Map': _simplify,\n    'Node, Array, Map, Object': _simplify\n  })\n  typed.removeConversion({ from: 'Object', to: 'Map', convert: createMap })\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 isParenthesisNode(node)\n        ? removeParens(node.content)\n        : node\n    })\n  }\n\n  // All constants that are allowed in rules\n  const 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\n    // null: false,\n    // undefined: false,\n    // version: false,\n  }\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  simplify.rules = [\n    simplifyCore,\n    // { 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    { l: 'log(e)', r: '1' },\n\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', // temporarily replace 'subtract' so we can further flatten the 'add' operator\n      assuming: { subtract: { total: true } }\n    },\n    {\n      s: 'n-n -> 0', // partial alternative when we can't always subtract\n      assuming: { subtract: { total: false } }\n    },\n    {\n      s: '-(cl*v) -> v * (-cl)', // make non-constant terms positive\n      assuming: { multiply: { commutative: true }, subtract: { total: true } }\n    },\n    {\n      s: '-(cl*v) -> (-cl) * v', // non-commutative version, part 1\n      assuming: { multiply: { commutative: false }, subtract: { total: true } }\n    },\n    {\n      s: '-(v*cl) -> v * (-cl)', // non-commutative version, part 2\n      assuming: { multiply: { commutative: false }, subtract: { total: true } }\n    },\n    { l: '-(n1/n2)', r: '-n1/n2' },\n    { l: '-v', r: 'v * (-1)' }, // finish making non-constant terms positive\n    { l: '(n1 + n2)*(-1)', r: 'n1*(-1) + n2*(-1)', repeat: true }, // expand negations to achieve as much sign cancellation as possible\n    { l: 'n/n1^n2', r: 'n*n1^-n2' }, // temporarily replace 'divide' so we can further flatten the 'multiply' operator\n    { l: 'n/n1', r: 'n*n1^-1' },\n    {\n      s: '(n1*n2)^n3 -> n1^n3 * n2^n3',\n      assuming: { multiply: { commutative: true } }\n    },\n    {\n      s: '(n1*n2)^(-1) -> n2^(-1) * n1^(-1)',\n      assuming: { multiply: { commutative: false } }\n    },\n\n    // expand nested exponentiation\n    {\n      s: '(n ^ n1) ^ n2 -> n ^ (n1 * n2)',\n      assuming: { divide: { total: true } } // 1/(1/n) = n needs 1/n to exist\n    },\n\n    // collect like factors; into a sum, only do this for nonconstants\n    { l: ' vd   * ( vd   * n1 + n2)', r: 'vd^2       * n1 +  vd   * n2' },\n    {\n      s: ' vd   * (vd^n4 * n1 + n2)   ->  vd^(1+n4)  * n1 +  vd   * n2',\n      assuming: { divide: { total: true } } // v*1/v = v^(1+-1) needs 1/v\n    },\n    {\n      s: 'vd^n3 * ( vd   * n1 + n2)   ->  vd^(n3+1)  * n1 + vd^n3 * n2',\n      assuming: { divide: { total: true } }\n    },\n    {\n      s: 'vd^n3 * (vd^n4 * n1 + n2)   ->  vd^(n3+n4) * n1 + vd^n3 * n2',\n      assuming: { divide: { total: true } }\n    },\n    { l: 'n*n', r: 'n^2' },\n    {\n      s: 'n * n^n1 -> n^(n1+1)',\n      assuming: { divide: { total: true } } // n*1/n = n^(-1+1) needs 1/n\n    },\n    {\n      s: 'n^n1 * n^n2 -> n^(n1+n2)',\n      assuming: { divide: { total: true } } // ditto for n^2*1/n^2\n    },\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\n    // collect like terms\n    {\n      s: 'n+n -> 2*n',\n      assuming: { add: { total: true } } // 2 = 1 + 1 needs to exist\n    },\n    { l: 'n+-n', r: '0' },\n    { l: 'vd*n + vd', r: 'vd*(n+1)' }, // NOTE: leftmost position is special:\n    { l: 'n3*n1 + n3*n2', r: 'n3*(n1+n2)' }, // All sub-monomials tried there.\n    { l: 'n3^(-n4)*n1 +   n3  * n2', r: 'n3^(-n4)*(n1 + n3^(n4+1) *n2)' },\n    { l: 'n3^(-n4)*n1 + n3^n5 * n2', r: 'n3^(-n4)*(n1 + n3^(n4+n5)*n2)' },\n    // noncommutative additional cases (term collection & factoring)\n    {\n      s: 'n*vd + vd -> (n+1)*vd',\n      assuming: { multiply: { commutative: false } }\n    },\n    {\n      s: 'vd + n*vd -> (1+n)*vd',\n      assuming: { multiply: { commutative: false } }\n    },\n    {\n      s: 'n1*n3 + n2*n3 -> (n1+n2)*n3',\n      assuming: { multiply: { commutative: false } }\n    },\n    {\n      s: 'n^n1 * n -> n^(n1+1)',\n      assuming: { divide: { total: true }, multiply: { commutative: false } }\n    },\n    {\n      s: 'n1*n3^(-n4) + n2 * n3    -> (n1 + n2*n3^(n4 +  1))*n3^(-n4)',\n      assuming: { multiply: { commutative: false } }\n    },\n    {\n      s: 'n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)',\n      assuming: { multiply: { commutative: false } }\n    },\n    { l: 'n*cd + cd', r: '(n+1)*cd' },\n    {\n      s: 'cd*n + cd -> cd*(n+1)',\n      assuming: { multiply: { commutative: false } }\n    },\n    {\n      s: 'cd + cd*n -> cd*(1+n)',\n      assuming: { multiply: { commutative: false } }\n    },\n    simplifyConstant, // Second: before returning expressions to \"standard form\"\n\n    // make factors positive (and undo 'make non-constant terms positive')\n    {\n      s: '(-n)*n1 -> -(n*n1)',\n      assuming: { subtract: { total: true } }\n    },\n    {\n      s: 'n1*(-n) -> -(n1*n)', // in case * non-commutative\n      assuming: { subtract: { total: true }, multiply: { commutative: false } }\n    },\n\n    // final ordering of constants\n    {\n      s: 'ce+ve -> ve+ce',\n      assuming: { add: { commutative: true } },\n      imposeContext: { add: { commutative: false } }\n    },\n    {\n      s: 'vd*cd -> cd*vd',\n      assuming: { multiply: { commutative: true } },\n      imposeContext: { multiply: { commutative: false } }\n    },\n\n    // undo temporary rules\n    // { l: '(-1) * n', r: '-n' }, // #811 added test which proved this is redundant\n    { l: 'n+-n1', r: 'n-n1' }, // undo replace 'subtract'\n    { l: 'n+-(n1)', r: 'n-(n1)' },\n    {\n      s: 'n*(n1^-1) -> n/n1', // undo replace 'divide'; for * commutative\n      assuming: { multiply: { commutative: true } } // o.w. / not conventional\n    },\n    {\n      s: 'n*n1^-n2 -> n/n1^n2',\n      assuming: { multiply: { commutative: true } } // o.w. / not conventional\n    },\n    {\n      s: 'n^-1 -> 1/n',\n      assuming: { multiply: { commutative: true } } // o.w. / not conventional\n    },\n    { l: 'n^1', r: 'n' }, // can be produced by power cancellation\n    {\n      s: 'n*(n1/n2) -> (n*n1)/n2', // '*' before '/'\n      assuming: { multiply: { associative: true } }\n    },\n    {\n      s: 'n-(n1+n2) -> n-n1-n2', // '-' before '+'\n      assuming: { addition: { associative: true, commutative: true } }\n    },\n    // { l: '(n1/n2)/n3', r: 'n1/(n2*n3)' },\n    // { l: '(n*n1)/(n*n2)', r: 'n1/n2' },\n\n    // simplifyConstant can leave an extra factor of 1, which can always\n    // be eliminated, since the identity always commutes\n    { l: '1*n', r: 'n', imposeContext: { multiply: { commutative: true } } },\n\n    {\n      s: 'n1/(n2/n3) -> (n1*n3)/n2',\n      assuming: { multiply: { associative: true } }\n    },\n\n    { l: 'n1/(-n2)', r: '-n1/n2' }\n\n  ]\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  function _canonicalizeRule (ruleObject, context) {\n    const newRule = {}\n    if (ruleObject.s) {\n      const lr = ruleObject.s.split('->')\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    newRule.l = removeParens(parse(newRule.l))\n    newRule.r = removeParens(parse(newRule.r))\n    for (const prop of ['imposeContext', 'repeat', 'assuming']) {\n      if (prop in ruleObject) {\n        newRule[prop] = ruleObject[prop]\n      }\n    }\n    if (ruleObject.evaluate) {\n      newRule.evaluate = parse(ruleObject.evaluate)\n    }\n\n    if (isAssociative(newRule.l, context)) {\n      const nonCommutative = !isCommutative(newRule.l, context)\n      let leftExpandsym\n      // Gen. the LHS placeholder used in this NC-context specific expansion rules\n      if (nonCommutative) leftExpandsym = _getExpandPlaceholderSymbol()\n\n      const makeNode = createMakeNodeFunction(newRule.l)\n      const expandsym = _getExpandPlaceholderSymbol()\n      newRule.expanded = {}\n      newRule.expanded.l = makeNode([newRule.l, expandsym])\n      // Push the expandsym into the deepest possible branch.\n      // This helps to match the newRule against nodes returned from getSplits() later on.\n      flatten(newRule.expanded.l, context)\n      unflattenr(newRule.expanded.l, context)\n      newRule.expanded.r = makeNode([newRule.r, expandsym])\n\n      // In and for a non-commutative context, attempting with yet additional expansion rules makes\n      // way for more matches cases of multi-arg expressions; such that associative rules (such as\n      // 'n*n -> n^2') can be applied to exprs. such as 'a * b * b' and 'a * b * b * a'.\n      if (nonCommutative) {\n        // 'Non-commutative' 1: LHS (placeholder) only\n        newRule.expandedNC1 = {}\n        newRule.expandedNC1.l = makeNode([leftExpandsym, newRule.l])\n        newRule.expandedNC1.r = makeNode([leftExpandsym, newRule.r])\n        // 'Non-commutative' 2: farmost LHS and RHS placeholders\n        newRule.expandedNC2 = {}\n        newRule.expandedNC2.l = makeNode([leftExpandsym, newRule.expanded.l])\n        newRule.expandedNC2.r = makeNode([leftExpandsym, newRule.expanded.r])\n      }\n    }\n\n    return newRule\n  }\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  function _buildRules (rules, context) {\n    // Array of rules to be used to simplify expressions\n    const ruleSet = []\n    for (let i = 0; i < rules.length; i++) {\n      let rule = rules[i]\n      let newRule\n      const ruleType = typeof rule\n      switch (ruleType) {\n        case 'string':\n          rule = { s: rule }\n        /* falls through */\n        case 'object':\n          newRule = _canonicalizeRule(rule, context)\n          break\n        case 'function':\n          newRule = rule\n          break\n        default:\n          throw TypeError('Unsupported type of rule: ' + ruleType)\n      }\n      // console.log('Adding rule: ' + rules[i])\n      // console.log(newRule)\n      ruleSet.push(newRule)\n    }\n    return ruleSet\n  }\n\n  let _lastsym = 0\n  function _getExpandPlaceholderSymbol () {\n    return new SymbolNode('_p' + _lastsym++)\n  }\n\n  function _simplify (expr, rules, scope = createEmptyMap(), options = {}) {\n    const debug = options.consoleDebug\n    rules = _buildRules(rules || simplify.rules, options.context)\n    let res = resolve(expr, scope)\n    res = removeParens(res)\n    const visited = {}\n    let str = res.toString({ parenthesis: 'all' })\n    while (!visited[str]) {\n      visited[str] = true\n      _lastsym = 0 // counter for placeholder symbols\n      let laststr = str\n      if (debug) console.log('Working on: ', str)\n      for (let i = 0; i < rules.length; i++) {\n        let rulestr = ''\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          if (debug) {\n            rulestr = `${rules[i].l.toString()} -> ${rules[i].r.toString()}`\n          }\n        }\n        if (debug) {\n          const newstr = res.toString({ parenthesis: 'all' })\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        unflattenl(res, options.context)\n      }\n      str = res.toString({ parenthesis: 'all' })\n    }\n    return res\n  }\n\n  function mapRule (nodes, rule, context) {\n    let resNodes = nodes\n    if (nodes) {\n      for (let i = 0; i < nodes.length; ++i) {\n        const newNode = applyRule(nodes[i], rule, context)\n        if (newNode !== nodes[i]) {\n          if (resNodes === nodes) {\n            resNodes = nodes.slice()\n          }\n          resNodes[i] = newNode\n        }\n      }\n    }\n    return resNodes\n  }\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  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\n    // check that the assumptions for this rule are satisfied by the current\n    // context:\n    if (rule.assuming) {\n      for (const symbol in rule.assuming) {\n        for (const property in rule.assuming[symbol]) {\n          if (hasProperty(symbol, property, context) !==\n              rule.assuming[symbol][property]) {\n            return node\n          }\n        }\n      }\n    }\n\n    const mergedContext = mergeContext(rule.imposeContext, context)\n\n    // Do not clone node unless we find a match\n    let res = node\n\n    // 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    if (res instanceof OperatorNode || res instanceof FunctionNode) {\n      const newArgs = mapRule(res.args, rule, context)\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        const newContent = applyRule(res.content, rule, context)\n        if (newContent !== res.content) {\n          res = new ParenthesisNode(newContent)\n        }\n      }\n    } else if (res instanceof ArrayNode) {\n      const newItems = mapRule(res.items, rule, context)\n      if (newItems !== res.items) {\n        res = new ArrayNode(newItems)\n      }\n    } else if (res instanceof AccessorNode) {\n      let newObj = res.object\n      if (res.object) {\n        newObj = applyRule(res.object, rule, context)\n      }\n      let newIndex = res.index\n      if (res.index) {\n        newIndex = applyRule(res.index, rule, context)\n      }\n      if (newObj !== res.object || newIndex !== res.index) {\n        res = new AccessorNode(newObj, newIndex)\n      }\n    } else if (res instanceof IndexNode) {\n      const newDims = mapRule(res.dimensions, rule, context)\n      if (newDims !== res.dimensions) {\n        res = new IndexNode(newDims)\n      }\n    } else if (res instanceof ObjectNode) {\n      let changed = false\n      const newProps = {}\n      for (const prop in res.properties) {\n        newProps[prop] = applyRule(res.properties[prop], rule, context)\n        if (newProps[prop] !== res.properties[prop]) {\n          changed = true\n        }\n      }\n      if (changed) {\n        res = new ObjectNode(newProps)\n      }\n    }\n\n    // Try to match a rule against this node\n    let repl = rule.r\n    let matches = _ruleMatch(rule.l, res, mergedContext)[0]\n\n    // 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    if (!matches && rule.expanded) {\n      repl = rule.expanded.r\n      matches = _ruleMatch(rule.expanded.l, res, mergedContext)[0]\n    }\n    // Additional, non-commutative context expansion-rules\n    if (!matches && rule.expandedNC1) {\n      repl = rule.expandedNC1.r\n      matches = _ruleMatch(rule.expandedNC1.l, res, mergedContext)[0]\n      if (!matches) { // Existence of NC1 implies NC2\n        repl = rule.expandedNC2.r\n        matches = _ruleMatch(rule.expandedNC2.l, res, mergedContext)[0]\n      }\n    }\n\n    if (matches) {\n      // const before = res.toString({parenthesis: 'all'})\n\n      // Create a new node by cloning the rhs of the matched rule\n      // we keep any implicit multiplication state if relevant\n      const implicit = res.implicit\n      res = repl.clone()\n      if (implicit && 'implicit' in repl) {\n        res.implicit = true\n      }\n\n      // Replace placeholders with their respective nodes without traversing deeper into the replaced nodes\n      res = res.transform(function (node) {\n        if (node.isSymbolNode && hasOwnProperty(matches.placeholders, node.name)) {\n          return matches.placeholders[node.name].clone()\n        } else {\n          return node\n        }\n      })\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  /**\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  function getSplits (node, context) {\n    const res = []\n    let right, rightArgs\n    const makeNode = createMakeNodeFunction(node)\n    if (isCommutative(node, context)) {\n      for (let 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 (let i = 1; i < node.args.length; i++) {\n        let left = node.args[0]\n        if (i > 1) {\n          left = makeNode(node.args.slice(0, i))\n        }\n        rightArgs = node.args.slice(i)\n        right = (rightArgs.length === 1) ? rightArgs[0] : makeNode(rightArgs)\n        res.push(makeNode([left, right]))\n      }\n    }\n    return res\n  }\n\n  /**\n   * Returns the set union of two match-placeholders or null if there is a conflict.\n   */\n  function mergeMatch (match1, match2) {\n    const res = { placeholders: {} }\n\n    // Some matches may not have placeholders; this is OK\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    }\n\n    // Placeholders with the same key must match exactly\n    for (const key in match1.placeholders) {\n      if (hasOwnProperty(match1.placeholders, key)) {\n        res.placeholders[key] = match1.placeholders[key]\n\n        if (hasOwnProperty(match2.placeholders, key)) {\n          if (!_exactMatch(match1.placeholders[key], match2.placeholders[key])) {\n            return null\n          }\n        }\n      }\n    }\n\n    for (const key in match2.placeholders) {\n      if (hasOwnProperty(match2.placeholders, key)) {\n        res.placeholders[key] = match2.placeholders[key]\n      }\n    }\n\n    return res\n  }\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  function combineChildMatches (list1, list2) {\n    const res = []\n\n    if (list1.length === 0 || list2.length === 0) {\n      return res\n    }\n\n    let merged\n    for (let i1 = 0; i1 < list1.length; i1++) {\n      for (let i2 = 0; i2 < list2.length; i2++) {\n        merged = mergeMatch(list1[i1], list2[i2])\n        if (merged) {\n          res.push(merged)\n        }\n      }\n    }\n    return res\n  }\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  function mergeChildMatches (childMatches) {\n    if (childMatches.length === 0) {\n      return childMatches\n    }\n\n    const sets = childMatches.reduce(combineChildMatches)\n    const uniqueSets = []\n    const unique = {}\n    for (let i = 0; i < sets.length; i++) {\n      const s = JSON.stringify(sets[i])\n      if (!unique[s]) {\n        unique[s] = true\n        uniqueSets.push(sets[i])\n      }\n    }\n    return uniqueSets\n  }\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  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\n    //    console.log('Entering _ruleMatch(', rule.toString({parenthesis:'all'}), ', ', node.toString({parenthesis:'all'}), ', ', context, ')')\n    let res = [{ placeholders: {} }]\n\n    if ((rule instanceof OperatorNode && node instanceof OperatorNode) ||\n      (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      }\n\n      // rule and node match. Search the children of rule and node.\n      if ((node.args.length === 1 && rule.args.length === 1) ||\n          (!isAssociative(node, context) &&\n           node.args.length === rule.args.length) ||\n          isSplit) {\n        // Expect non-associative operators to match exactly,\n        // except in any order if operator is commutative\n        let childMatches = []\n        for (let i = 0; i < rule.args.length; i++) {\n          const childMatch = _ruleMatch(rule.args[i], node.args[i], context)\n          if (childMatch.length === 0) {\n            // Child did not match, so stop searching immediately\n            break\n          }\n          // The child matched, so add the information returned from the child to our result\n          childMatches.push(childMatch)\n        }\n        if (childMatches.length !== rule.args.length) {\n          if (!isCommutative(node, context) || // exact match in order needed\n              rule.args.length === 1) { // nothing to commute\n            return []\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          const leftMatch = _ruleMatch(rule.args[0], node.args[1], context)\n          if (leftMatch.length === 0) {\n            return []\n          }\n          const rightMatch = _ruleMatch(rule.args[1], node.args[0], context)\n          if (rightMatch.length === 0) {\n            return []\n          }\n          childMatches = [leftMatch, rightMatch]\n        }\n        res = mergeChildMatches(childMatches)\n      } else if (node.args.length >= 2 && rule.args.length === 2) { // node is flattened, rule is not\n        // Associative operators/functions can be split in different ways so we check if the rule\n        // matches for each of them and return their union.\n        const splits = getSplits(node, context)\n        let splitMatches = []\n        for (let i = 0; i < splits.length; i++) {\n          const matchSet = _ruleMatch(rule, splits[i], context, true) // recursing at the same tree depth here\n          splitMatches = splitMatches.concat(matchSet)\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 one or two characters of the symbol node name.\n      // These meanings are expalined in the documentation for simplify()\n      if (rule.name.length === 0) {\n        throw new Error('Symbol in rule has 0 length...!?')\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 {\n        // wildcards are composed of up to two alphabetic or underscore characters\n        switch (rule.name[1] >= 'a' && rule.name[1] <= 'z' ? rule.name.substring(0, 2) : rule.name[0]) {\n          case 'n':\n          case '_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            break\n          case 'c':\n          case 'cl':\n            // rule matches a ConstantNode\n            if (isConstantNode(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 'v':\n            // rule matches anything other than a ConstantNode\n            if (!isConstantNode(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 'vl':\n            // rule matches VariableNode\n            if (isVariableNode(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 'cd':\n            // rule matches a ConstantNode or unaryMinus-wrapped ConstantNode\n            if (isNumericNode(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 'vd':\n            // rule matches anything other than a ConstantNode or unaryMinus-wrapped ConstantNode\n            if (!isNumericNode(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 'ce':\n            // rule matches expressions that have a constant value\n            if (isConstantExpression(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          case 've':\n            // rule matches expressions that do not have a constant value\n            if (!isConstantExpression(node)) {\n              res[0].placeholders[rule.name] = node\n            } else {\n              // mis-match: rule does not encompass current node\n              return []\n            }\n            break\n          default:\n            throw new Error('Invalid symbol in rule: ' + rule.name)\n        }\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    }\n\n    // It's a match!\n\n    // console.log('_ruleMatch(' + rule.toString() + ', ' + node.toString() + ') found a match')\n    return res\n  }\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  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) ||\n        (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 (let 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})\n","import { isFraction, isMatrix, isNode, isArrayNode, isConstantNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\nimport { createUtil } from './simplify/util.js'\nimport { noBignumber, noFraction } from '../../utils/noop.js'\n\nconst name = 'simplifyConstant'\nconst dependencies = [\n  'typed',\n  'config',\n  'mathWithTransform',\n  'matrix',\n  '?fraction',\n  '?bignumber',\n  'AccessorNode',\n  'ArrayNode',\n  'ConstantNode',\n  'FunctionNode',\n  'IndexNode',\n  'ObjectNode',\n  'OperatorNode',\n  'SymbolNode'\n]\n\nexport const createSimplifyConstant = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  config,\n  mathWithTransform,\n  matrix,\n  fraction,\n  bignumber,\n  AccessorNode,\n  ArrayNode,\n  ConstantNode,\n  FunctionNode,\n  IndexNode,\n  ObjectNode,\n  OperatorNode,\n  SymbolNode\n}) => {\n  const { isCommutative, isAssociative, allChildren, createMakeNodeFunction } =\n    createUtil({ FunctionNode, OperatorNode, SymbolNode })\n\n  /**\n   * simplifyConstant() takes a mathjs expression (either a Node representing\n   * a parse tree or a string which it parses to produce a node), and replaces\n   * any subexpression of it consisting entirely of constants with the computed\n   * value of that subexpression.\n   *\n   * Syntax:\n   *\n   *     math.simplifyConstant(expr)\n   *     math.simplifyConstant(expr, options)\n   *\n   * Examples:\n   *\n   *     math.simplifyConstant('x + 4*3/6')  // Node \"x + 2\"\n   *     math.simplifyConstant('z cos(0)')   // Node \"z 1\"\n   *     math.simplifyConstant('(5.2 + 1.08)t', {exactFractions: false})  // Node \"6.28 t\"\n   *\n   * See also:\n   *\n   *     simplify, simplifyCore, resolve, derivative\n   *\n   * @param {Node | string} node\n   *     The expression to be simplified\n   * @param {Object} options\n   *     Simplification options, as per simplify()\n   * @return {Node} Returns expression with constant subexpressions evaluated\n   */\n  const simplifyConstant = typed('simplifyConstant', {\n    Node: node => _ensureNode(foldFraction(node, {})),\n\n    'Node, Object': function (expr, options) {\n      return _ensureNode(foldFraction(expr, options))\n    }\n  })\n\n  function _removeFractions (thing) {\n    if (isFraction(thing)) {\n      return thing.valueOf()\n    }\n    if (thing instanceof Array) {\n      return thing.map(_removeFractions)\n    }\n    if (isMatrix(thing)) {\n      return matrix(_removeFractions(thing.valueOf()))\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  const _toNode = typed({\n    Fraction: _fractionToNode,\n    number: function (n) {\n      if (n < 0) {\n        return unaryMinusNode(new ConstantNode(-n))\n      }\n      return new ConstantNode(n)\n    },\n    BigNumber: function (n) {\n      if (n < 0) {\n        return unaryMinusNode(new ConstantNode(-n))\n      }\n      return new ConstantNode(n) // old parameters: (n.toString(), 'number')\n    },\n    bigint: function (n) {\n      if (n < 0n) {\n        return unaryMinusNode(new ConstantNode(-n))\n      }\n      return new ConstantNode(n)\n    },\n    Complex: function (s) {\n      throw new Error('Cannot convert Complex number to Node')\n    },\n    string: function (s) {\n      return new ConstantNode(s)\n    },\n    Matrix: function (m) {\n      return new ArrayNode(m.valueOf().map(e => _toNode(e)))\n    }\n  })\n\n  function _ensureNode (thing) {\n    if (isNode(thing)) {\n      return thing\n    }\n    return _toNode(thing)\n  }\n\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  function _exactFraction (n, options) {\n    const exactFractions = (options && options.exactFractions !== false)\n    if (exactFractions && isFinite(n) && fraction) {\n      const f = fraction(n)\n      const fractionsLimit = (options && typeof options.fractionsLimit === 'number')\n        ? options.fractionsLimit\n        : Infinity // no limit by default\n\n      if (f.valueOf() === n && f.n < fractionsLimit && f.d < fractionsLimit) {\n        return f\n      }\n    }\n    return n\n  }\n\n  // Convert numbers to a preferred number type in preference order: Fraction, number, Complex\n  // BigNumbers are left alone\n  const _toNumber = typed({\n    'string, Object': function (s, options) {\n      const numericType = safeNumberType(s, config)\n\n      if (numericType === 'BigNumber') {\n        if (bignumber === undefined) {\n          noBignumber()\n        }\n        return bignumber(s)\n      } else if (numericType === 'bigint') {\n        return BigInt(s)\n      } else if (numericType === 'Fraction') {\n        if (fraction === undefined) {\n          noFraction()\n        }\n        return fraction(s)\n      } else {\n        const n = parseFloat(s)\n        return _exactFraction(n, options)\n      }\n    },\n\n    'Fraction, Object': function (s, options) { return s }, // we don't need options here\n\n    'BigNumber, Object': function (s, options) { return s }, // we don't need options here\n\n    'number, Object': function (s, options) {\n      return _exactFraction(s, options)\n    },\n\n    'bigint, Object': function (s, options) {\n      return s\n    },\n\n    'Complex, Object': function (s, options) {\n      if (s.im !== 0) {\n        return s\n      }\n      return _exactFraction(s.re, options)\n    },\n\n    'Matrix, Object': function (s, options) {\n      return matrix(_exactFraction(s.valueOf()))\n    },\n\n    'Array, Object': function (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    let n\n    const vn = f.s * f.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    return new OperatorNode('/', 'divide', [n, new ConstantNode(f.d)])\n  }\n\n  /* Handles constant indexing of ArrayNodes, matrices, and ObjectNodes */\n  function _foldAccessor (obj, index, options) {\n    if (!isIndexNode(index)) { // don't know what to do with that...\n      return new AccessorNode(_ensureNode(obj), _ensureNode(index))\n    }\n    if (isArrayNode(obj) || isMatrix(obj)) {\n      const 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      while (remainingDims.length > 0) {\n        if (isConstantNode(remainingDims[0]) &&\n            typeof remainingDims[0].value !== 'string') {\n          const first = _toNumber(remainingDims.shift().value, options)\n          if (isArrayNode(obj)) {\n            obj = obj.items[first - 1]\n          } else { // matrix\n            obj = obj.valueOf()[first - 1]\n            if (obj instanceof Array) {\n              obj = matrix(obj)\n            }\n          }\n        } else if (remainingDims.length > 1 &&\n                   isConstantNode(remainingDims[1]) &&\n                   typeof remainingDims[1].value !== 'string') {\n          const second = _toNumber(remainingDims[1].value, options)\n          const tryItems = []\n          const fromItems = isArrayNode(obj) ? obj.items : obj.valueOf()\n          for (const item of fromItems) {\n            if (isArrayNode(item)) {\n              tryItems.push(item.items[second - 1])\n            } else if (isMatrix(obj)) {\n              tryItems.push(item[second - 1])\n            } else {\n              break\n            }\n          }\n          if (tryItems.length === fromItems.length) {\n            if (isArrayNode(obj)) {\n              obj = new ArrayNode(tryItems)\n            } else { // matrix\n              obj = matrix(tryItems)\n            }\n            remainingDims.splice(1, 1)\n          } else { // extracting slice along 2nd dimension failed, give up\n            break\n          }\n        } else { // neither 1st or 2nd dimension is constant, give up\n          break\n        }\n      }\n      if (remainingDims.length === index.dimensions.length) {\n        /* No successful constant indexing */\n        return new AccessorNode(_ensureNode(obj), index)\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      return obj\n    }\n    if (isObjectNode(obj) &&\n        index.dimensions.length === 1 &&\n        isConstantNode(index.dimensions[0])) {\n      const key = index.dimensions[0].value\n      if (key in obj.properties) {\n        return obj.properties[key]\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    return new AccessorNode(_ensureNode(obj), index)\n  }\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  function foldOp (fn, args, makeNode, options) {\n    const first = args.shift()\n\n    // In the following reduction, sofar always has one of the three following\n    // forms: [NODE], [CONSTANT], or [NODE, CONSTANT]\n    const reduction = args.reduce((sofar, next) => {\n      if (!isNode(next)) {\n        const last = sofar.pop()\n\n        if (isNode(last)) {\n          return [last, next]\n        }\n        // Two constants in a row, try to fold them into one\n        try {\n          sofar.push(_eval(fn, [last, next], options))\n          return sofar\n        } catch (ignoreandcontinue) {\n          sofar.push(last)\n          // fall through to Node case\n        }\n      }\n\n      // Encountered a Node, or failed folding --\n      // collapse everything so far into a single tree:\n      sofar.push(_ensureNode(sofar.pop()))\n      const newtree = (sofar.length === 1) ? sofar[0] : makeNode(sofar)\n      return [makeNode([newtree, _ensureNode(next)])]\n    }, [first])\n\n    if (reduction.length === 1) {\n      return reduction[0]\n    }\n    // Might end up with a tree and a constant at the end:\n    return makeNode([reduction[0], _toNode(reduction[1])])\n  }\n\n  // destroys the original node and returns a folded one\n  function foldFraction (node, options) {\n    switch (node.type) {\n      case 'SymbolNode':\n        return node\n      case 'ConstantNode':\n        switch (typeof node.value) {\n          case 'number': return _toNumber(node.value, options)\n          case 'bigint': return _toNumber(node.value, options)\n          case 'string': return node.value\n          default:\n            if (!isNaN(node.value)) return _toNumber(node.value, options)\n        }\n        return node\n      case 'FunctionNode':\n        if (mathWithTransform[node.name] && mathWithTransform[node.name].rawArgs) {\n          return node\n        }\n        {\n          // Process operators as OperatorNode\n          const operatorFunctions = ['add', 'multiply']\n          if (!operatorFunctions.includes(node.name)) {\n            const args = node.args.map(arg => foldFraction(arg, options))\n\n            // If all args are numbers\n            if (!args.some(isNode)) {\n              try {\n                return _eval(node.name, args, options)\n              } catch (ignoreandcontinue) { }\n            }\n\n            // Size of a matrix does not depend on entries\n            if (node.name === 'size' &&\n                args.length === 1 &&\n                isArrayNode(args[0])) {\n              const sz = []\n              let section = args[0]\n              while (isArrayNode(section)) {\n                sz.push(section.items.length)\n                section = section.items[0]\n              }\n              return matrix(sz)\n            }\n\n            // Convert all args to nodes and construct a symbolic function call\n            return new FunctionNode(node.name, args.map(_ensureNode))\n          } else {\n            // treat as operator\n          }\n        }\n        /* falls through */\n      case 'OperatorNode':\n      {\n        const fn = node.fn.toString()\n        let args\n        let res\n        const makeNode = createMakeNodeFunction(node)\n        if (isOperatorNode(node) && node.isUnary()) {\n          args = [foldFraction(node.args[0], options)]\n          if (!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(arg => foldFraction(arg, options))\n\n          if (isCommutative(fn, options.context)) {\n            // commutative binary operator\n            const consts = []\n            const vars = []\n\n            for (let i = 0; i < args.length; i++) {\n              if (!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(arg => foldFraction(arg, options))\n          res = foldOp(fn, args, makeNode, options)\n        }\n        return res\n      }\n      case 'ParenthesisNode':\n        // remove the uneccessary parenthesis\n        return foldFraction(node.content, options)\n      case 'AccessorNode':\n        return _foldAccessor(\n          foldFraction(node.object, options),\n          foldFraction(node.index, options),\n          options)\n      case 'ArrayNode': {\n        const foldItems = node.items.map(item => foldFraction(item, options))\n        if (foldItems.some(isNode)) {\n          return new ArrayNode(foldItems.map(_ensureNode))\n        }\n        /* All literals -- return a Matrix so we can operate on it */\n        return matrix(foldItems)\n      }\n      case 'IndexNode': {\n        return new IndexNode(\n          node.dimensions.map(n => simplifyConstant(n, options)))\n      }\n      case 'ObjectNode': {\n        const foldProps = {}\n        for (const prop in node.properties) {\n          foldProps[prop] = simplifyConstant(node.properties[prop], options)\n        }\n        return new ObjectNode(foldProps)\n      }\n      case 'AssignmentNode':\n        /* falls through */\n      case 'BlockNode':\n        /* falls through */\n      case 'FunctionAssignmentNode':\n        /* falls through */\n      case 'RangeNode':\n        /* falls through */\n      case 'ConditionalNode':\n        /* falls through */\n      default:\n        throw new Error(`Unimplemented node type in simplifyConstant: ${node.type}`)\n    }\n  }\n\n  return simplifyConstant\n})\n","import { isAccessorNode, isArrayNode, isConstantNode, isFunctionNode, isIndexNode, isObjectNode, isOperatorNode } from '../../utils/is.js'\nimport { getOperator } from '../../expression/operators.js'\nimport { createUtil } from './simplify/util.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'simplifyCore'\nconst dependencies = [\n  'typed',\n  'parse',\n  'equal',\n  'isZero',\n  'add',\n  'subtract',\n  'multiply',\n  'divide',\n  'pow',\n  'AccessorNode',\n  'ArrayNode',\n  'ConstantNode',\n  'FunctionNode',\n  'IndexNode',\n  'ObjectNode',\n  'OperatorNode',\n  'ParenthesisNode',\n  'SymbolNode'\n]\n\nexport const createSimplifyCore = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  parse,\n  equal,\n  isZero,\n  add,\n  subtract,\n  multiply,\n  divide,\n  pow,\n  AccessorNode,\n  ArrayNode,\n  ConstantNode,\n  FunctionNode,\n  IndexNode,\n  ObjectNode,\n  OperatorNode,\n  ParenthesisNode,\n  SymbolNode\n}) => {\n  const node0 = new ConstantNode(0)\n  const node1 = new ConstantNode(1)\n  const nodeT = new ConstantNode(true)\n  const nodeF = new ConstantNode(false)\n  // test if a node will always have a boolean value (true/false)\n  // not sure if this list is complete\n  function isAlwaysBoolean (node) {\n    return isOperatorNode(node) && ['and', 'not', 'or'].includes(node.op)\n  }\n\n  const { hasProperty, isCommutative } =\n    createUtil({ FunctionNode, OperatorNode, SymbolNode })\n  /**\n   * simplifyCore() performs single pass simplification suitable for\n   * applications requiring ultimate performance. To roughly summarize,\n   * it handles cases along the lines of simplifyConstant() but where\n   * knowledge of a single argument is sufficient to determine the value.\n   * In contrast, simplify() extends simplifyCore() with additional passes\n   * to provide deeper simplification (such as gathering like terms).\n   *\n   * Specifically, simplifyCore:\n   *\n   * * Converts all function calls with operator equivalents to their\n   *   operator forms.\n   * * Removes operators or function calls that are guaranteed to have no\n   *   effect (such as unary '+').\n   * * Removes double unary '-', '~', and 'not'\n   * * Eliminates addition/subtraction of 0 and multiplication/division/powers\n   *   by 1 or 0.\n   * * Converts addition of a negation into subtraction.\n   * * Eliminates logical operations with constant true or false leading\n   *   arguments.\n   * * Puts constants on the left of a product, if multiplication is\n   *   considered commutative by the options (which is the default)\n   *\n   * Syntax:\n   *\n   *     math.simplifyCore(expr)\n   *     math.simplifyCore(expr, options)\n   *\n   * Examples:\n   *\n   *     const f = math.parse('2 * 1 * x ^ (1 - 0)')\n   *     math.simplifyCore(f)                          // Node \"2 * x\"\n   *     math.simplify('2 * 1 * x ^ (1 - 0)', [math.simplifyCore]) // Node \"2 * x\"\n   *\n   * See also:\n   *\n   *     simplify, simplifyConstant, resolve, derivative\n   *\n   * @param {Node | string} 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  function _simplifyCore (nodeToSimplify, options = {}) {\n    const context = options ? options.context : undefined\n    if (hasProperty(nodeToSimplify, 'trivial', context)) {\n      // This node does nothing if it has only one argument, so if so,\n      // return that argument simplified\n      if (isFunctionNode(nodeToSimplify) && nodeToSimplify.args.length === 1) {\n        return _simplifyCore(nodeToSimplify.args[0], options)\n      }\n      // For other node types, we try the generic methods\n      let simpChild = false\n      let childCount = 0\n      nodeToSimplify.forEach(c => {\n        ++childCount\n        if (childCount === 1) {\n          simpChild = _simplifyCore(c, options)\n        }\n      })\n      if (childCount === 1) {\n        return simpChild\n      }\n    }\n    let node = nodeToSimplify\n    if (isFunctionNode(node)) {\n      const op = getOperator(node.name)\n      if (op) {\n        // Replace FunctionNode with a new OperatorNode\n        if (node.args.length > 2 && hasProperty(node, 'associative', context)) {\n          // unflatten into binary operations since that's what simplifyCore handles\n          while (node.args.length > 2) {\n            const last = node.args.pop()\n            const seclast = node.args.pop()\n            node.args.push(new OperatorNode(op, node.name, [last, seclast]))\n          }\n        }\n        node = new OperatorNode(op, node.name, node.args)\n      } else {\n        return new FunctionNode(\n          _simplifyCore(node.fn), node.args.map(n => _simplifyCore(n, options)))\n      }\n    }\n    if (isOperatorNode(node) && node.isUnary()) {\n      const a0 = _simplifyCore(node.args[0], options)\n\n      if (node.op === '~') { // bitwise not\n        if (isOperatorNode(a0) && a0.isUnary() && a0.op === '~') {\n          return a0.args[0]\n        }\n      }\n      if (node.op === 'not') { // logical not\n        if (isOperatorNode(a0) && a0.isUnary() && a0.op === 'not') {\n          // Has the effect of turning the argument into a boolean\n          // So can only eliminate the double negation if\n          // the inside is already boolean\n          if (isAlwaysBoolean(a0.args[0])) {\n            return a0.args[0]\n          }\n        }\n      }\n      let finish = true\n      if (node.op === '-') { // unary minus\n        if (isOperatorNode(a0)) {\n          if (a0.isBinary() && a0.fn === 'subtract') {\n            node = new OperatorNode('-', 'subtract', [a0.args[1], a0.args[0]])\n            finish = false // continue to process the new binary node\n          }\n          if (a0.isUnary() && a0.op === '-') {\n            return a0.args[0]\n          }\n        }\n      }\n      if (finish) return new OperatorNode(node.op, node.fn, [a0])\n    }\n    if (isOperatorNode(node) && node.isBinary()) {\n      const a0 = _simplifyCore(node.args[0], options)\n      let a1 = _simplifyCore(node.args[1], options)\n\n      if (node.op === '+') {\n        if (isConstantNode(a0) && isZero(a0.value)) {\n          return a1\n        }\n        if (isConstantNode(a1) && isZero(a1.value)) {\n          return a0\n        }\n        if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') {\n          a1 = a1.args[0]\n          node = new OperatorNode('-', 'subtract', [a0, a1])\n        }\n      }\n      if (node.op === '-') {\n        if (isOperatorNode(a1) && a1.isUnary() && a1.op === '-') {\n          return _simplifyCore(\n            new OperatorNode('+', 'add', [a0, a1.args[0]]), options)\n        }\n        if (isConstantNode(a0) && isZero(a0.value)) {\n          return _simplifyCore(new OperatorNode('-', 'unaryMinus', [a1]))\n        }\n        if (isConstantNode(a1) && isZero(a1.value)) {\n          return a0\n        }\n        return new OperatorNode(node.op, node.fn, [a0, a1])\n      }\n      if (node.op === '*') {\n        if (isConstantNode(a0)) {\n          if (isZero(a0.value)) {\n            return node0\n          } else if (equal(a0.value, 1)) {\n            return a1\n          }\n        }\n        if (isConstantNode(a1)) {\n          if (isZero(a1.value)) {\n            return node0\n          } else if (equal(a1.value, 1)) {\n            return a0\n          }\n          if (isCommutative(node, context)) {\n            return new OperatorNode(node.op, node.fn, [a1, a0], node.implicit) // constants on left\n          }\n        }\n        return new OperatorNode(node.op, node.fn, [a0, a1], node.implicit)\n      }\n      if (node.op === '/') {\n        if (isConstantNode(a0) && isZero(a0.value)) {\n          return node0\n        }\n        if (isConstantNode(a1) && equal(a1.value, 1)) {\n          return a0\n        }\n        return new OperatorNode(node.op, node.fn, [a0, a1])\n      }\n      if (node.op === '^') {\n        if (isConstantNode(a1)) {\n          if (isZero(a1.value)) {\n            return node1\n          } else if (equal(a1.value, 1)) {\n            return a0\n          }\n        }\n      }\n      if (node.op === 'and') {\n        if (isConstantNode(a0)) {\n          if (a0.value) {\n            if (isAlwaysBoolean(a1)) return a1\n            if (isConstantNode(a1)) {\n              return a1.value ? nodeT : nodeF\n            }\n          } else {\n            return nodeF\n          }\n        }\n        if (isConstantNode(a1)) {\n          if (a1.value) {\n            if (isAlwaysBoolean(a0)) return a0\n          } else {\n            return nodeF\n          }\n        }\n      }\n      if (node.op === 'or') {\n        if (isConstantNode(a0)) {\n          if (a0.value) {\n            return nodeT\n          } else {\n            if (isAlwaysBoolean(a1)) return a1\n          }\n        }\n        if (isConstantNode(a1)) {\n          if (a1.value) {\n            return nodeT\n          } else {\n            if (isAlwaysBoolean(a0)) return a0\n          }\n        }\n      }\n      return new OperatorNode(node.op, node.fn, [a0, a1])\n    }\n    if (isOperatorNode(node)) {\n      return new OperatorNode(\n        node.op, node.fn, node.args.map(a => _simplifyCore(a, options)))\n    }\n    if (isArrayNode(node)) {\n      return new ArrayNode(node.items.map(n => _simplifyCore(n, options)))\n    }\n    if (isAccessorNode(node)) {\n      return new AccessorNode(\n        _simplifyCore(node.object, options), _simplifyCore(node.index, options))\n    }\n    if (isIndexNode(node)) {\n      return new IndexNode(\n        node.dimensions.map(n => _simplifyCore(n, options)))\n    }\n    if (isObjectNode(node)) {\n      const newProps = {}\n      for (const prop in node.properties) {\n        newProps[prop] = _simplifyCore(node.properties[prop], options)\n      }\n      return new ObjectNode(newProps)\n    }\n    // cannot simplify\n    return node\n  }\n\n  return typed(name, { Node: _simplifyCore, 'Node,Object': _simplifyCore })\n})\n","import { createMap } from '../../utils/map.js'\nimport { isFunctionNode, isNode, isOperatorNode, isParenthesisNode, isSymbolNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'resolve'\nconst dependencies = [\n  'typed',\n  'parse',\n  'ConstantNode',\n  'FunctionNode',\n  'OperatorNode',\n  'ParenthesisNode'\n]\n\nexport const createResolve = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  parse,\n  ConstantNode,\n  FunctionNode,\n  OperatorNode,\n  ParenthesisNode\n}) => {\n  /**\n   * resolve(expr, scope) replaces variable nodes with their scoped values\n   *\n   * Syntax:\n   *\n   *     math.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: math.parse('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, within = new Set()) { // note `within`:\n    // `within` is not documented, since it is for internal cycle\n    // detection only\n    if (!scope) {\n      return node\n    }\n    if (isSymbolNode(node)) {\n      if (within.has(node.name)) {\n        const variables = Array.from(within).join(', ')\n        throw new ReferenceError(\n          `recursive loop of variable definitions among {${variables}}`\n        )\n      }\n      const value = scope.get(node.name)\n      if (isNode(value)) {\n        const 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 (isOperatorNode(node)) {\n      const 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 (isParenthesisNode(node)) {\n      return new ParenthesisNode(_resolve(node.content, scope, within))\n    } else if (isFunctionNode(node)) {\n      const args = node.args.map(function (arg) {\n        return _resolve(arg, scope, within)\n      })\n      return new FunctionNode(node.name, args)\n    }\n\n    // Otherwise just recursively resolve any children (might also work\n    // for some of the above special cases)\n    return node.map(child => _resolve(child, scope, within))\n  }\n\n  return typed('resolve', {\n    Node: _resolve,\n    'Node, Map | null | undefined': _resolve,\n    'Node, Object': (n, scope) => _resolve(n, createMap(scope)),\n    // For arrays and matrices, we map `self` rather than `_resolve`\n    // because resolve is fairly expensive anyway, and this way\n    // we get nice error messages if one entry in the array has wrong type.\n    'Array | Matrix': typed.referToSelf(self => A => A.map(n => self(n))),\n    'Array | Matrix, null | undefined': typed.referToSelf(\n      self => A => A.map(n => self(n))),\n    'Array, Object': typed.referTo(\n      'Array,Map', selfAM => (A, scope) => selfAM(A, createMap(scope))),\n    'Matrix, Object': typed.referTo(\n      'Matrix,Map', selfMM => (A, scope) => selfMM(A, createMap(scope))),\n    'Array | Matrix, Map': typed.referToSelf(\n      self => (A, scope) => A.map(n => self(n, scope)))\n  })\n})\n","import { isConstantNode } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'symbolicEqual'\nconst dependencies = [\n  'parse',\n  'simplify',\n  'typed',\n  'OperatorNode'\n]\n\nexport const createSymbolicEqual = /* #__PURE__ */ factory(name, dependencies, ({\n  parse,\n  simplify,\n  typed,\n  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   *     math.symbolicEqual(expr1, expr2)\n   *     math.symbolicEqual(expr1, expr2, options)\n   *\n   * Examples:\n   *\n   *     math.symbolicEqual('x*y', 'y*x') // Returns true\n   *     math.symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}}) // Returns false\n   *     math.symbolicEqual('x/y', '(y*x^(-1))^(-1)') // Returns true\n   *     math.symbolicEqual('abs(x)','x') // Returns false\n   *     math.symbolicEqual('abs(x)','x', simplify.positiveContext) // Returns 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  function _symbolicEqual (e1, e2, options = {}) {\n    const diff = new OperatorNode('-', 'subtract', [e1, e2])\n    const simplified = simplify(diff, {}, options)\n    return (isConstantNode(simplified) && !(simplified.value))\n  }\n\n  return typed(name, {\n    'Node, Node': _symbolicEqual,\n    'Node, Node, Object': _symbolicEqual\n  })\n})\n","import { isConstantNode, typeOf } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { safeNumberType } from '../../utils/number.js'\n\nconst name = 'derivative'\nconst dependencies = [\n  'typed',\n  'config',\n  'parse',\n  'simplify',\n  'equal',\n  'isZero',\n  'numeric',\n  'ConstantNode',\n  'FunctionNode',\n  'OperatorNode',\n  'ParenthesisNode',\n  'SymbolNode'\n]\n\nexport const createDerivative = /* #__PURE__ */ factory(name, dependencies, ({\n  typed,\n  config,\n  parse,\n  simplify,\n  equal,\n  isZero,\n  numeric,\n  ConstantNode,\n  FunctionNode,\n  OperatorNode,\n  ParenthesisNode,\n  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   *     math.derivative(expr, variable)\n   *     math.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  function plainDerivative (expr, variable, options = { simplify: true }) {\n    const constNodes = {}\n    constTag(constNodes, expr, variable.name)\n    const res = _derivative(expr, constNodes)\n    return options.simplify ? simplify(res) : res\n  }\n\n  typed.addConversion(\n    { from: 'identifier', to: 'SymbolNode', convert: parse })\n\n  const derivative = typed(name, {\n    'Node, SymbolNode': plainDerivative,\n    'Node, SymbolNode, Object': plainDerivative\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  typed.removeConversion(\n    { from: 'identifier', to: 'SymbolNode', convert: parse })\n\n  derivative._simplify = true\n\n  derivative.toTex = function (deriv) {\n    return _derivTex.apply(null, deriv.args)\n  }\n\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  const _derivTex = typed('_derivTex', {\n    'Node, SymbolNode': function (expr, x) {\n      if (isConstantNode(expr) && 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 (expr, x) {\n      if (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 (expr, x, order) {\n      return _derivTex(expr.toString(), x.name, order.value)\n    },\n    'string, string, number': function (expr, x, order) {\n      let d\n      if (order === 1) {\n        d = '{d\\\\over d' + x + '}'\n      } else {\n        d = '{d^{' + order + '}\\\\over d' + x + '^{' + order + '}}'\n      }\n      return d + `\\\\left[${expr}\\\\right]`\n    }\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  const constTag = typed('constTag', {\n    'Object, ConstantNode, string': function (constNodes, node) {\n      constNodes[node] = true\n      return true\n    },\n\n    'Object, SymbolNode, string': function (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      return false\n    },\n\n    'Object, ParenthesisNode, string': function (constNodes, node, varName) {\n      return constTag(constNodes, node.content, varName)\n    },\n\n    'Object, FunctionAssignmentNode, string': function (constNodes, node, varName) {\n      if (!node.params.includes(varName)) {\n        constNodes[node] = true\n        return true\n      }\n      return constTag(constNodes, node.expr, varName)\n    },\n\n    'Object, FunctionNode | OperatorNode, string': function (constNodes, node, varName) {\n      if (node.args.length > 0) {\n        let isConst = constTag(constNodes, node.args[0], varName)\n        for (let 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      return false\n    }\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  const _derivative = typed('_derivative', {\n    'ConstantNode, Object': function (node) {\n      return createConstantNode(0)\n    },\n\n    'SymbolNode, Object': function (node, constNodes) {\n      if (constNodes[node] !== undefined) {\n        return createConstantNode(0)\n      }\n      return createConstantNode(1)\n    },\n\n    'ParenthesisNode, Object': function (node, constNodes) {\n      return new ParenthesisNode(_derivative(node.content, constNodes))\n    },\n\n    'FunctionAssignmentNode, Object': function (node, constNodes) {\n      if (constNodes[node] !== undefined) {\n        return createConstantNode(0)\n      }\n      return _derivative(node.expr, constNodes)\n    },\n\n    'FunctionNode, Object': function (node, constNodes) {\n      if (constNodes[node] !== undefined) {\n        return createConstantNode(0)\n      }\n\n      const arg0 = node.args[0]\n      let arg1\n\n      let div = false // is output a fraction?\n      let negative = false // is output negative?\n\n      let funcDerivative\n      switch (node.name) {\n        case 'cbrt':\n          // d/dx(cbrt(x)) = 1 / (3x^(2/3))\n          div = true\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            createConstantNode(3),\n            new OperatorNode('^', 'pow', [\n              arg0,\n              new OperatorNode('/', 'divide', [\n                createConstantNode(2),\n                createConstantNode(3)\n              ])\n            ])\n          ])\n          break\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', [\n              createConstantNode(2),\n              new FunctionNode('sqrt', [arg0])\n            ])\n          } else if (node.args.length === 2) {\n            // Rearrange from nthRoot(x, a) -> x^(1/a)\n            arg1 = new OperatorNode('/', 'divide', [\n              createConstantNode(1),\n              node.args[1]\n            ])\n\n            // Is a variable?\n            constNodes[arg1] = constNodes[node.args[1]]\n\n            return _derivative(new OperatorNode('^', 'pow', [arg0, arg1]), constNodes)\n          }\n          break\n        case 'log10':\n          arg1 = createConstantNode(10)\n          /* fall through! */\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) ||\n              (node.args.length === 2 && constNodes[node.args[1]] !== undefined)) {\n            // d/dx(log(x, c)) = 1 / (x*ln(c))\n            funcDerivative = new OperatorNode('*', 'multiply', [\n              arg0.clone(),\n              new FunctionNode('log', [arg1 || node.args[1]])\n            ])\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', [\n              new FunctionNode('log', [arg0]),\n              new FunctionNode('log', [node.args[1]])\n            ]), constNodes)\n          }\n          break\n        case 'pow':\n          if (node.args.length === 2) {\n            constNodes[arg1] = constNodes[node.args[1]]\n            // Pass to pow operator node parser\n            return _derivative(new OperatorNode('^', 'pow', [arg0, node.args[1]]), constNodes)\n          }\n          break\n        case 'exp':\n          // d/dx(e^x) = e^x\n          funcDerivative = new FunctionNode('exp', [arg0.clone()])\n          break\n        case 'sin':\n          // d/dx(sin(x)) = cos(x)\n          funcDerivative = new FunctionNode('cos', [arg0.clone()])\n          break\n        case 'cos':\n          // d/dx(cos(x)) = -sin(x)\n          funcDerivative = new OperatorNode('-', 'unaryMinus', [\n            new FunctionNode('sin', [arg0.clone()])\n          ])\n          break\n        case 'tan':\n          // d/dx(tan(x)) = sec(x)^2\n          funcDerivative = new OperatorNode('^', 'pow', [\n            new FunctionNode('sec', [arg0.clone()]),\n            createConstantNode(2)\n          ])\n          break\n        case 'sec':\n          // d/dx(sec(x)) = sec(x)tan(x)\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            node,\n            new FunctionNode('tan', [arg0.clone()])\n          ])\n          break\n        case 'csc':\n          // d/dx(csc(x)) = -csc(x)cot(x)\n          negative = true\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            node,\n            new FunctionNode('cot', [arg0.clone()])\n          ])\n          break\n        case 'cot':\n          // d/dx(cot(x)) = -csc(x)^2\n          negative = true\n          funcDerivative = new OperatorNode('^', 'pow', [\n            new FunctionNode('csc', [arg0.clone()]),\n            createConstantNode(2)\n          ])\n          break\n        case 'asin':\n          // d/dx(asin(x)) = 1 / sqrt(1 - x^2)\n          div = true\n          funcDerivative = new FunctionNode('sqrt', [\n            new OperatorNode('-', 'subtract', [\n              createConstantNode(1),\n              new OperatorNode('^', 'pow', [\n                arg0.clone(),\n                createConstantNode(2)\n              ])\n            ])\n          ])\n          break\n        case 'acos':\n          // d/dx(acos(x)) = -1 / sqrt(1 - x^2)\n          div = true\n          negative = true\n          funcDerivative = new FunctionNode('sqrt', [\n            new OperatorNode('-', 'subtract', [\n              createConstantNode(1),\n              new OperatorNode('^', 'pow', [\n                arg0.clone(),\n                createConstantNode(2)\n              ])\n            ])\n          ])\n          break\n        case 'atan':\n          // d/dx(atan(x)) = 1 / (x^2 + 1)\n          div = true\n          funcDerivative = new OperatorNode('+', 'add', [\n            new OperatorNode('^', 'pow', [\n              arg0.clone(),\n              createConstantNode(2)\n            ]),\n            createConstantNode(1)\n          ])\n          break\n        case 'asec':\n          // d/dx(asec(x)) = 1 / (|x|*sqrt(x^2 - 1))\n          div = true\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            new FunctionNode('abs', [arg0.clone()]),\n            new FunctionNode('sqrt', [\n              new OperatorNode('-', 'subtract', [\n                new OperatorNode('^', 'pow', [\n                  arg0.clone(),\n                  createConstantNode(2)\n                ]),\n                createConstantNode(1)\n              ])\n            ])\n          ])\n          break\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', [\n            new FunctionNode('abs', [arg0.clone()]),\n            new FunctionNode('sqrt', [\n              new OperatorNode('-', 'subtract', [\n                new OperatorNode('^', 'pow', [\n                  arg0.clone(),\n                  createConstantNode(2)\n                ]),\n                createConstantNode(1)\n              ])\n            ])\n          ])\n          break\n        case 'acot':\n          // d/dx(acot(x)) = -1 / (x^2 + 1)\n          div = true\n          negative = true\n          funcDerivative = new OperatorNode('+', 'add', [\n            new OperatorNode('^', 'pow', [\n              arg0.clone(),\n              createConstantNode(2)\n            ]),\n            createConstantNode(1)\n          ])\n          break\n        case 'sinh':\n          // d/dx(sinh(x)) = cosh(x)\n          funcDerivative = new FunctionNode('cosh', [arg0.clone()])\n          break\n        case 'cosh':\n          // d/dx(cosh(x)) = sinh(x)\n          funcDerivative = new FunctionNode('sinh', [arg0.clone()])\n          break\n        case 'tanh':\n          // d/dx(tanh(x)) = sech(x)^2\n          funcDerivative = new OperatorNode('^', 'pow', [\n            new FunctionNode('sech', [arg0.clone()]),\n            createConstantNode(2)\n          ])\n          break\n        case 'sech':\n          // d/dx(sech(x)) = -sech(x)tanh(x)\n          negative = true\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            node,\n            new FunctionNode('tanh', [arg0.clone()])\n          ])\n          break\n        case 'csch':\n          // d/dx(csch(x)) = -csch(x)coth(x)\n          negative = true\n          funcDerivative = new OperatorNode('*', 'multiply', [\n            node,\n            new FunctionNode('coth', [arg0.clone()])\n          ])\n          break\n        case 'coth':\n          // d/dx(coth(x)) = -csch(x)^2\n          negative = true\n          funcDerivative = new OperatorNode('^', 'pow', [\n            new FunctionNode('csch', [arg0.clone()]),\n            createConstantNode(2)\n          ])\n          break\n        case 'asinh':\n          // d/dx(asinh(x)) = 1 / sqrt(x^2 + 1)\n          div = true\n          funcDerivative = new FunctionNode('sqrt', [\n            new OperatorNode('+', 'add', [\n              new OperatorNode('^', 'pow', [\n                arg0.clone(),\n                createConstantNode(2)\n              ]),\n              createConstantNode(1)\n            ])\n          ])\n          break\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', [\n            new OperatorNode('-', 'subtract', [\n              new OperatorNode('^', 'pow', [\n                arg0.clone(),\n                createConstantNode(2)\n              ]),\n              createConstantNode(1)\n            ])\n          ])\n          break\n        case 'atanh':\n          // d/dx(atanh(x)) = 1 / (1 - x^2)\n          div = true\n          funcDerivative = new OperatorNode('-', 'subtract', [\n            createConstantNode(1),\n            new OperatorNode('^', 'pow', [\n              arg0.clone(),\n              createConstantNode(2)\n            ])\n          ])\n          break\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', [\n            arg0.clone(),\n            new FunctionNode('sqrt', [\n              new OperatorNode('-', 'subtract', [\n                createConstantNode(1),\n                new OperatorNode('^', 'pow', [\n                  arg0.clone(),\n                  createConstantNode(2)\n                ])\n              ])\n            ])\n          ])\n          break\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', [\n            new FunctionNode('abs', [arg0.clone()]),\n            new FunctionNode('sqrt', [\n              new OperatorNode('+', 'add', [\n                new OperatorNode('^', 'pow', [\n                  arg0.clone(),\n                  createConstantNode(2)\n                ]),\n                createConstantNode(1)\n              ])\n            ])\n          ])\n          break\n        case 'acoth':\n          // d/dx(acoth(x)) = -1 / (1 - x^2)\n          div = true\n          negative = true\n          funcDerivative = new OperatorNode('-', 'subtract', [\n            createConstantNode(1),\n            new OperatorNode('^', 'pow', [\n              arg0.clone(),\n              createConstantNode(2)\n            ])\n          ])\n          break\n        case 'abs':\n          // d/dx(abs(x)) = abs(x)/x\n          funcDerivative = new OperatorNode('/', 'divide', [\n            new FunctionNode(new SymbolNode('abs'), [arg0.clone()]),\n            arg0.clone()\n          ])\n          break\n        case 'gamma': // Needs digamma function, d/dx(gamma(x)) = gamma(x)digamma(x)\n        default:\n          throw new Error('Cannot process function \"' + node.name + '\" in derivative: ' +\n          'the function is not supported, undefined, or the number of arguments passed to it are not supported')\n      }\n\n      let op, func\n      if (div) {\n        op = '/'\n        func = 'divide'\n      } else {\n        op = '*'\n        func = 'multiply'\n      }\n\n      /* Apply chain rule to all functions:\n         F(x)  = f(g(x))\n         F'(x) = g'(x)*f'(g(x)) */\n      let chainDerivative = _derivative(arg0, constNodes)\n      if (negative) {\n        chainDerivative = new OperatorNode('-', 'unaryMinus', [chainDerivative])\n      }\n      return new OperatorNode(op, func, [chainDerivative, funcDerivative])\n    },\n\n    'OperatorNode, Object': function (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, [\n            _derivative(node.args[0], constNodes)\n          ])\n        }\n\n        // Linearity of differentiation, d/dx(f(x) +/- g(x)) = f'(x) +/- g'(x)\n        if (node.isBinary()) {\n          return new OperatorNode(node.op, node.fn, [\n            _derivative(node.args[0], constNodes),\n            _derivative(node.args[1], constNodes)\n          ])\n        }\n      }\n\n      if (node.op === '*') {\n        // d/dx(c*f(x)) = c*f'(x)\n        const constantTerms = node.args.filter(function (arg) {\n          return constNodes[arg] !== undefined\n        })\n\n        if (constantTerms.length > 0) {\n          const nonConstantTerms = node.args.filter(function (arg) {\n            return constNodes[arg] === undefined\n          })\n\n          const nonConstantNode = nonConstantTerms.length === 1\n            ? nonConstantTerms[0]\n            : new OperatorNode('*', 'multiply', nonConstantTerms)\n\n          const newArgs = constantTerms.concat(_derivative(nonConstantNode, constNodes))\n\n          return new OperatorNode('*', 'multiply', newArgs)\n        }\n\n        // Product Rule, d/dx(f(x)*g(x)) = f'(x)*g(x) + f(x)*g'(x)\n        return new OperatorNode('+', 'add', node.args.map(function (argOuter) {\n          return new OperatorNode('*', 'multiply', node.args.map(function (argInner) {\n            return (argInner === argOuter)\n              ? _derivative(argInner, constNodes)\n              : argInner.clone()\n          }))\n        }))\n      }\n\n      if (node.op === '/' && node.isBinary()) {\n        const arg0 = node.args[0]\n        const arg1 = node.args[1]\n\n        // d/dx(f(x) / c) = f'(x) / c\n        if (constNodes[arg1] !== undefined) {\n          return new OperatorNode('/', 'divide', [_derivative(arg0, constNodes), arg1])\n        }\n\n        // Reciprocal Rule, d/dx(c / f(x)) = -c(f'(x)/f(x)^2)\n        if (constNodes[arg0] !== undefined) {\n          return new OperatorNode('*', 'multiply', [\n            new OperatorNode('-', 'unaryMinus', [arg0]),\n            new OperatorNode('/', 'divide', [\n              _derivative(arg1, constNodes),\n              new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])\n            ])\n          ])\n        }\n\n        // Quotient rule, d/dx(f(x) / g(x)) = (f'(x)g(x) - f(x)g'(x)) / g(x)^2\n        return new OperatorNode('/', 'divide', [\n          new OperatorNode('-', 'subtract', [\n            new OperatorNode('*', 'multiply', [_derivative(arg0, constNodes), arg1.clone()]),\n            new OperatorNode('*', 'multiply', [arg0.clone(), _derivative(arg1, constNodes)])\n          ]),\n          new OperatorNode('^', 'pow', [arg1.clone(), createConstantNode(2)])\n        ])\n      }\n\n      if (node.op === '^' && node.isBinary()) {\n        const arg0 = node.args[0]\n        const arg1 = node.args[1]\n\n        if (constNodes[arg0] !== undefined) {\n          // If is secretly constant; 0^f(x) = 1 (in JS), 1^f(x) = 1\n          if (isConstantNode(arg0) && (isZero(arg0.value) || equal(arg0.value, 1))) {\n            return createConstantNode(0)\n          }\n\n          // d/dx(c^f(x)) = c^f(x)*ln(c)*f'(x)\n          return new OperatorNode('*', 'multiply', [\n            node,\n            new OperatorNode('*', 'multiply', [\n              new FunctionNode('log', [arg0.clone()]),\n              _derivative(arg1.clone(), constNodes)\n            ])\n          ])\n        }\n\n        if (constNodes[arg1] !== undefined) {\n          if (isConstantNode(arg1)) {\n            // If is secretly constant; f(x)^0 = 1 -> d/dx(1) = 0\n            if (isZero(arg1.value)) {\n              return createConstantNode(0)\n            }\n            // Ignore exponent; f(x)^1 = f(x)\n            if (equal(arg1.value, 1)) {\n              return _derivative(arg0, constNodes)\n            }\n          }\n\n          // Elementary Power Rule, d/dx(f(x)^c) = c*f'(x)*f(x)^(c-1)\n          const powMinusOne = new OperatorNode('^', 'pow', [\n            arg0.clone(),\n            new OperatorNode('-', 'subtract', [\n              arg1,\n              createConstantNode(1)\n            ])\n          ])\n\n          return new OperatorNode('*', 'multiply', [\n            arg1.clone(),\n            new OperatorNode('*', 'multiply', [\n              _derivative(arg0, constNodes),\n              powMinusOne\n            ])\n          ])\n        }\n\n        // Functional Power Rule, d/dx(f^g) = f^g*[f'*(g/f) + g'ln(f)]\n        return new OperatorNode('*', 'multiply', [\n          new OperatorNode('^', 'pow', [arg0.clone(), arg1.clone()]),\n          new OperatorNode('+', 'add', [\n            new OperatorNode('*', 'multiply', [\n              _derivative(arg0, constNodes),\n              new OperatorNode('/', 'divide', [arg1.clone(), arg0.clone()])\n            ]),\n            new OperatorNode('*', 'multiply', [\n              _derivative(arg1, constNodes),\n              new FunctionNode('log', [arg0.clone()])\n            ])\n          ])\n        ])\n      }\n\n      throw new Error('Cannot process operator \"' + node.op + '\" in derivative: ' +\n        'the operator is not supported, undefined, or the number of arguments passed to it are not supported')\n    }\n  })\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  function createConstantNode (value, valueType) {\n    return new ConstantNode(numeric(value, valueType || safeNumberType(String(value), config)))\n  }\n\n  return derivative\n})\n","import { isInteger } from '../../utils/number.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'rationalize'\nconst dependencies = [\n  'config',\n  'typed',\n  'equal',\n  'isZero',\n  'add',\n  'subtract',\n  'multiply',\n  'divide',\n  'pow',\n  'parse',\n  'simplifyConstant',\n  'simplifyCore',\n  'simplify',\n  '?bignumber',\n  '?fraction',\n  'mathWithTransform',\n  'matrix',\n  'AccessorNode',\n  'ArrayNode',\n  'ConstantNode',\n  'FunctionNode',\n  'IndexNode',\n  'ObjectNode',\n  'OperatorNode',\n  'SymbolNode',\n  'ParenthesisNode'\n]\n\nexport const createRationalize = /* #__PURE__ */ factory(name, dependencies, ({\n  config,\n  typed,\n  equal,\n  isZero,\n  add,\n  subtract,\n  multiply,\n  divide,\n  pow,\n  parse,\n  simplifyConstant,\n  simplifyCore,\n  simplify,\n  fraction,\n  bignumber,\n  mathWithTransform,\n  matrix,\n  AccessorNode,\n  ArrayNode,\n  ConstantNode,\n  FunctionNode,\n  IndexNode,\n  ObjectNode,\n  OperatorNode,\n  SymbolNode,\n  ParenthesisNode\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   *     math.rationalize(expr)\n   *     math.rationalize(expr, detailed)\n   *     math.rationalize(expr, scope)\n   *     math.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  function _rationalize (expr, scope = {}, detailed = false) {\n    const setRules = rulesRationalize() // Rules for change polynomial in near canonical form\n    const polyRet = polynomial(expr, scope, true, setRules.firstRules) // Check if expression is a rationalizable polynomial\n    const nVars = polyRet.variables.length\n    const noExactFractions = { exactFractions: false }\n    const withExactFractions = { exactFractions: true }\n    expr = polyRet.expression\n\n    if (nVars >= 1) { // If expression in not a constant\n      expr = expandPower(expr) // First expand power of polynomials (cannot be made from rules!)\n      let sBefore // Previous expression\n      let rules\n      let eDistrDiv = true\n      let redoInic = false\n      // Apply the initial rules, including succ div rules:\n      expr = simplify(expr, setRules.firstRules, {}, noExactFractions)\n      let s\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        if (s === sBefore) {\n          break // No changes : end of the loop\n        }\n\n        redoInic = true\n        sBefore = s\n      }\n\n      if (redoInic) { // Apply first rules again without succ div rules (if there are changes)\n        expr = simplify(expr, setRules.firstRulesAgain, {}, noExactFractions)\n      }\n      // Apply final rules:\n      expr = simplify(expr, setRules.finalRules, {}, noExactFractions)\n    } // NVars >= 1\n\n    const coefficients = []\n    const retRationalize = {}\n\n    if (expr.type === 'OperatorNode' && expr.isBinary() && expr.op === '/') { // 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      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      if (detailed) {\n        retRationalize.numerator = expr\n        retRationalize.denominator = null\n      }\n    }\n    // nVars\n\n    if (!detailed) return expr\n    retRationalize.coefficients = coefficients\n    retRationalize.variables = polyRet.variables\n    retRationalize.expression = expr\n    return retRationalize\n  }\n\n  return typed(name, {\n    Node: _rationalize,\n    'Node, boolean': (expr, detailed) => _rationalize(expr, {}, detailed),\n    'Node, Object': _rationalize,\n    'Node, Object, boolean': _rationalize\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  function polynomial (expr, scope, extended, rules) {\n    const variables = []\n    const node = simplify(expr, rules, scope, { exactFractions: false }) // Resolves any variables and functions with all defined parameters\n    extended = !!extended\n\n    const oper = '+-*' + (extended ? '/' : '')\n    recPoly(node)\n    const retFunc = {}\n    retFunc.expression = node\n    retFunc.variables = variables\n    return retFunc\n\n    // -------------------------------------------------------------------------------------------------------\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    function recPoly (node) {\n      const tp = node.type // node type\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' || !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.includes(node.op)) {\n            throw new Error('Operator ' + node.op + ' invalid in polynomial expression')\n          }\n          for (let i = 0; i < node.args.length; i++) {\n            recPoly(node.args[i])\n          }\n        } // type of operator\n      } else if (tp === 'SymbolNode') {\n        const name = node.name // variable name\n        const pos = variables.indexOf(name)\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  } // 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  function rulesRationalize () {\n    const oldRules = [simplifyCore, // sCore\n      { l: 'n+n', r: '2*n' },\n      { l: 'n+-n', r: '0' },\n      simplifyConstant, // sConstant\n      { l: 'n*(n1^-1)', r: 'n/n1' },\n      { l: 'n*n1^-n2', r: 'n/n1^n2' },\n      { l: 'n1^-1', r: '1/n1' },\n      { l: 'n*(n1/n2)', r: '(n*n1)/n2' },\n      { l: '1*n', r: 'n' }]\n\n    const rulesFirst = [\n      { l: '(-n1)/(-n2)', r: 'n1/n2' }, // Unary division\n      { l: '(-n1)*(-n2)', r: 'n1*n2' }, // Unary multiplication\n      { l: 'n1--n2', r: 'n1+n2' }, // '--' elimination\n      { l: 'n1-n2', r: 'n1+(-n2)' }, // Subtraction turn into add with un�ry minus\n      { l: '(n1+n2)*n3', r: '(n1*n3 + n2*n3)' }, // Distributive 1\n      { l: 'n1*(n2+n3)', r: '(n1*n2+n1*n3)' }, // Distributive 2\n      { l: 'c1*n + c2*n', r: '(c1+c2)*n' }, // Joining constants\n      { l: 'c1*n + n', r: '(c1+1)*n' }, // Joining constants\n      { l: 'c1*n - c2*n', r: '(c1-c2)*n' }, // Joining constants\n      { l: 'c1*n - n', r: '(c1-1)*n' }, // Joining constants\n      { l: 'v/c', r: '(1/c)*v' }, // variable/constant (new!)\n      { l: 'v/-c', r: '-(1/c)*v' }, // variable/constant (new!)\n      { l: '-v*-c', r: 'c*v' }, // Inversion constant and variable 1\n      { l: '-v*c', r: '-c*v' }, // Inversion constant and variable 2\n      { l: 'v*-c', r: '-c*v' }, // Inversion constant and variable 3\n      { l: 'v*c', r: 'c*v' }, // Inversion constant and variable 4\n      { l: '-(-n1*n2)', r: '(n1*n2)' }, // Unary propagation\n      { l: '-(n1*n2)', r: '(-n1*n2)' }, // Unary propagation\n      { l: '-(-n1+n2)', r: '(n1-n2)' }, // Unary propagation\n      { l: '-(n1+n2)', r: '(-n1-n2)' }, // Unary propagation\n      { l: '(n1^n2)^n3', r: '(n1^(n2*n3))' }, // Power to Power\n      { l: '-(-n1/n2)', r: '(n1/n2)' }, // Division and Unary\n      { l: '-(n1/n2)', r: '(-n1/n2)' }] // Divisao and Unary\n\n    const rulesDistrDiv = [\n      { l: '(n1/n2 + n3/n4)', r: '((n1*n4 + n3*n2)/(n2*n4))' }, // Sum of fractions\n      { l: '(n1/n2 + n3)', r: '((n1 + n3*n2)/n2)' }, // Sum fraction with number 1\n      { l: '(n1 + n2/n3)', r: '((n1*n3 + n2)/n3)' }] // Sum fraction with number 1\n\n    const rulesSucDiv = [\n      { l: '(n1/(n2/n3))', r: '((n1*n3)/n2)' }, // Division simplification\n      { l: '(n1/n2/n3)', r: '(n1/(n2*n3))' }]\n\n    const setRules = {} // rules set in 4 steps.\n\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    setRules.distrDivRules = rulesDistrDiv // Just distr. div. rules\n    setRules.sucDivRules = rulesSucDiv // Jus succ. div. rules\n    setRules.firstRulesAgain = oldRules.concat(rulesFirst) // Last rules set without succ. div.\n\n    // Division simplification\n\n    // Second rule set.\n    // There is no aggregate expression with parentesis, but the only variable can be scattered.\n    setRules.finalRules = [simplifyCore, // simplify.rules[0]\n      { l: 'n*-n', r: '-n^2' }, // Joining multiply with power 1\n      { l: 'n*n', r: 'n^2' }, // Joining multiply with power 2\n      simplifyConstant, // simplify.rules[14] old 3rd index in oldRules\n      { l: 'n*-n^n1', r: '-n^(n1+1)' }, // Joining multiply with power 3\n      { l: 'n*n^n1', r: 'n^(n1+1)' }, // Joining multiply with power 4\n      { l: 'n^n1*-n^n2', r: '-n^(n1+n2)' }, // Joining multiply with power 5\n      { l: 'n^n1*n^n2', r: 'n^(n1+n2)' }, // Joining multiply with power 6\n      { l: 'n^n1*-n', r: '-n^(n1+1)' }, // Joining multiply with power 7\n      { l: 'n^n1*n', r: 'n^(n1+1)' }, // Joining multiply with power 8\n      { l: 'n^n1/-n', r: '-n^(n1-1)' }, // Joining multiply with power 8\n      { l: 'n^n1/n', r: 'n^(n1-1)' }, // Joining division with power 1\n      { l: 'n/-n^n1', r: '-n^(1-n1)' }, // Joining division with power 2\n      { l: 'n/n^n1', r: 'n^(1-n1)' }, // Joining division with power 3\n      { l: 'n^n1/-n^n2', r: 'n^(n1-n2)' }, // Joining division with power 4\n      { l: 'n^n1/n^n2', r: 'n^(n1-n2)' }, // Joining division with power 5\n      { l: 'n1+(-n2*n3)', r: 'n1-n2*n3' }, // Solving useless parenthesis 1\n      { l: 'v*(-c)', r: '-c*v' }, // Solving useless unary 2\n      { l: 'n1+-n2', r: 'n1-n2' }, // Solving +- together (new!)\n      { l: 'v*c', r: 'c*v' }, // inversion constant with variable\n      { l: '(n1^n2)^n3', r: '(n1^(n2*n3))' } // Power to Power\n\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  function expandPower (node, parent, indParent) {\n    const tp = node.type\n    const internal = (arguments.length > 1) // TRUE in internal calls\n\n    if (tp === 'OperatorNode' && node.isBinary()) {\n      let does = false\n      let val\n      if (node.op === '^') { // First operator: Parenthesis or UnaryMinus\n        if ((node.args[0].type === 'ParenthesisNode' ||\n            node.args[0].type === 'OperatorNode') &&\n            (node.args[1].type === 'ConstantNode')) { // Second operator: Constant\n          val = parseFloat(node.args[1].value)\n          does = (val >= 2 && isInteger(val))\n        }\n      }\n\n      if (does) { // Exponent >= 2\n        // Before:\n        //            operator A --> Subtree\n        // parent pow\n        //            constant\n        //\n        if (val > 2) { // 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          const nEsqTopo = node.args[0]\n          const nDirTopo = new OperatorNode('^', 'pow', [node.args[0].cloneDeep(), new ConstantNode(val - 1)])\n          node = new OperatorNode('*', 'multiply', [nEsqTopo, nDirTopo])\n        } else { // 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') { parent.content = node } else { parent.args[indParent] = node }\n        }\n      } // does\n    } // binary OperatorNode\n\n    if (tp === 'ParenthesisNode') {\n      // Recursion\n      expandPower(node.content, node, 'content')\n    } else if (tp !== 'ConstantNode' && tp !== 'SymbolNode') {\n      for (let 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  function polyToCanonical (node, coefficients) {\n    if (coefficients === undefined) { coefficients = [] } // coefficients.\n\n    coefficients[0] = 0 // index is the exponent\n    const o = {}\n    o.cte = 1\n    o.oper = '+'\n\n    // 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    o.fire = ''\n\n    let maxExpo = 0 // maximum exponent\n    let varname = '' // variable name\n\n    recurPol(node, null, o)\n    maxExpo = coefficients.length - 1\n    let first = true\n    let no\n\n    for (let i = maxExpo; i >= 0; i--) {\n      if (coefficients[i] === 0) continue\n      let n1 = new ConstantNode(\n        first ? coefficients[i] : Math.abs(coefficients[i]))\n      const op = coefficients[i] < 0 ? '-' : '+'\n\n      if (i > 0) { // Is not a constant without variable\n        let n2 = new SymbolNode(varname)\n        if (i > 1) {\n          const n3 = new ConstantNode(i)\n          n2 = new OperatorNode('^', 'pow', [n2, n3])\n        }\n        if (coefficients[i] === -1 && first) { n1 = new OperatorNode('-', 'unaryMinus', [n2]) } else if (Math.abs(coefficients[i]) === 1) { n1 = n2 } else { n1 = new OperatorNode('*', 'multiply', [n1, n2]) }\n      }\n\n      if (first) { no = n1 } else if (op === '+') { no = new OperatorNode('+', 'add', [no, n1]) } else { no = new OperatorNode('-', 'subtract', [no, n1]) }\n\n      first = false\n    } // for\n\n    if (first) { return new ConstantNode(0) } else { 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    function recurPol (node, noPai, o) {\n      const tp = node.type\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 (!'+-*^'.includes(node.op)) 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' &&\n                                noPai.fn !== 'subtract' && noPai.fn !== 'multiply') { throw new Error('Invalid ' + node.op + ' placing') }\n\n          // -,+,* : children of +,-\n          if ((node.fn === 'subtract' || node.fn === 'add' || node.fn === 'multiply') &&\n              noPai.fn !== 'add' && noPai.fn !== 'subtract') { throw new Error('Invalid ' + node.op + ' placing') }\n\n          // -,+ : first child\n          if ((node.fn === 'subtract' || node.fn === 'add' ||\n            node.fn === 'unaryMinus') && o.noFil !== 0) { throw new Error('Invalid ' + node.op + ' placing') }\n        } // Has parent\n\n        // Firers: ^,*       Old:   ^,&,-(unary): firers\n        if (node.op === '^' || node.op === '*') {\n          o.fire = node.op\n        }\n\n        for (let i = 0; i < node.args.length; i++) {\n          // +,-: reset fire\n          if (node.fn === 'unaryMinus') o.oper = '-'\n          if (node.op === '+' || node.fn === 'subtract') {\n            o.fire = ''\n            o.cte = 1 // default if there is no constant\n            o.oper = (i === 0 ? '+' : node.op)\n          }\n          o.noFil = i // number of son\n          recurPol(node.args[i], node, o)\n        } // for in children\n      } else if (tp === 'SymbolNode') { // ***** SymbolName *****\n        if (node.name !== varname && varname !== '') { throw new Error('There is more than one variable') }\n        varname = node.name\n        if (noPai === null) {\n          coefficients[1] = 1\n          return\n        }\n\n        // ^: Symbol is First child\n        if (noPai.op === '^' && o.noFil !== 0) { throw new Error('In power the variable should be the first parameter') }\n\n        // *: Symbol is Second child\n        if (noPai.op === '*' && o.noFil !== 1) { throw new Error('In multiply the variable should be the second parameter') }\n\n        // Symbol: firers '',* => it means there is no exponent above, so it's 1 (cte * var)\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        const valor = parseFloat(node.value)\n        if (noPai === null) {\n          coefficients[0] = valor\n          return\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 (!isInteger(valor) || valor <= 0) { throw new Error('Non-integer exponent is not allowed') }\n\n          for (let i = maxExpo + 1; i < valor; i++) coefficients[i] = 0\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        o.cte = valor\n\n        // Cte: firer '' => There is no exponent and no multiplication, so the exponent is 0.\n        if (o.fire === '') { coefficients[0] += o.cte * (o.oper === '+' ? 1 : -1) }\n      } else { throw new Error('Type ' + tp + ' is not allowed') }\n    } // End of recurPol\n  } // End of polyToCanonical\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'zpk2tf'\n\nconst dependencies = [\n  'typed',\n  'add',\n  'multiply',\n  'Complex',\n  'number'\n]\n\nexport const createZpk2tf = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, multiply, Complex, number }) => {\n  /**\n     * Compute the transfer function of a zero-pole-gain model.\n     *\n     * Syntax:\n     *      math.zpk2tf(z, p, k)\n     *\n     * Examples:\n     *    math.zpk2tf([1, 2], [-1, -2], 1)    // returns [[1, -3, 2], [1, 3, 2]]\n     *\n     * See also:\n     *   freqz\n     *\n     * @param {Array} z Array of zeros values\n     * @param {Array} p Array of poles values\n     * @param {number} k Gain value\n     * @return {Array} Two dimensional array containing the numerator (first row) and denominator (second row) polynomials\n     *\n     */\n  return typed(name, {\n    'Array,Array,number': function (z, p, k) {\n      return _zpk2tf(z, p, k)\n    },\n    'Array,Array': function (z, p) {\n      return _zpk2tf(z, p, 1)\n    },\n    'Matrix,Matrix,number': function (z, p, k) {\n      return _zpk2tf(z.valueOf(), p.valueOf(), k)\n    },\n    'Matrix,Matrix': function (z, p) {\n      return _zpk2tf(z.valueOf(), p.valueOf(), 1)\n    }\n  })\n\n  function _zpk2tf (z, p, k) {\n    // if z is bignumber, convert it to number\n    if (z.some((el) => el.type === 'BigNumber')) {\n      z = z.map((el) => number(el))\n    }\n    // if p is bignumber, convert it to number\n    if (p.some((el) => el.type === 'BigNumber')) {\n      p = p.map((el) => number(el))\n    }\n    let num = [Complex(1, 0)]\n    let den = [Complex(1, 0)]\n    for (let i = 0; i < z.length; i++) {\n      let zero = z[i]\n      if (typeof zero === 'number') zero = Complex(zero, 0)\n      num = _multiply(num, [Complex(1, 0), Complex(-zero.re, -zero.im)])\n    }\n    for (let i = 0; i < p.length; i++) {\n      let pole = p[i]\n      if (typeof pole === 'number') pole = Complex(pole, 0)\n      den = _multiply(den, [Complex(1, 0), Complex(-pole.re, -pole.im)])\n    }\n    for (let i = 0; i < num.length; i++) {\n      num[i] = multiply(num[i], k)\n    }\n    return [num, den]\n  }\n\n  function _multiply (a, b) {\n    const c = []\n    for (let i = 0; i < a.length + b.length - 1; i++) {\n      c[i] = Complex(0, 0)\n      for (let j = 0; j < a.length; j++) {\n        if (i - j >= 0 && i - j < b.length) {\n          c[i] = add(c[i], multiply(a[j], b[i - j]))\n        }\n      }\n    }\n    return c\n  }\n})\n","import { factory } from '../../utils/factory.js'\n\nconst name = 'freqz'\n\nconst dependencies = [\n  'typed',\n  'add',\n  'multiply',\n  'Complex',\n  'divide',\n  'matrix'\n]\n\nexport const createFreqz = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, multiply, Complex, divide, matrix }) => {\n  /**\n     * Calculates the frequency response of a filter given its numerator and denominator coefficients.\n     *\n     * Syntax:\n     *    math.freqz(b, a)\n     *    math.freqz(b, a, w)\n     *\n     * Examples:\n     *   math.freqz([1, 2], [1, 2, 3], 4) // returns { h: [0.5 + 0i, 0.4768589245763655 + 0.2861153547458193i, 0.25000000000000006 + 0.75i, -0.770976571635189 + 0.4625859429811135i], w: [0, 0.7853981633974483, 1.5707963267948966, 2.356194490192345 ] }\n     *   math.freqz([1, 2], [1, 2, 3], [0, 1]) // returns { h: [0.5 + 0i, 0.45436781 + 0.38598051i], w: [0, 1] }\n     *\n     * See also:\n     *  zpk2tf\n     *\n     * @param {Array.<number>} b The numerator coefficients of the filter.\n     * @param {Array.<number>} a The denominator coefficients of the filter.\n     * @param {Array.<number>} [w] A vector of frequencies (in radians/sample) at which the frequency response is to be computed or the number of points to compute (if a number is not provided, the default is 512 points)\n     * @returns {Object} An object with two properties: h, a vector containing the complex frequency response, and w, a vector containing the normalized frequencies (in radians/sample) at which the response was computed.\n     *\n     *\n     */\n  return typed(name, {\n    'Array, Array': function (b, a) {\n      const w = createBins(512)\n      return _freqz(b, a, w)\n    },\n    'Array, Array, Array': function (b, a, w) {\n      return _freqz(b, a, w)\n    },\n    'Array, Array, number': function (b, a, w) {\n      if (w < 0) {\n        throw new Error('w must be a positive number')\n      }\n      const w2 = createBins(w)\n      return _freqz(b, a, w2)\n    },\n    'Matrix, Matrix': function (b, a) {\n      // console.log('here')\n      const _w = createBins(512)\n      const { w, h } = _freqz(b.valueOf(), a.valueOf(), _w)\n      return {\n        w: matrix(w),\n        h: matrix(h)\n      }\n    },\n    'Matrix, Matrix, Matrix': function (b, a, w) {\n      const { h } = _freqz(b.valueOf(), a.valueOf(), w.valueOf())\n      return {\n        h: matrix(h),\n        w: matrix(w)\n      }\n    },\n    'Matrix, Matrix, number': function (b, a, w) {\n      if (w < 0) {\n        throw new Error('w must be a positive number')\n      }\n      const _w = createBins(w)\n      const { h } = _freqz(b.valueOf(), a.valueOf(), _w)\n      return {\n        h: matrix(h),\n        w: matrix(_w)\n      }\n    }\n  })\n\n  function _freqz (b, a, w) {\n    const num = []\n    const den = []\n    for (let i = 0; i < w.length; i++) {\n      let sumNum = Complex(0, 0)\n      let sumDen = Complex(0, 0)\n      for (let j = 0; j < b.length; j++) {\n        sumNum = add(sumNum, multiply(b[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i]))))\n      }\n      for (let j = 0; j < a.length; j++) {\n        sumDen = add(sumDen, multiply(a[j], Complex(Math.cos(-j * w[i]), Math.sin(-j * w[i]))))\n      }\n      num.push(sumNum)\n      den.push(sumDen)\n    }\n    const h = []\n    for (let i = 0; i < num.length; i++) {\n      h.push(divide(num[i], den[i]))\n    }\n    return { h, w }\n  }\n\n  function createBins (n) {\n    const bins = []\n    for (let i = 0; i < n; i++) {\n      bins.push(i / n * Math.PI)\n    }\n    return bins\n  }\n})\n","import { factory } from '../utils/factory.js'\n\nconst name = 'reviver'\nconst dependencies = [\n  'classes'\n]\n\nexport const createReviver = /* #__PURE__ */ factory(name, dependencies, ({ classes }) => {\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    const 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})\n","import { factory } from '../utils/factory.js'\n\nconst name = 'replacer'\nconst dependencies = []\n\nexport const createReplacer = /* #__PURE__ */ factory(name, dependencies, () => {\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    if (typeof value === 'bigint') {\n      return {\n        mathjs: 'bigint',\n        value: String(value)\n      }\n    }\n\n    return value\n  }\n})\n","export const pi = Math.PI\nexport const tau = 2 * Math.PI\nexport const e = Math.E\nexport const phi = 1.6180339887498948 // eslint-disable-line no-loss-of-precision\n","import { factory } from './utils/factory.js'\nimport { version } from './version.js'\nimport {\n  createBigNumberE,\n  createBigNumberPhi,\n  createBigNumberPi,\n  createBigNumberTau\n} from './utils/bignumber/constants.js'\nimport { pi, tau, e, phi } from './plain/number/index.js'\n\nexport const createTrue = /* #__PURE__ */ factory('true', [], () => true)\nexport const createFalse = /* #__PURE__ */ factory('false', [], () => false)\nexport const createNull = /* #__PURE__ */ factory('null', [], () => null)\n\nexport const createInfinity = /* #__PURE__ */ recreateFactory(\n  'Infinity',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(Infinity)\n    : Infinity\n)\n\nexport const createNaN = /* #__PURE__ */ recreateFactory(\n  'NaN',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(NaN)\n    : NaN\n)\n\nexport const createPi = /* #__PURE__ */ recreateFactory(\n  'pi',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? createBigNumberPi(BigNumber)\n    : pi\n)\n\nexport const createTau = /* #__PURE__ */ recreateFactory(\n  'tau',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? createBigNumberTau(BigNumber)\n    : tau\n)\n\nexport const createE = /* #__PURE__ */ recreateFactory(\n  'e',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? createBigNumberE(BigNumber)\n    : e\n)\n\n// golden ratio, (1+sqrt(5))/2\nexport const createPhi = /* #__PURE__ */ recreateFactory(\n  'phi',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? createBigNumberPhi(BigNumber)\n    : phi\n)\n\nexport const createLN2 = /* #__PURE__ */ recreateFactory(\n  'LN2',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(2).ln()\n    : Math.LN2\n)\n\nexport const createLN10 = /* #__PURE__ */ recreateFactory(\n  'LN10',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(10).ln()\n    : Math.LN10\n)\n\nexport const createLOG2E = /* #__PURE__ */ recreateFactory(\n  'LOG2E',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(1).div(new BigNumber(2).ln())\n    : Math.LOG2E\n)\n\nexport const createLOG10E = /* #__PURE__ */ recreateFactory(\n  'LOG10E',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(1).div(new BigNumber(10).ln())\n    : Math.LOG10E\n)\n\nexport const createSQRT1_2 = /* #__PURE__ */ recreateFactory( // eslint-disable-line camelcase\n  'SQRT1_2',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber('0.5').sqrt()\n    : Math.SQRT1_2\n)\n\nexport const createSQRT2 = /* #__PURE__ */ recreateFactory(\n  'SQRT2',\n  ['config', '?BigNumber'],\n  ({ config, BigNumber }) => (config.number === 'BigNumber')\n    ? new BigNumber(2).sqrt()\n    : Math.SQRT2\n)\n\nexport const createI = /* #__PURE__ */ recreateFactory(\n  'i',\n  ['Complex'],\n  ({ Complex }) => Complex.I\n)\n\n// for backward compatibility with v5\nexport const createUppercasePi = /* #__PURE__ */ factory('PI', ['pi'], ({ pi }) => pi)\nexport const createUppercaseE = /* #__PURE__ */ factory('E', ['e'], ({ e }) => e)\n\nexport const createVersion = /* #__PURE__ */ factory('version', [], () => version)\n\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?\nfunction recreateFactory (name, dependencies, create) {\n  return factory(name, dependencies, create, {\n    recreateOnConfigChange: true\n  })\n}\n","export const version = '13.0.3'\n// Note: This file is automatically generated when building math.js.\n// Changes made in this file will be overwritten.\n","import { factory } from '../../utils/factory.js'\n\n// Source: https://en.wikipedia.org/wiki/Physical_constant\n\n// Universal constants\nexport const createSpeedOfLight = /* #__PURE__ */ unitFactory('speedOfLight', '299792458', 'm s^-1')\nexport const createGravitationConstant = /* #__PURE__ */ unitFactory('gravitationConstant', '6.67430e-11', 'm^3 kg^-1 s^-2')\nexport const createPlanckConstant = /* #__PURE__ */ unitFactory('planckConstant', '6.62607015e-34', 'J s')\nexport const createReducedPlanckConstant = /* #__PURE__ */ unitFactory('reducedPlanckConstant', '1.0545718176461565e-34', 'J s')\n\n// Electromagnetic constants\nexport const createMagneticConstant = /* #__PURE__ */ unitFactory('magneticConstant', '1.25663706212e-6', 'N A^-2')\nexport const createElectricConstant = /* #__PURE__ */ unitFactory('electricConstant', '8.8541878128e-12', 'F m^-1')\nexport const createVacuumImpedance = /* #__PURE__ */ unitFactory('vacuumImpedance', '376.730313667', 'ohm')\nexport const createCoulomb = /* #__PURE__ */ unitFactory('coulomb', '8.987551792261171e9', 'N m^2 C^-2')\nexport const createElementaryCharge = /* #__PURE__ */ unitFactory('elementaryCharge', '1.602176634e-19', 'C')\nexport const createBohrMagneton = /* #__PURE__ */ unitFactory('bohrMagneton', '9.2740100783e-24', 'J T^-1')\nexport const createConductanceQuantum = /* #__PURE__ */ unitFactory('conductanceQuantum', '7.748091729863649e-5', 'S')\nexport const createInverseConductanceQuantum = /* #__PURE__ */ unitFactory('inverseConductanceQuantum', '12906.403729652257', 'ohm')\nexport const createMagneticFluxQuantum = /* #__PURE__ */ unitFactory('magneticFluxQuantum', '2.0678338484619295e-15', 'Wb')\nexport const createNuclearMagneton = /* #__PURE__ */ unitFactory('nuclearMagneton', '5.0507837461e-27', 'J T^-1')\nexport const createKlitzing = /* #__PURE__ */ unitFactory('klitzing', '25812.807459304513', 'ohm')\nexport const createJosephson = /* #__PURE__ */ unitFactory('josephson', '4.835978484169836e14 Hz V', 'Hz V^-1') // TODO: support for Hz needed\n\n// Atomic and nuclear constants\nexport const createBohrRadius = /* #__PURE__ */ unitFactory('bohrRadius', '5.29177210903e-11', 'm')\nexport const createClassicalElectronRadius = /* #__PURE__ */ unitFactory('classicalElectronRadius', '2.8179403262e-15', 'm')\nexport const createElectronMass = /* #__PURE__ */ unitFactory('electronMass', '9.1093837015e-31', 'kg')\nexport const createFermiCoupling = /* #__PURE__ */ unitFactory('fermiCoupling', '1.1663787e-5', 'GeV^-2')\nexport const createFineStructure = numberFactory('fineStructure', 7.2973525693e-3)\nexport const createHartreeEnergy = /* #__PURE__ */ unitFactory('hartreeEnergy', '4.3597447222071e-18', 'J')\nexport const createProtonMass = /* #__PURE__ */ unitFactory('protonMass', '1.67262192369e-27', 'kg')\nexport const createDeuteronMass = /* #__PURE__ */ unitFactory('deuteronMass', '3.3435830926e-27', 'kg')\nexport const createNeutronMass = /* #__PURE__ */ unitFactory('neutronMass', '1.6749271613e-27', 'kg')\nexport const createQuantumOfCirculation = /* #__PURE__ */ unitFactory('quantumOfCirculation', '3.6369475516e-4', 'm^2 s^-1')\nexport const createRydberg = /* #__PURE__ */ unitFactory('rydberg', '10973731.568160', 'm^-1')\nexport const createThomsonCrossSection = /* #__PURE__ */ unitFactory('thomsonCrossSection', '6.6524587321e-29', 'm^2')\nexport const createWeakMixingAngle = numberFactory('weakMixingAngle', 0.22290)\nexport const createEfimovFactor = numberFactory('efimovFactor', 22.7)\n\n// Physico-chemical constants\nexport const createAtomicMass = /* #__PURE__ */ unitFactory('atomicMass', '1.66053906660e-27', 'kg')\nexport const createAvogadro = /* #__PURE__ */ unitFactory('avogadro', '6.02214076e23', 'mol^-1')\nexport const createBoltzmann = /* #__PURE__ */ unitFactory('boltzmann', '1.380649e-23', 'J K^-1')\nexport const createFaraday = /* #__PURE__ */ unitFactory('faraday', '96485.33212331001', 'C mol^-1')\nexport const createFirstRadiation = /* #__PURE__ */ unitFactory('firstRadiation', '3.7417718521927573e-16', 'W m^2')\n// TODO spectralRadiance = 1.1910429723971881e-16 W m^2 sr^-1\nexport const createLoschmidt = /* #__PURE__ */ unitFactory('loschmidt', '2.686780111798444e25', 'm^-3')\nexport const createGasConstant = /* #__PURE__ */ unitFactory('gasConstant', '8.31446261815324', 'J K^-1 mol^-1')\nexport const createMolarPlanckConstant = /* #__PURE__ */ unitFactory('molarPlanckConstant', '3.990312712893431e-10', 'J s mol^-1')\nexport const createMolarVolume = /* #__PURE__ */ unitFactory('molarVolume', '0.022413969545014137', 'm^3 mol^-1')\nexport const createSackurTetrode = numberFactory('sackurTetrode', -1.16487052358)\nexport const createSecondRadiation = /* #__PURE__ */ unitFactory('secondRadiation', '0.014387768775039337', 'm K')\nexport const createStefanBoltzmann = /* #__PURE__ */ unitFactory('stefanBoltzmann', '5.67037441918443e-8', 'W m^-2 K^-4')\nexport const createWienDisplacement = /* #__PURE__ */ unitFactory('wienDisplacement', '2.897771955e-3', 'm K')\n\n// Adopted values\nexport const createMolarMass = /* #__PURE__ */ unitFactory('molarMass', '0.99999999965e-3', 'kg mol^-1')\nexport const createMolarMassC12 = /* #__PURE__ */ unitFactory('molarMassC12', '11.9999999958e-3', 'kg mol^-1')\nexport const createGravity = /* #__PURE__ */ unitFactory('gravity', '9.80665', 'm s^-2')\n// atm is defined in Unit.js\n\n// Natural units\nexport const createPlanckLength = /* #__PURE__ */ unitFactory('planckLength', '1.616255e-35', 'm')\nexport const createPlanckMass = /* #__PURE__ */ unitFactory('planckMass', '2.176435e-8', 'kg')\nexport const createPlanckTime = /* #__PURE__ */ unitFactory('planckTime', '5.391245e-44', 's')\nexport const createPlanckCharge = /* #__PURE__ */ unitFactory('planckCharge', '1.87554603778e-18', 'C')\nexport const createPlanckTemperature = /* #__PURE__ */ unitFactory('planckTemperature', '1.416785e+32', 'K')\n\n// 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\nfunction unitFactory (name, valueStr, unitStr) {\n  const dependencies = ['config', 'Unit', 'BigNumber']\n\n  return factory(name, dependencies, ({ config, Unit, 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    const value = config.number === 'BigNumber'\n      ? new BigNumber(valueStr)\n      : parseFloat(valueStr)\n\n    const unit = new Unit(value, unitStr)\n    unit.fixPrefix = true\n    return unit\n  })\n}\n\n// helper function to create a factory function which creates a numeric constant,\n// either a number or BigNumber depending on the configuration\nfunction numberFactory (name, value) {\n  const dependencies = ['config', 'BigNumber']\n\n  return factory(name, dependencies, ({ config, BigNumber }) => {\n    return config.number === 'BigNumber'\n      ? new BigNumber(value)\n      : value\n  })\n}\n","import { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createApply } from '../../function/matrix/apply.js'\nimport { isBigNumber, isNumber } from '../../utils/is.js'\n\nconst name = 'apply'\nconst dependencies = ['typed', 'isInteger']\n\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 */\nexport const createApplyTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, isInteger }) => {\n  const apply = createApply({ typed, isInteger })\n\n  // @see: comment of concat itself\n  return typed('apply', {\n    '...any': function (args) {\n      // change dim from one-based to zero-based\n      const dim = args[1]\n\n      if (isNumber(dim)) {\n        args[1] = dim - 1\n      } else if (isBigNumber(dim)) {\n        args[1] = dim.minus(1)\n      }\n\n      try {\n        return apply.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createColumn } from '../../function/matrix/column.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'column'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\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 */\nexport const createColumnTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n  const column = createColumn({ typed, Index, matrix, range })\n\n  // @see: comment of column itself\n  return typed('column', {\n    '...any': function (args) {\n      // change last argument from zero-based to one-based\n      const lastIndex = args.length - 1\n      const last = args[lastIndex]\n      if (isNumber(last)) {\n        args[lastIndex] = last - 1\n      }\n\n      try {\n        return column.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { isSymbolNode } from '../../../utils/is.js'\nimport { PartitionedMap } from '../../../utils/map.js'\n\n/**\n * Compile an inline expression like \"x > 0\"\n * @param {Node} expression\n * @param {Object} math\n * @param {Map} scope\n * @return {function} Returns a function with one argument which fills in the\n *                    undefined variable (like \"x\") and evaluates the expression\n */\nexport function compileInlineExpression (expression, math, scope) {\n  // find an undefined symbol\n  const symbol = expression.filter(function (node) {\n    return isSymbolNode(node) &&\n        !(node.name in math) &&\n        !(scope.has(node.name))\n  })[0]\n\n  if (!symbol) {\n    throw new Error('No undefined variable found in inline expression \"' + expression + '\"')\n  }\n\n  // create a test function for this equation\n  const name = symbol.name // variable name\n  const argsScope = new Map()\n  const subScope = new PartitionedMap(scope, argsScope, new Set([name]))\n  const eq = expression.compile()\n  return function inlineExpression (x) {\n    argsScope.set(name, x)\n    return eq.evaluate(subScope)\n  }\n}\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { filter, filterRegExp } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\n\nconst name = 'filter'\nconst dependencies = ['typed']\n\nexport const createFilterTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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    let x, callback\n\n    if (args[0]) {\n      x = args[0].compile().evaluate(scope)\n    }\n\n    if (args[1]) {\n      if (isSymbolNode(args[1]) || 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 = compileInlineExpression(args[1], math, scope)\n      }\n    }\n\n    return filter(x, callback)\n  }\n  filterTransform.rawArgs = true\n\n  // one based version of function filter\n  const filter = typed('filter', {\n    'Array, function': _filter,\n\n    'Matrix, function': function (x, test) {\n      return x.create(_filter(x.toArray(), test))\n    },\n\n    'Array, RegExp': filterRegExp,\n\n    'Matrix, RegExp': function (x, test) {\n      return x.create(filterRegExp(x.toArray(), test))\n    }\n  })\n\n  return filterTransform\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 */\nfunction _filter (x, callback) {\n  return filter(x, function (value, index, array) {\n    // invoke the callback function with the right number of arguments\n    return applyCallback(callback, value, [index + 1], array, 'filter')\n  })\n}\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { forEach } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\n\nconst name = 'forEach'\nconst dependencies = ['typed']\n\nexport const createForEachTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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    let x, callback\n\n    if (args[0]) {\n      x = args[0].compile().evaluate(scope)\n    }\n\n    if (args[1]) {\n      if (isSymbolNode(args[1]) || 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 = compileInlineExpression(args[1], math, scope)\n      }\n    }\n\n    return _forEach(x, callback)\n  }\n  forEachTransform.rawArgs = true\n\n  // one-based version of forEach\n  const _forEach = typed('forEach', {\n    'Array | Matrix, function': function (array, callback) {\n      const recurse = function (value, index) {\n        if (Array.isArray(value)) {\n          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          return applyCallback(callback, value, index, array, 'forEach')\n        }\n      }\n      recurse(array.valueOf(), []) // pass Array\n    }\n  })\n\n  return forEachTransform\n}, { isTransformFunction: true })\n","import { isArray, isBigNumber, isMatrix, isNumber, isRange } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\n\nconst name = 'index'\nconst dependencies = ['Index', 'getMatrixDataType']\n\nexport const createIndexTransform = /* #__PURE__ */ factory(name, dependencies, ({ Index, getMatrixDataType }) => {\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    const args = []\n    for (let i = 0, ii = arguments.length; i < ii; i++) {\n      let arg = arguments[i]\n\n      // change from one-based to zero based, convert BigNumber to number and leave Array of Booleans as is\n      if (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) { return v - 1 })\n      } else if (isArray(arg) || isMatrix(arg)) {\n        if (getMatrixDataType(arg) !== 'boolean') {\n          arg = arg.map(function (v) { return v - 1 })\n        }\n      } else if (isNumber(arg)) {\n        arg--\n      } else if (isBigNumber(arg)) {\n        arg = arg.toNumber() - 1\n      } else if (typeof arg === 'string') {\n      // 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    const res = new Index()\n    Index.apply(res, args)\n    return res\n  }\n}, { isTransformFunction: true })\n","import { applyCallback } from '../../utils/applyCallback.js'\nimport { map } from '../../utils/array.js'\nimport { factory } from '../../utils/factory.js'\nimport { isFunctionAssignmentNode, isSymbolNode } from '../../utils/is.js'\nimport { compileInlineExpression } from './utils/compileInlineExpression.js'\n\nconst name = 'map'\nconst dependencies = ['typed']\n\nexport const createMapTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed }) => {\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    let x, callback\n\n    if (args[0]) {\n      x = args[0].compile().evaluate(scope)\n    }\n\n    if (args[1]) {\n      if (isSymbolNode(args[1]) || 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 = compileInlineExpression(args[1], math, scope)\n      }\n    }\n\n    return map(x, callback)\n  }\n  mapTransform.rawArgs = true\n\n  // one-based version of map function\n  const map = typed('map', {\n    'Array, function': function (x, callback) {\n      return _map(x, callback, x)\n    },\n\n    'Matrix, function': function (x, callback) {\n      return x.create(_map(x.valueOf(), callback, x))\n    }\n  })\n\n  return mapTransform\n}, { isTransformFunction: true })\n\n/**\n * Map for a multidimensional array. One-based indexes\n * @param {Array} array\n * @param {function} callback\n * @param {Array} orig\n * @return {Array}\n * @private\n */\nfunction _map (array, callback, orig) {\n  function recurse (value, index) {\n    if (Array.isArray(value)) {\n      return 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      return applyCallback(callback, value, index, orig, 'map')\n    }\n  }\n\n  return recurse(array, [])\n}\n","import { isBigNumber, isCollection, isNumber } from '../../../utils/is.js'\n\n/**\n * Change last argument dim from one-based to zero-based.\n */\nexport function lastDimToZeroBase (args) {\n  if (args.length === 2 && isCollection(args[0])) {\n    args = args.slice()\n    const dim = args[1]\n    if (isNumber(dim)) {\n      args[1] = dim - 1\n    } else if (isBigNumber(dim)) {\n      args[1] = dim.minus(1)\n    }\n  }\n  return args\n}\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMax } from '../../function/statistics/max.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'max'\nconst dependencies = ['typed', 'config', 'numeric', 'larger']\n\nexport const createMaxTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, larger }) => {\n  const max = createMax({ typed, config, numeric, 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  return typed('max', {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return max.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMean } from '../../function/statistics/mean.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'mean'\nconst dependencies = ['typed', 'add', 'divide']\n\nexport const createMeanTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, divide }) => {\n  const mean = createMean({ typed, add, 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  return typed('mean', {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return mean.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createMin } from '../../function/statistics/min.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'min'\nconst dependencies = ['typed', 'config', 'numeric', 'smaller']\n\nexport const createMinTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, numeric, smaller }) => {\n  const min = createMin({ typed, config, numeric, 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  return typed('min', {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return min.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createRange } from '../../function/matrix/range.js'\n\nconst name = 'range'\nconst dependencies = ['typed', 'config', '?matrix', '?bignumber', 'smaller', 'smallerEq', 'larger', 'largerEq', 'add', 'isPositive']\n\nexport const createRangeTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive }) => {\n  const range = createRange({ typed, config, matrix, bignumber, smaller, smallerEq, larger, largerEq, add, isPositive })\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  return typed('range', {\n    '...any': function (args) {\n      const lastIndex = args.length - 1\n      const last = args[lastIndex]\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}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createRow } from '../../function/matrix/row.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { isNumber } from '../../utils/is.js'\n\nconst name = 'row'\nconst dependencies = ['typed', 'Index', 'matrix', 'range']\n\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 */\nexport const createRowTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, Index, matrix, range }) => {\n  const row = createRow({ typed, Index, matrix, range })\n\n  // @see: comment of row itself\n  return typed('row', {\n    '...any': function (args) {\n      // change last argument from zero-based to one-based\n      const lastIndex = args.length - 1\n      const last = args[lastIndex]\n      if (isNumber(last)) {\n        args[lastIndex] = last - 1\n      }\n\n      try {\n        return row.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createSubset } from '../../function/matrix/subset.js'\n\nconst name = 'subset'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createSubsetTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\n  const subset = createSubset({ typed, matrix, zeros, add })\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  return typed('subset', {\n    '...any': function (args) {\n      try {\n        return subset.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { isBigNumber, isNumber } from '../../utils/is.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { factory } from '../../utils/factory.js'\nimport { createConcat } from '../../function/matrix/concat.js'\n\nconst name = 'concat'\nconst dependencies = ['typed', 'matrix', 'isInteger']\n\nexport const createConcatTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, isInteger }) => {\n  const concat = createConcat({ typed, matrix, 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  return typed('concat', {\n    '...any': function (args) {\n      // change last argument from one-based to zero-based\n      const lastIndex = args.length - 1\n      const last = args[lastIndex]\n      if (isNumber(last)) {\n        args[lastIndex] = last - 1\n      } else if (isBigNumber(last)) {\n        args[lastIndex] = last.minus(1)\n      }\n\n      try {\n        return concat.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createDiff } from '../../function/matrix/diff.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'diff'\nconst dependencies = ['typed', 'matrix', 'subtract', 'number', 'bignumber']\n\nexport const createDiffTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, subtract, number, bignumber }) => {\n  const diff = createDiff({ typed, matrix, subtract, number, 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  return typed(name, {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return diff.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createStd } from '../../function/statistics/std.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'std'\nconst dependencies = ['typed', 'map', 'sqrt', 'variance']\n\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 */\nexport const createStdTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, map, sqrt, variance }) => {\n  const std = createStd({ typed, map, sqrt, variance })\n\n  return typed('std', {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return std.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createSum } from '../../function/statistics/sum.js'\nimport { lastDimToZeroBase } from './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 */\nconst name = 'sum'\nconst dependencies = ['typed', 'config', 'add', 'numeric']\n\nexport const createSumTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, config, add, numeric }) => {\n  const sum = createSum({ typed, config, add, numeric })\n\n  return typed(name, {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return sum.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { createQuantileSeq } from '../../function/statistics/quantileSeq.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'quantileSeq'\nconst dependencies = ['typed', 'bignumber', 'add', 'subtract', 'divide', 'multiply', 'partitionSelect', 'compare', 'isInteger', 'smaller', 'smallerEq', 'larger']\n\n/**\n * Attach a transform function to math.quantileSeq\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 */\nexport const createQuantileSeqTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger }) => {\n  const quantileSeq = createQuantileSeq({ typed, bignumber, add, subtract, divide, multiply, partitionSelect, compare, isInteger, smaller, smallerEq, larger })\n\n  return typed('quantileSeq', {\n    'Array | Matrix, number | BigNumber': quantileSeq,\n    'Array | Matrix, number | BigNumber, number': (arr, prob, dim) => quantileSeq(arr, prob, dimToZeroBase(dim)),\n    'Array | Matrix, number | BigNumber, boolean': quantileSeq,\n    'Array | Matrix, number | BigNumber, boolean, number': (arr, prob, sorted, dim) => quantileSeq(arr, prob, sorted, dimToZeroBase(dim)),\n    'Array | Matrix, Array | Matrix': quantileSeq,\n    'Array | Matrix, Array | Matrix, number': (data, prob, dim) => quantileSeq(data, prob, dimToZeroBase(dim)),\n    'Array | Matrix, Array | Matrix, boolean': quantileSeq,\n    'Array | Matrix, Array | Matrix, boolean, number': (data, prob, sorted, dim) => quantileSeq(data, prob, sorted, dimToZeroBase(dim))\n  })\n\n  function dimToZeroBase (dim) {\n    // TODO: find a better way, maybe lastDimToZeroBase could apply to more cases.\n    return lastDimToZeroBase([[], dim])[1]\n  }\n}, { isTransformFunction: true })\n","import { isBigNumber, isCollection, isNumber } from '../../utils/is.js'\nimport { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createCumSum } from '../../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 */\nconst name = 'cumsum'\nconst dependencies = ['typed', 'add', 'unaryPlus']\n\nexport const createCumSumTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, unaryPlus }) => {\n  const cumsum = createCumSum({ typed, add, unaryPlus })\n\n  return typed(name, {\n    '...any': function (args) {\n      // change last argument dim from one-based to zero-based\n      if (args.length === 2 && isCollection(args[0])) {\n        const dim = args[1]\n        if (isNumber(dim)) {\n          args[1] = dim - 1\n        } else if (isBigNumber(dim)) {\n          args[1] = dim.minus(1)\n        }\n      }\n\n      try {\n        return cumsum.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { factory } from '../../utils/factory.js'\nimport { errorTransform } from './utils/errorTransform.js'\nimport { createVariance } from '../../function/statistics/variance.js'\nimport { lastDimToZeroBase } from './utils/lastDimToZeroBase.js'\n\nconst name = 'variance'\nconst dependencies = ['typed', 'add', 'subtract', 'multiply', 'divide', 'apply', 'isNaN']\n\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 */\nexport const createVarianceTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, add, subtract, multiply, divide, apply, isNaN }) => {\n  const variance = createVariance({ typed, add, subtract, multiply, divide, apply, isNaN })\n\n  return typed(name, {\n    '...any': function (args) {\n      args = lastDimToZeroBase(args)\n\n      try {\n        return variance.apply(null, args)\n      } catch (err) {\n        throw errorTransform(err)\n      }\n    }\n  })\n}, { isTransformFunction: true })\n","import { createPrint } from '../../function/string/print.js'\nimport { factory } from '../../utils/factory.js'\nimport { printTemplate } from '../../utils/print.js'\n\nconst name = 'print'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add']\n\nexport const createPrintTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, zeros, add }) => {\n  const print = createPrint({ typed, matrix, zeros, add })\n  return typed(name, {\n    'string, Object | Array': function (template, values) { return print(_convertTemplateToZeroBasedIndex(template), values) },\n    'string, Object | Array, number | Object': function (template, values, options) { return print(_convertTemplateToZeroBasedIndex(template), values, options) }\n  })\n\n  function _convertTemplateToZeroBasedIndex (template) {\n    return template.replace(printTemplate, (x) => {\n      const parts = x.slice(1).split('.')\n      const result = parts.map(function (part) {\n        if (!isNaN(part) && part.length > 0) {\n          return parseInt(part) - 1\n        } else {\n          return part\n        }\n      })\n      return '$' + result.join('.')\n    })\n  }\n}, { isTransformFunction: true })\n","import { createAnd } from '../../function/logical/and.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'and'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']\n\nexport const createAndTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n  const and = createAnd({ typed, matrix, equalScalar, zeros, not, concat })\n\n  function andTransform (args, math, scope) {\n    const condition1 = args[0].compile().evaluate(scope)\n    if (!isCollection(condition1) && !and(condition1, true)) {\n      return false\n    }\n    const condition2 = args[1].compile().evaluate(scope)\n    return and(condition1, condition2)\n  }\n\n  andTransform.rawArgs = true\n\n  return andTransform\n}, { isTransformFunction: true })\n","import { createOr } from '../../function/logical/or.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'or'\nconst dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']\n\nexport const createOrTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n  const or = createOr({ typed, matrix, equalScalar, DenseMatrix, concat })\n\n  function orTransform (args, math, scope) {\n    const condition1 = args[0].compile().evaluate(scope)\n    if (!isCollection(condition1) && or(condition1, false)) {\n      return true\n    }\n    const condition2 = args[1].compile().evaluate(scope)\n    return or(condition1, condition2)\n  }\n\n  orTransform.rawArgs = true\n\n  return orTransform\n}, { isTransformFunction: true })\n","import { createBitAnd } from '../../function/bitwise/bitAnd.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'bitAnd'\nconst dependencies = ['typed', 'matrix', 'zeros', 'add', 'equalScalar', 'not', 'concat']\n\nexport const createBitAndTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, zeros, not, concat }) => {\n  const bitAnd = createBitAnd({ typed, matrix, equalScalar, zeros, not, concat })\n\n  function bitAndTransform (args, math, scope) {\n    const condition1 = args[0].compile().evaluate(scope)\n    if (!isCollection(condition1)) {\n      if (isNaN(condition1)) {\n        return NaN\n      }\n      if (condition1 === 0 || condition1 === false) {\n        return 0\n      }\n    }\n    const condition2 = args[1].compile().evaluate(scope)\n    return bitAnd(condition1, condition2)\n  }\n\n  bitAndTransform.rawArgs = true\n\n  return bitAndTransform\n}, { isTransformFunction: true })\n","import { createBitOr } from '../../function/bitwise/bitOr.js'\nimport { factory } from '../../utils/factory.js'\nimport { isCollection } from '../../utils/is.js'\n\nconst name = 'bitOr'\nconst dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix', 'concat']\n\nexport const createBitOrTransform = /* #__PURE__ */ factory(name, dependencies, ({ typed, matrix, equalScalar, DenseMatrix, concat }) => {\n  const bitOr = createBitOr({ typed, matrix, equalScalar, DenseMatrix, concat })\n\n  function bitOrTransform (args, math, scope) {\n    const condition1 = args[0].compile().evaluate(scope)\n    if (!isCollection(condition1)) {\n      if (isNaN(condition1)) {\n        return NaN\n      }\n      if (condition1 === (-1)) {\n        return -1\n      }\n      if (condition1 === true) {\n        return 1\n      }\n    }\n    const condition2 = args[1].compile().evaluate(scope)\n    return bitOr(condition1, condition2)\n  }\n\n  bitOrTransform.rawArgs = true\n\n  return bitOrTransform\n}, { isTransformFunction: true })\n","export const DEFAULT_CONFIG = {\n  // minimum relative difference between two compared values,\n  // used by all comparison functions\n  relTol: 1e-12,\n\n  // minimum absolute difference between two compared values,\n  // used by all comparison functions\n  absTol: 1e-15,\n\n  // type of default matrix output. Choose 'matrix' (default) or 'array'\n  matrix: 'Matrix',\n\n  // type of default number output. Choose 'number' (default) 'BigNumber', 'bigint', or 'Fraction'\n  number: 'number',\n\n  // type of fallback used for config { number: 'bigint' } when a value cannot be represented\n  // in the configured numeric type. Choose 'number' (default) or 'BigNumber'.\n  numberFallback: 'number',\n\n  // number of significant digits in BigNumbers\n  precision: 64,\n\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\n  // random seed for seeded pseudo random number generation\n  // null = randomly seed\n  randomSeed: null\n}\n","import { clone, deepExtend } from '../../utils/object.js'\nimport { DEFAULT_CONFIG } from '../config.js'\n\nexport const MATRIX_OPTIONS = ['Matrix', 'Array'] // valid values for option matrix\nexport const NUMBER_OPTIONS = ['number', 'BigNumber', 'Fraction'] // valid values for option number\n\nexport function 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} relTol\n   *                              Minimum relative difference between two\n   *                              compared values, used by all comparison functions.\n   *                            {number} absTol\n   *                              Minimum absolute 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', 'bigint', 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      if (options.epsilon !== undefined) {\n        // this if is only for backwards compatibility, it can be removed in the future.\n        console.warn('Warning: The configuration option \"epsilon\" is deprecated. Use \"relTol\" and \"absTol\" instead.')\n        const optionsFix = clone(options)\n        optionsFix.relTol = options.epsilon\n        optionsFix.absTol = options.epsilon * 1e-3\n        delete optionsFix.epsilon\n        return _config(optionsFix)\n      }\n      const prev = clone(config)\n\n      // validate some of the options\n      validateOption(options, 'matrix', MATRIX_OPTIONS)\n      validateOption(options, 'number', NUMBER_OPTIONS)\n\n      // merge options\n      deepExtend(config, options)\n\n      const curr = clone(config)\n\n      const changes = clone(options)\n\n      // emit 'config' event\n      emit('config', curr, prev, changes)\n\n      return curr\n    } else {\n      return clone(config)\n    }\n  }\n\n  // attach the valid options to the function so they can be extended\n  _config.MATRIX_OPTIONS = MATRIX_OPTIONS\n  _config.NUMBER_OPTIONS = NUMBER_OPTIONS\n\n  // attach the config properties as readonly properties to the config function\n  Object.keys(DEFAULT_CONFIG).forEach(key => {\n    Object.defineProperty(_config, key, {\n      get: () => config[key],\n      enumerable: true,\n      configurable: true\n    })\n  })\n\n  return _config\n}\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.<string>} values  Array with valid values for this option\n */\nfunction validateOption (options, name, values) {\n  if (options[name] !== undefined && !values.includes(options[name])) {\n    // unknown value\n    console.warn('Warning: Unknown value \"' + options[name] + '\" for configuration option \"' + name + '\". ' +\n      'Available options: ' + values.map(value => JSON.stringify(value)).join(', ') + '.')\n  }\n}\n","import * as all from './factoriesAny.js'\nimport { create } from './core/create.js'\n\nexport default create(all)\n","import typedFunction from 'typed-function'\nimport { deepFlatten, isLegacyFactory } from '../utils/object.js'\nimport * as emitter from './../utils/emitter.js'\nimport { importFactory } from './function/import.js'\nimport { configFactory } from './function/config.js'\nimport { factory, isFactory } from '../utils/factory.js'\nimport {\n  isAccessorNode,\n  isArray,\n  isArrayNode,\n  isAssignmentNode,\n  isBigNumber,\n  isBlockNode,\n  isBoolean,\n  isChain,\n  isCollection,\n  isComplex,\n  isConditionalNode,\n  isConstantNode,\n  isDate,\n  isDenseMatrix,\n  isFraction,\n  isFunction,\n  isFunctionAssignmentNode,\n  isFunctionNode,\n  isHelp,\n  isIndex,\n  isIndexNode,\n  isMatrix,\n  isNode,\n  isNull,\n  isNumber,\n  isObject,\n  isObjectNode,\n  isOperatorNode,\n  isParenthesisNode,\n  isRange,\n  isRangeNode,\n  isRelationalNode,\n  isRegExp,\n  isResultSet,\n  isSparseMatrix,\n  isString,\n  isSymbolNode,\n  isUndefined,\n  isUnit,\n  isBigInt\n} from '../utils/is.js'\nimport { ArgumentsError } from '../error/ArgumentsError.js'\nimport { DimensionError } from '../error/DimensionError.js'\nimport { IndexError } from '../error/IndexError.js'\nimport { DEFAULT_CONFIG } from './config.js'\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} relTol\n *                              Minimum relative difference between two\n *                              compared values, used by all comparison functions.\n *                            {number} absTol\n *                              Minimum absolute 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 */\nexport function create (factories, config) {\n  const configInternal = Object.assign({}, DEFAULT_CONFIG, config)\n\n  // simple test for ES5 support\n  if (typeof Object.create !== 'function') {\n    throw new Error('ES5 not supported by this JavaScript engine. ' +\n      'Please load the es5-shim and es5-sham library for compatibility.')\n  }\n\n  // create the mathjs instance\n  const math = emitter.mixin({\n    // only here for backward compatibility for legacy factory functions\n    isNumber,\n    isComplex,\n    isBigNumber,\n    isBigInt,\n    isFraction,\n    isUnit,\n    isString,\n    isArray,\n    isMatrix,\n    isCollection,\n    isDenseMatrix,\n    isSparseMatrix,\n    isRange,\n    isIndex,\n    isBoolean,\n    isResultSet,\n    isHelp,\n    isFunction,\n    isDate,\n    isRegExp,\n    isObject,\n    isNull,\n    isUndefined,\n\n    isAccessorNode,\n    isArrayNode,\n    isAssignmentNode,\n    isBlockNode,\n    isConditionalNode,\n    isConstantNode,\n    isFunctionAssignmentNode,\n    isFunctionNode,\n    isIndexNode,\n    isNode,\n    isObjectNode,\n    isOperatorNode,\n    isParenthesisNode,\n    isRangeNode,\n    isRelationalNode,\n    isSymbolNode,\n\n    isChain\n  })\n\n  // load config function and apply provided config\n  math.config = configFactory(configInternal, math.emit)\n\n  math.expression = {\n    transform: {},\n    mathWithTransform: {\n      config: math.config\n    }\n  }\n\n  // cached factories and instances used by function load\n  const legacyFactories = []\n  const legacyInstances = []\n\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  function load (factory) {\n    if (isFactory(factory)) {\n      return factory(math)\n    }\n\n    const firstProperty = factory[Object.keys(factory)[0]]\n    if (isFactory(firstProperty)) {\n      return firstProperty(math)\n    }\n\n    if (!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    const index = legacyFactories.indexOf(factory)\n    let instance\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      }\n\n      // append to the cache\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  const importedFactories = {}\n\n  // load the import function\n  function lazyTyped (...args) {\n    return math.typed.apply(math.typed, args)\n  }\n  lazyTyped.isTypedFunction = typedFunction.isTypedFunction\n\n  const internalImport = importFactory(lazyTyped, load, math, importedFactories)\n  math.import = internalImport\n\n  // listen for changes in config, import all functions again when changed\n  // TODO: move this listener into the import function?\n  math.on('config', () => {\n    Object.values(importedFactories).forEach(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, { override: true })\n      }\n    })\n  })\n\n  // the create function exposed on the mathjs instance is bound to\n  // the factory functions passed before\n  math.create = create.bind(null, factories)\n\n  // export factory function\n  math.factory = factory\n\n  // 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  math.import(Object.values(deepFlatten(factories)))\n\n  math.ArgumentsError = ArgumentsError\n  math.DimensionError = DimensionError\n  math.IndexError = IndexError\n\n  return math\n}\n","import Emitter from 'tiny-emitter'\n\n/**\n * Extend given object with emitter functions `on`, `off`, `once`, `emit`\n * @param {Object} obj\n * @return {Object} obj\n */\nexport function mixin (obj) {\n  // create event emitter\n  const emitter = new Emitter()\n\n  // bind methods to obj (we don't want to expose the emitter.e Array...)\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\n  return obj\n}\n","import { isBigNumber, isComplex, isFraction, isMatrix, isUnit } from '../../utils/is.js'\nimport { isFactory, stripOptionalNotation } from '../../utils/factory.js'\nimport { hasOwnProperty, lazy } from '../../utils/object.js'\nimport { ArgumentsError } from '../../error/ArgumentsError.js'\n\nexport function 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    const num = arguments.length\n    if (num !== 1 && num !== 2) {\n      throw new 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(item => flattenImports(flatValues, item))\n      } else if (typeof value === 'object') {\n        for (const name in value) {\n          if (hasOwnProperty(value, name)) {\n            flattenImports(flatValues, value[name], name)\n          }\n        }\n      } else if (isFactory(value) || name !== undefined) {\n        const flatName = isFactory(value)\n          ? isTransformFunctionFactory(value)\n            ? (value.fn + '.transform') // TODO: this is ugly\n            : value.fn\n          : name\n\n        // we allow importing the same function twice if it points to the same implementation\n        if (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    const flatValues = {}\n    flattenImports(flatValues, functions)\n\n    for (const name in flatValues) {\n      if (hasOwnProperty(flatValues, name)) {\n        // console.log('import', name)\n        const value = flatValues[name]\n\n        if (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  /**\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  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    }\n\n    // turn a plain function with a typed-function signature into a typed-function\n    if (hasTypedFunctionSignature(value)) {\n      value = typed(name, {\n        [value.signature]: value\n      })\n    }\n\n    if (typed.isTypedFunction(math[name]) && typed.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      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      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      if (allowedInExpressions(name)) {\n        math.expression.mathWithTransform[name] = value.transform\n      }\n    } else {\n      // remove existing transform\n      delete math.expression.transform[name]\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    if (allowedInExpressions(name)) {\n      math.expression.mathWithTransform[name] = math[name]\n    } else {\n      delete math.expression.mathWithTransform[name]\n    }\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  function _wrap (fn) {\n    const wrapper = function wrapper () {\n      const args = []\n      for (let i = 0, len = arguments.length; i < len; i++) {\n        const arg = arguments[i]\n        args[i] = arg && arg.valueOf()\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  /**\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  function _importFactory (factory, options, name = factory.fn) {\n    if (name.includes('.')) {\n      throw new Error('Factory name should not contain a nested path. ' +\n        'Name: ' + JSON.stringify(name))\n    }\n\n    const namespace = isTransformFunctionFactory(factory)\n      ? math.expression.transform\n      : math\n\n    const existingTransform = name in math.expression.transform\n    const existing = hasOwnProperty(namespace, name) ? namespace[name] : undefined\n\n    const resolver = function () {\n      // collect all dependencies, handle finding both functions and classes and other special cases\n      const dependencies = {}\n      factory.dependencies\n        .map(stripOptionalNotation)\n        .forEach(dependency => {\n          if (dependency.includes('.')) {\n            throw new Error('Factory dependency should not contain a nested path. ' +\n              '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') { // special case for json reviver\n            dependencies.classes = math\n          } else {\n            dependencies[dependency] = math[dependency]\n          }\n        })\n\n      const instance = /* #__PURE__ */ factory(dependencies)\n\n      if (instance && typeof instance.transform === 'function') {\n        throw new Error('Transforms cannot be attached to factory functions. ' +\n            'Please create a separate function for it with export const path = \"expression.transform\"')\n      }\n\n      if (existing === undefined || options.override) {\n        return instance\n      }\n\n      if (typed.isTypedFunction(existing) && typed.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    }\n\n    // TODO: add unit test with non-lazy factory\n    if (!factory.meta || factory.meta.lazy !== false) {\n      lazy(namespace, name, resolver)\n\n      // 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      if (existing && existingTransform) {\n        _deleteTransform(name)\n      } else {\n        if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n          lazy(math.expression.mathWithTransform, name, () => namespace[name])\n        }\n      }\n    } else {\n      namespace[name] = resolver()\n\n      // 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      if (existing && existingTransform) {\n        _deleteTransform(name)\n      } else {\n        if (isTransformFunctionFactory(factory) || factoryAllowedInExpressions(factory)) {\n          lazy(math.expression.mathWithTransform, name, () => namespace[name])\n        }\n      }\n    }\n\n    // TODO: improve factories, store a list with imports instead which can be re-played\n    importedFactories[name] = factory\n\n    math.emit('import', name, resolver)\n  }\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  function isSupportedType (object) {\n    return typeof object === 'function' ||\n        typeof object === 'number' ||\n        typeof object === 'string' ||\n        typeof object === 'boolean' ||\n        object === null ||\n        isUnit(object) ||\n        isComplex(object) ||\n        isBigNumber(object) ||\n        isFraction(object) ||\n        isMatrix(object) ||\n        Array.isArray(object)\n  }\n\n  function hasTypedFunctionSignature (fn) {\n    return typeof fn === 'function' && typeof fn.signature === 'string'\n  }\n\n  function allowedInExpressions (name) {\n    return !hasOwnProperty(unsafe, name)\n  }\n\n  function factoryAllowedInExpressions (factory) {\n    return !factory.fn.includes('.') && // FIXME: make checking on path redundant, check on meta data instead\n      !hasOwnProperty(unsafe, factory.fn) &&\n      (!factory.meta || !factory.meta.isClass)\n  }\n\n  function isTransformFunctionFactory (factory) {\n    return (factory !== undefined &&\n      factory.meta !== undefined &&\n      factory.meta.isTransformFunction === true) || false\n  }\n\n  // namespaces and functions not available in the parser for safety reasons\n  const 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}\n"],"names":["root","factory","exports","module","define","amd","this","cosh","Math","x","abs","exp","sinh","parser_exit","SyntaxError","logHypot","a","b","_a","_b","log","LN2","Complex","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","_extends","Object","assign","target","arguments","source","key","hasOwnProperty","call","defaultEscapes","$","_","formatEscapes","defaultEscapeMapFn","str","_ref","_ref$preserveFormatti","preserveFormatting","_ref$escapeMapFn","escapeMapFn","runningStr","String","result","escapes","escapeKeys","keys","_loop","specialCharFound","forEach","index","slice","naturalSort","oFxNcL","oFyNcL","sre","dre","hre","ore","s","insensitive","toLowerCase","replace","xN","split","yN","xD","parseInt","Date","yD","cLoc","numS","max","alea","xor128","xorwow","xorshift7","xor4096","tychei","sr","global","Alea","seed","n","me","mash","data","h","charCodeAt","next","s0","s1","s2","copy","f","impl","opts","xg","state","prng","int32","double","quick","XorGen","strseed","k","w","v","X","j","limit","init","push","pool","math","nodecrypto","width","startdenom","significance","overflow","mask","seedrandom","options","callback","shortseed","mixkey","flatten","entropy","tostring","out","randomBytes","Uint8Array","crypto","msCrypto","getRandomValues","e","browser","navigator","plugins","screen","autoseed","arc4","ARC4","g","S","pass","is_math_call","keylen","count","obj","depth","prop","typ","smear","stringseed","fromCharCode","apply","random","ex","self","on","name","ctx","fn","once","listener","off","emit","evtArr","len","evts","liveEvents","TinyEmitter","isCallable","tryToString","$TypeError","TypeError","argument","isConstructor","isPossiblePrototype","$String","wellKnownSymbol","create","defineProperty","UNSCOPABLES","ArrayPrototype","Array","configurable","value","charAt","unicode","isPrototypeOf","it","Prototype","isObject","toIndexedObject","toAbsoluteIndex","lengthOfArrayLike","createMethod","IS_INCLUDES","$this","el","fromIndex","O","includes","indexOf","fails","METHOD_NAME","method","aCallable","toObject","IndexedObject","REDUCE_EMPTY","IS_RIGHT","that","callbackfn","argumentsLength","memo","left","right","uncurryThis","arraySlice","sort","array","comparefn","element","middle","llength","rlength","lindex","rindex","ITERATOR","SAFE_CLOSING","called","iteratorWithReturn","done","from","error","exec","SKIP_CLOSING","ITERATION_SUPPORT","object","toString","stringSlice","TO_STRING_TAG_SUPPORT","classofRaw","TO_STRING_TAG","$Object","CORRECT_ARGUMENTS","tag","tryGet","callee","hasOwn","ownKeys","getOwnPropertyDescriptorModule","definePropertyModule","exceptions","getOwnPropertyDescriptor","DESCRIPTORS","createPropertyDescriptor","bitmap","enumerable","writable","makeBuiltIn","descriptor","get","getter","set","setter","defineGlobalProperty","simple","unsafe","nonConfigurable","nonWritable","P","document","EXISTS","createElement","firefox","IS_DENO","IS_NODE","window","Deno","version","UA","test","userAgent","Pebble","classof","process","versions","v8","webkit","createNonEnumerableProperty","defineBuiltIn","copyConstructorProperties","isForced","targetProperty","sourceProperty","TARGET","GLOBAL","STATIC","stat","dontCallGetSet","forced","sham","regexpExec","SPECIES","RegExpPrototype","RegExp","KEY","FORCED","SHAM","SYMBOL","DELEGATES_TO_SYMBOL","DELEGATES_TO_EXEC","execCalled","constructor","flags","nativeRegExpMethod","methods","nativeMethod","regexp","arg2","forceStringMethod","$exec","NATIVE_BIND","FunctionPrototype","Function","Reflect","bind","getDescriptor","PROPER","CONFIGURABLE","uncurryThisWithBind","namespace","getMethod","isNullOrUndefined","Iterators","anObject","getIteratorMethod","usingIterator","iteratorMethod","isArray","replacer","rawLength","keysLength","V","func","SUBSTITUTION_SYMBOLS","SUBSTITUTION_SYMBOLS_NO_NAMED","matched","position","captures","namedCaptures","replacement","tailPos","m","symbols","ch","capture","check","globalThis","console","getBuiltIn","propertyIsEnumerable","setPrototypeOf","dummy","Wrapper","NewTarget","NewTargetPrototype","store","functionToString","inspectSource","has","NATIVE_WEAK_MAP","shared","sharedKey","hiddenKeys","OBJECT_ALREADY_INITIALIZED","WeakMap","metadata","facade","STATE","enforce","getterFor","TYPE","type","documentAll","all","noop","construct","constructorRegExp","INCORRECT_TO_STRING","isConstructorModern","isConstructorLegacy","feature","detection","normalize","POLYFILL","NATIVE","string","MATCH","isRegExp","USE_SYMBOL_AS_UID","$Symbol","isArrayIteratorMethod","getIterator","iteratorClose","Result","stopped","ResultPrototype","iterable","unboundFunction","iterator","iterFn","step","AS_ENTRIES","IS_RECORD","IS_ITERATOR","INTERRUPTED","stop","condition","callFn","kind","innerResult","innerError","toLength","CONFIGURABLE_FUNCTION_NAME","InternalStateModule","enforceInternalState","getInternalState","join","CONFIGURABLE_LENGTH","TEMPLATE","arity","trunc","notify","toggle","node","promise","then","safeGetBuiltIn","macrotask","Queue","IS_IOS","IS_IOS_PEBBLE","IS_WEBOS_WEBKIT","MutationObserver","WebKitMutationObserver","Promise","microtask","queue","flush","parent","domain","exit","head","enter","resolve","nextTick","createTextNode","observe","characterData","add","PromiseCapability","C","reject","$$resolve","$$reject","activeXDocument","definePropertiesModule","enumBugKeys","html","documentCreateElement","PROTOTYPE","SCRIPT","IE_PROTO","EmptyConstructor","scriptTag","content","LT","NullProtoObjectViaActiveX","write","close","parentWindow","NullProtoObject","ActiveXObject","iframeDocument","iframe","JS","style","display","appendChild","src","contentWindow","open","F","Properties","V8_PROTOTYPE_DEFINE_BUG","objectKeys","defineProperties","props","IE8_DOM_DEFINE","toPropertyKey","$defineProperty","$getOwnPropertyDescriptor","ENUMERABLE","WRITABLE","Attributes","current","propertyIsEnumerableModule","internalObjectKeys","concat","getOwnPropertyNames","getOwnPropertySymbols","names","$propertyIsEnumerable","NASHORN_BUG","uncurryThisAccessor","requireObjectCoercible","aPossiblePrototype","CORRECT_SETTER","proto","__proto__","input","pref","val","valueOf","getOwnPropertyNamesModule","getOwnPropertySymbolsModule","NativePromiseConstructor","IS_BROWSER","IS_PURE","V8_VERSION","NativePromisePrototype","SUBCLASSING","NATIVE_PROMISE_REJECTION_EVENT","PromiseRejectionEvent","FORCED_PROMISE_CONSTRUCTOR","PROMISE_CONSTRUCTOR_SOURCE","GLOBAL_CORE_JS_PROMISE","FakePromise","CONSTRUCTOR","REJECTION_EVENT","newPromiseCapability","promiseCapability","checkCorrectnessOfIteration","Target","Source","tail","item","entry","R","re1","re2","regexpFlags","stickyHelpers","UNSUPPORTED_DOT_ALL","UNSUPPORTED_NCG","nativeReplace","nativeExec","patchedExec","UPDATES_LAST_INDEX_WRONG","lastIndex","UNSUPPORTED_Y","BROKEN_CARET","NPCG_INCLUDED","reCopy","group","raw","groups","sticky","charsAdded","strCopy","multiline","hasIndices","ignoreCase","dotAll","unicodeSets","regExpFlags","$RegExp","MISSED_STICKY","defineBuiltInAccessor","CONSTRUCTOR_NAME","Constructor","TAG","uid","SHARED","mode","copyright","license","aConstructor","defaultConstructor","toIntegerOrInfinity","CONVERT_TO_STRING","pos","first","second","size","codeAt","symbol","Symbol","$location","defer","channel","port","validateArgumentsLength","setImmediate","clear","clearImmediate","Dispatch","MessageChannel","counter","ONREADYSTATECHANGE","location","run","id","runner","eventListener","event","globalPostMessageDefer","postMessage","protocol","host","handler","args","now","port2","port1","onmessage","addEventListener","importScripts","removeChild","setTimeout","min","integer","number","isSymbol","ordinaryToPrimitive","TO_PRIMITIVE","exoticToPrim","toPrimitive","postfix","NATIVE_SYMBOL","passed","required","WellKnownSymbolsStore","createWellKnownSymbol","withoutSetter","$includes","addToUnscopables","$reduce","arrayMethodIsStrict","CHROME_VERSION","reduce","deletePropertyOrThrow","internalSort","FF","IE_OR_EDGE","V8","WEBKIT","nativeSort","FAILS_ON_UNDEFINED","FAILS_ON_NULL","STRICT_METHOD","STABLE_SORT","code","chr","itemsLength","items","arrayLength","getSortCompare","getReplacerFunction","$stringify","numberToString","tester","low","hi","WRONG_SYMBOLS_CONVERSION","ILL_FORMED_UNICODE","stringifyWithSymbolsFix","$replacer","fixIllFormed","offset","prev","stringify","space","newPromiseCapabilityModule","perform","iterate","capability","$promiseResolve","values","remaining","alreadyCalled","real","onRejected","Internal","OwnPromiseCapability","nativeThen","setToStringTag","setSpecies","anInstance","speciesConstructor","task","hostReportErrors","PromiseConstructorDetection","PROMISE","NATIVE_PROMISE_SUBCLASSING","getInternalPromiseState","setInternalState","PromiseConstructor","PromisePrototype","newGenericPromiseCapability","DISPATCH_EVENT","createEvent","dispatchEvent","UNHANDLED_REJECTION","isThenable","callReaction","reaction","exited","ok","fail","rejection","onHandleUnhandled","isReject","notified","reactions","onUnhandled","reason","initEvent","isUnhandled","unwrap","internalReject","internalResolve","wrapper","executor","onFulfilled","PromiseWrapper","wrap","race","capabilityReject","promiseResolve","PromiseConstructorWrapper","CHECK_WRAPPER","inheritIfRequired","getRegExpFlags","proxyAccessor","NativeRegExp","stringIndexOf","IS_NCG","CORRECT_NEW","RegExpWrapper","pattern","rawFlags","handled","thisIsRegExp","patternIsRegExp","flagsAreUndefined","rawPattern","named","brackets","ncg","groupid","groupname","handleNCG","handleDotAll","fixRegExpWellKnownSymbolLogic","advanceStringIndex","getSubstitution","regExpExec","REPLACE","REPLACE_KEEPS_$0","REGEXP_REPLACE_SUBSTITUTES_UNDEFINED_CAPTURE","maybeCallNative","UNSAFE_SUBSTITUTE","searchValue","replaceValue","rx","functionalReplace","fullUnicode","results","accumulatedResult","nextSourcePosition","replacerArgs","NativeSymbol","SymbolPrototype","description","EmptyStringDescriptionStore","SymbolWrapper","thisSymbolValue","symbolDescriptiveString","desc","notOk","undef","NOT_TYPED_FUNCTION","isPlainObject","_types","anyType","isAny","typeMap","typeList","nConversions","typed","createCount","findType","typeName","message","otherName","addTypes","types","beforeSpec","beforeIndex","newTypes","conversionsTo","affectedTypes","Map","findTypeNames","matches","filter","isTypedFunction","entity","findSignature","signature","exact","params","parseSignature","canonicalSignature","stringifyParams","signatures","_typedFunctionData","signatureMap","nParams","remainingSignatures","candidate","want","filteredSignatures","possibility","have","getParamAtIndex","restParam","hasAny","haveTypes","paramTypeSet","some","wtype","separator","map","p","parseParam","param","typeDefs","trim","paramName","typeIndex","conversion","conversionIndex","hasConversion","expandParam","matchingConversions","typeNames","knownTypes","Set","newMatch","availableConversions","newName","convertibleTypes","typeSet","rawSignature","rawParams","parsedParam","hasRestParam","last","compileTest","test0","test1","tests","compileTests","initial","varIndex","lastTest","testRestParam","getTypeSetAtIndex","isExactType","mergeExpectedParams","paramSet","createError","err","expected","_name","matchingSignatures","nextMatchingDefs","actualTypes","category","actual","lengths","maxLength","expectedLength","argTypes","getLowestTypeIndex","getLowestConversionIndex","compareParams","param1","param2","typeDiff","convDiff","compareSignatures","signature1","signature2","pars1","pars2","last1","last2","hasRest1","hasRest2","par","any1","conv1","any2","conv2","lengthCriterion","comparisons","tc","thisComparison","compileArgsPreprocessing","fnConvert","compiledConversions","compileArgConversion","fnPreprocess","conversion0","conversion1","conversions","convert","splitParams","_splitParams","paramsSoFar","resultingParams","exactTypes","arr","nextParam","conflicting","params1","params2","ii","typeSet1","typeSet2","overlap","len1","len2","restParam1","restParam2","collectResolutions","references","functionList","resolvedReferences","reference","resolution","resolveReferences","resolvedFunctions","isReferToSelf","referToSelf","isReferTo","makeReferTo","referTo","clearResolutions","isResolved","fill","leftUnresolved","nothingResolved","createTypedFunction","rawSignaturesMap","warnAgainstDeprecatedThis","signaturesMap","deprecatedThisRegex","validateDeprecatedThis","parsedParams","originalFunctions","preliminarySignatures","pp","functionIndex","conversionParams","sp","spName","every","theTypedFn","internalSignatureMap","ok0","ok1","ok2","ok3","ok4","ok5","allOk","test00","test10","test20","test30","test40","test50","test01","test11","test21","test31","test41","test51","implementation","fn0","fn1","fn2","fn3","fn4","fn5","len0","len3","len4","len5","iStart","iEnd","fns","generic","onMismatch","arg0","arg1","_onMismatch","start","end","objectOrFn","checkName","nameSoFar","Error","getObjectName","mergeSignatures","dest","sourceFunction","destFunction","saveTyped","_validateConversion","to","maybeName","allSignatures","thisName","theseSignatures","throwMismatchError","clearConversions","_findType","find","addType","beforeObjectTest","before","addConversion","override","existing","other","removeConversion","addConversions","existingConversion","findInArray","splice","tf","argList","sigs","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","loaded","__webpack_modules__","amdD","amdO","definition","o","toStringTag","nmd","paths","children","isNumber","isBigNumber","isDecimal","isBigInt","isComplex","getPrototypeOf","isFraction","isUnit","isString","isMatrix","isCollection","isDenseMatrix","isSparseMatrix","isRange","isIndex","isBoolean","isResultSet","isHelp","isFunction","isDate","isNull","isUndefined","isAccessorNode","isNode","isArrayNode","isAssignmentNode","isBlockNode","isConditionalNode","isConstantNode","rule2Node","isOperatorNode","op","isFunctionAssignmentNode","isFunctionNode","isIndexNode","isObjectNode","isParenthesisNode","isRangeNode","isRelationalNode","isSymbolNode","isChain","typeOf","isInteger","safeNumberType","numberStr","config","numberFallback","sign","log2","log10","LN10","log1p","cbrt","negate","formatNumberToBase","base","prefix","suffix","format","notation","precision","wordSize","normalizeFormatOptions","toFixed","toExponential","rounded","roundDigits","splitNumber","exponent","coefficients","newExp","missingZeros","expDiff","decimalIdx","decimals","decimalVal","toEngineering","lowerExp","_toNumberOrDefault","upperExp","zeros","dot","toPrecision","digits","toNumber","_toNumberOrThrow","splitValue","shift","unshift","pop","nearlyEqual","relTol","absTol","EPSILON","tanh","onError","defaultValue","clone","mapObject","extend","deepExtend","deepStrictEqual","deepFlatten","nestedObject","flattenedObject","_deepFlatten","lazy","valueResolver","_value","_uninitialized","property","dependencies","meta","assertAndCreate","scope","deps","properties","pickShallow","stripOptionalNotation","dependency","isOptionalDependency","missingDependencies","assertDependencies","isFactory","getSafeProperty","isSafeProperty","isSafeMethod","setSafeProperty","safeNativeProperties","safeNativeMethods","toLocaleString","ObjectWrappingMap","wrappedObject","entries","mapIterator","delete","PartitionedMap","bKeys","createEmptyMap","createMap","mapOrObject","isMap","_createTyped","typedFunction","createTyped","BigNumber","DenseMatrix","Fraction","throwNoBignumber","throwNoComplex","MAX_SAFE_INTEGER","throwNoFraction","BigInt","throwNoMatrix","matrix","usualError","sig","createResultSet","ResultSet","toJSON","mathjs","fromJSON","json","isClass","inexact","quadrant","EXP_LIMIT","MAX_DIGITS","NUMERALS","DEFAULTS","rounding","modulo","toExpNeg","toExpPos","minE","maxE","external","decimalError","invalidArgument","precisionLimitExceeded","cryptoUnavailable","mathfloor","mathpow","isBinary","isHex","isOctal","BASE","LOG_BASE","LN10_PRECISION","PI_PRECISION","digitsToString","ws","indexOfLastWord","getZeroString","checkInt32","checkRoundingDigits","rm","repeating","di","rd","convertBase","baseIn","baseOut","arrL","strL","reverse","absoluteValue","finalise","clampedTo","clamp","Ctor","gt","cmp","comparedTo","xdL","ydL","xd","yd","xs","ys","cosine","pr","sd","isZero","tinyPow","taylorSeries","times","cos2x","toLessThanHalfPi","neg","cubeRoot","rep","t3","t3plusx","divide","eq","decimalPlaces","dp","dividedBy","div","dividedToIntegerBy","divToInt","equals","greaterThan","greaterThanOrEqualTo","gte","hyperbolicCosine","one","cosh2_x","d8","hyperbolicSine","sinh2_x","d5","d16","d20","hyperbolicTangent","inverseCosine","halfPi","isNeg","getPi","inverseHyperbolicCosine","lte","ln","inverseHyperbolicSine","inverseHyperbolicTangent","wpr","xsd","inverseSine","inverseTangent","px","x2","isInt","isNegative","isPositive","isPos","lessThan","lt","lessThanOrEqualTo","logarithm","isBase10","denominator","inf","num","naturalLogarithm","getLn10","sub","xe","xLTy","getBase10Exponent","mod","q","naturalExponential","negated","carry","getPrecision","sine","sin2_x","squareRoot","tangent","tan","mul","rL","toBinary","toStringBinary","toDecimalPlaces","toDP","finiteToString","toFraction","maxD","d0","d1","d2","n0","n1","toHexadecimal","toHex","toNearest","toOctal","toPower","yn","intPow","toSignificantDigits","toSD","truncated","multiplyInteger","compare","aL","bL","subtract","logBase","more","prod","prodL","qd","rem","remL","rem0","xi","xL","yd0","yL","yz","isTruncated","roundUp","xdi","isExp","nonFiniteToString","zs","truncate","isOdd","maxOrMin","ltgt","guard","sum","c0","numerator","x1","parseDecimal","search","substring","parseOther","divisor","isFloat","Decimal","isHyperbolic","u","pi","useDefaults","defaults","ps","hypot","isDecimalInstance","Uint32Array","for","ROUND_UP","ROUND_DOWN","ROUND_CEIL","ROUND_FLOOR","ROUND_HALF_UP","ROUND_HALF_DOWN","ROUND_HALF_EVEN","ROUND_HALF_CEIL","ROUND_HALF_FLOOR","EUCLID","createBigNumberClass","curr","createComplexClass","toPolar","phi","strRe","strIm","epsilon","hasBase","InvalidParameter","newFraction","DivisionByZero","gcd","factorize","factors","p1","p2","M","A","B","D","N","NonIntegerParameter","eps","thisABS","cont","excludeWhole","whole","dec","cycLen","cycleLen","cycOff","rem1","rem2","modpow","cycleStart","createFractionClass","createRangeClass","Range","hasStart","hasEnd","hasStep","nums","diff","toArray","createMatrixClass","Matrix","storage","datatype","subset","resize","reshape","skipZeros","formatBigNumberToBase","big2","BigNumberCtor","endsWith","text","formatNumber","valueStr","formatBigNumber","looksLikeFraction","fraction","formatArray","syntax","_format","escaped","controlCharacters","escape","compareText","DimensionError","relation","stack","IndexError","arraySize","_validate","dim","dimNext","child","validate","validateIndexSourceSize","valueSize","_size","_sourceSize","sourceDim","validateIndex","isEmptyIndex","_dimensions","dimension","_data","_resize","elem","oldLen","newLen","minLen","sizes","flatArray","currentLength","newLength","product","processSizesWildcard","tmpArray2","tmpArray","sizeIndex","_reshape","processedSizes","wildCardIndex","squeeze","dims","_squeeze","unsqueeze","outer","_unsqueeze","flat","filterRegExp","identify","identifier","generalize","getArrayDataType","itemType","concatRecursive","concatDim","arrays","broadcastSizes","_len","_key","dimensions","sizeMax","checkBroadcastingRules","toSize","broadcastTo","Asize","broadcastedSize","paddedSize","arrayToStretch","sizeToStretch","dimToStretch","lruQueue","del","oldIndex","hit","nuIndex","memoize","hasher","POSITIVE_INFINITY","JSON","cache","lru","hash","newVal","maxArgumentCount","RangeError","isDimensionError","isIndexError","createDenseMatrixClass","_datatype","preprocess","_getSubmatrix","range","_setSubmatrix","submatrix","dataIndex","subIndex","_fit","newSize","changed","createDenseMatrix","getDataType","isScalar","_get","iSize","sSize","_unused","_set","indexI","sizeArray","recurse","rows","row","columns","col","diagonal","kSuper","kSub","ms","swapRows","_swapRows","vi","createClone","any","objectClone","_switch","mat","I","J","containsCollections","deepForEach","deepMap","_reduce","tran","scatter","mark","cindex","inverse","update","avalues","_values","aindex","_index","aptr","_ptr","k0","k1","createIsInteger","isIntegerNumber","bigint","isNegativeNumber","isPositiveNumber","isNaNNumber","createIsNegative","bigNearlyEqual","Unit","valueType","createIsNumeric","number | BigNumber | bigint | Fraction | boolean","Complex | Unit | string | null | undefined | Node","createHasNumericValue","isNumeric","boolean","createIsPositive","createIsZero","equalScalar","createIsNaN","createTypeOf","_typeOf","createCompareUnits","equalBase","createEqualScalar","compareUnits","complexEquals","createSparseMatrixClass","_ref2","SparseMatrix","_createFromArray","_createFromMatrix","ptr","zero","_getValueIndex","top","bottom","_insert","ins","_toArray","createSparseMatrix","density","idx","kk","mvalues","mindex","mptr","pv","_getsubset","firstDimensionRange","secondDimensionRange","firstDataIndex","firstSubIndex","secondDataIndex","secondSubIndex","_setsubset","_remove","colIndex","rowIndex","r1","c1","minRow","maxRow","minColumn","maxColumn","invoke","_map","_forEachRow","kx","ky","vx","vy","createNumber","nonDecimalNumberParts","nonDecimalWithRadixMatch","radix","integerPart","fractionalPart","getNonDecimalNumberParts","parts","makeNumberFromNonDecimalParts","wordSizeSuffixMatch","null","unit","valuelessUnit","createBigint","createString","createBoolean","lcase","createBignumber","twoPowSize","twoPowSizeSubOne","createComplex","ZERO","createFraction","createMatrix","_create","createMatrixFromFunction","createMatrixFromRows","_createArray","checkVectorTypeAndReturnLength","rowLength","vec","createMatrixFromColumns","colLength","createSplitUnit","splitUnit","n2","absNumber","addNumber","subtractNumber","multiplyNumber","unaryMinusNumber","unaryPlusNumber","cbrtNumber","cubeNumber","expNumber","expm1Number","lcmNumber","log10Number","log2Number","nthRootNumber","inv","signNumber","squareNumber","xgcdNumber","lastx","lasty","powNumber","roundNumber","createUnaryMinus","createUnaryPlus","numeric","createAbs","createApply","_apply","createAddScalar","fixPrefix","createSubtractScalar","createCbrt","unaryMinus","_cbrtComplex","third","allRoots","arg3","principal","createMatAlgo11xS0s","asize","adt","dt","cf","cvalues","cptr","createMatAlgo12xSfs","cdata","createMatAlgo14xDs","adata","_iterate","level","av","bv","cv","createCeilNumber","createCeil","matAlgo11xS0s","matAlgo12xSfs","matAlgo14xDs","ceilNumber","createCube","createExp","createExpm1","createFixNumber","createFix","fixNumber","bn","createFloorNumber","createFloor","floorNumber","createMatAlgo02xDS0","denseMatrix","sparseMatrix","bvalues","bindex","bptr","bsize","bdt","cij","createMatAlgo03xDSf","createMatAlgo05xSfSf","xa","xb","wa","wb","wai","wbi","vc","createMatAlgo13xDD","bdata","csize","broadcast","_broadcastTo","createMatrixAlgorithmSuite","matAlgo13xDD","elop","SD","DS","matrixSignatures","DenseMatrix, DenseMatrix","Array, Array","Array, DenseMatrix","DenseMatrix, Array","SS","scalar","Ds","Ss","sS","createMod","matAlgo02xDS0","matAlgo03xDSf","matAlgo05xSfSf","matrixAlgorithmSuite","createMatAlgo01xDSid","createMatAlgo04xSidSid","createMatAlgo10xSids","ArgumentsError","isArgumentsError","gcdTypes","gcdManyTypesSignature","is1d","createGcd","matAlgo01xDSid","matAlgo04xSidSid","matAlgo10xSids","Fraction, Fraction","createMatAlgo06xS0S0","createLcm","matAlgo06xS0S0","lcmTypes","lcmManySignature","lcm","createLog10","predictable","createLog2","_log2Complex","newX","createMultiplyScalar","number | Fraction | BigNumber | Complex, Unit","multiply","Unit, number | Fraction | BigNumber | Complex | Unit","createMultiply","addScalar","multiplyScalar","_validateMatrixDimensions","size1","size2","_multiplyMatrixVector","arows","acolumns","af","mf","brows","ib","vbi","ka0","ka1","ka","ia","ic","_multiplyMatrixMatrix","bcolumns","jb","kb0","kb1","kb","vbij","p0","selfMM","xsize","ysize","_multiplyVectorVector","alength","_multiplyVectorDenseMatrix","_multiplyVectorMatrix","rest","createNthRoot","complexErr","_bigNthRoot","selfDn","selfSn","selfDS","Big","createSign","complex","_isDerived","units","createSqrt","_sqrtNumber","createSquare","createSubtract","subtractScalar","createXgcd","createInvmod","xgcd","equal","smaller","invmod","createMatAlgo09xS0Sf","vb","createDotMultiply","matAlgo09xS0Sf","bitAndBigNumber","bitwise","bitNotBigNumber","prevPrec","bitOrBigNumber","negOne","xBits","yBits","xSign","ySign","decCoefficientToBinaryString","minBits","maxBits","minSign","shortLen","longLen","expFuncVal","outVal","twoPower","two","bitXor","leftShiftBigNumber","rightArithShiftBigNumber","bitAndNumber","bitNotNumber","bitOrNumber","bitXorNumber","leftShiftNumber","rightArithShiftNumber","rightLogShiftNumber","createBitAnd","bigint, bigint","createBitNot","createBitOr","createMatAlgo07xSSf","_scatter","va","createBitXor","matAlgo07xSSf","bigBitXor","createArg","createConj","conjugate","createIm","createRe","notNumber","orNumber","xorNumber","andNumber","createNot","null | undefined","createOr","createXor","createConcat","prevDim","asMatrix","matrices","_concat","createColumn","Index","_column","column","rowRange","createCross","_cross","highestDimension","xSize","ySize","createDiag","_diag","l","_createDiagonalMatrix","dm","vector","_getDiagonal","applyCallback","mappingFnName","args3","signature3","tryWithArgs","args2","args1","_err$data","argsDesc","createFilter","_filterCallback","createFlatten","flattenArray","createForEach","_forEach","forEachArray","createGetMatrixDataType","createIdentity","_identity","cols","_identityVector","minimum","createKron","_kron","createDiff","_diff","_recursive","selfAn","selfMn","_ElementDiff","obj1","obj2","obj1IsArray","obj2IsArray","arr1","arr2","_ArrayDiff","createOnes","_ones","hasBigNumbers","_normalize","noBignumber","noFraction","noMatrix","createRange","bignumber","smallerEq","larger","largerEq","_strRange","_out","_range","includeEnd","_parse","ongoing","createReshape","arrayReshape","createResize","defaultChar","_resizeString","arrayResize","createRotate","rotationMatrix","theta","_validateSize","expectedSize","actualSize","createRotationMatrix","norm","_rotationMatrix2x2","matrixV","_validateVector","_rotationMatrix3x3","storageType","minusOne","cosTheta","sinTheta","_convertToFormat","_mul","normV","vz","oneMinusC","createRow","_row","columnRange","createSize","createSqueeze","arraySqueeze","createSubset","subsetRef","subsetResult","_getObjectProperty","_getSubstring","_isScalar","indexSize","_broadcastReplacement","_setSubstring","_setObjectProperty","strLen","substr","chars","updated","createTranspose","transposeMatrix","transposed","transposedRow","_denseTranspose","_sparseTranspose","createCtranspose","transpose","conj","createZeros","_zeros","createFft","divideScalar","tau","dotDivide","_ndFft","_fft","_1dFft","_transpose","chirp","N2","xp","ichirp","fftXp","fftIchirp","fftProduct","ifftProduct","_czt","createIfft","fft","acc","createSolveODE","_rk","butcherTableau","tspan","y0","isNumOrBig","t0","isForwards","firstStep","maxStep","minStep","timeVars","tol","minDelta","maxDelta","maxIter","bp","deltaB","iter","_createOngoing","trimStep","outOfBounds","_createTrimStep","TE","delta","_rk23","_rk45","_solveODE","opt","RK23","RK45","toUpperCase","methodOptions","methodsWithQuotes","availableMethodsString","_matrixSolveODE","T","sol","function, Array, Array","function, Matrix, Matrix","function, Array, number | BigNumber | Unit","Y","function, Matrix, number | BigNumber | Unit","function, Array, number | BigNumber | Unit, Object","function, Matrix, number | BigNumber | Unit, Object","createErf","MAX_NUM","THRESH","ysq","xnum","xden","Q","erf1","erfc2","SQRPI","erfc3","createZeta","factorial","gamma","zetaNumeric","zeta","createValue","determineDigits","getRe","factor","createMode","_mode","improveErrorMessage","fnName","details","createProd","_prod","createFormat","formatString","createBin","createOct","createHex","printTemplate","createPrint","_print","template","original","createTo","Unit, Unit | string","createIsPrime","modPow","modulus","accumulator","bases","adn","createNumeric","validInputTypes","validOutputTypes","outputType","inputType","createDivideScalar","Unit, number | Complex | Fraction | BigNumber | Unit","number | Fraction | Complex | BigNumber, Unit","divideInto","createPow","identity","_pow","_powArray","_powMatrix","yFrac","yNum","NO_INT","createRound","toExponent","xEpsilon","epsilonExponent","_n","valueless","toNumeric","createLog","logNumber","createLog1p","_log1p","_log1pComplex","xRe1p","createNthRoots","_calculateExactResult","_nthComplexRoots","aIsNumeric","roots","halfPiFactor","createDotPow","powScalarSignatures","powScalar","createDotDivide","createSolveValidation","mSize","bSize","createLsolve","solveValidation","bj","vjj","jValues","jIndices","firstIndex","xj","_sparseForwardSubstitution","_denseForwardSubstitution","mdata","createUsolve","_sparseBackwardSubstitution","_denseBackwardSubstitution","createLsolveAll","b_","L","iValues","iIndices","Mii","bNew","createUsolveAll","createMatAlgo08xS0Sid","createUseMatrixForArrayScalar","selfDB","selfnD","selfBD","createLeftShift","matAlgo08xS0Sid","useMatrixForArrayScalar","createRightArithShift","createRightLogShift","createAnd","not","createCompare","createCompareNumber","createCompareNatural","compareBooleans","_compareNatural","typeX","typeY","matTypes","compareMatricesAndArrays","compareComplexNumbers","compareArrays","formatUnits","compareNatural","keysX","keysY","compareObjects","_compareText","createCompareText","createEqual","createEqualNumber","createEqualText","createSmaller","createSmallerNumber","boolean, boolean","createSmallerEq","createSmallerEqNumber","createLarger","createLargerNumber","createLargerEq","createLargerEqNumber","createDeepEqual","_deepEqual","createUnequal","createUnequalNumber","createPartitionSelect","asc","_partitionSelect","quickSelect","pivot","createSort","compareAsc","compareDesc","_arrayIsVector","_matrixIsVector","_comparator","order","createMax","_max","_largest","createMin","_min","_smallest","createImmutableDenseMatrixClass","ImmutableDenseMatrix","isImmutableDenseMatrix","createIndexClass","getMatrixDataType","ranges","argIsArray","argIsMatrix","sourceSize","_createImmutableMatrix","_booleansArrayToNumbersForIndex","isObjectProperty","getObjectProperty","strings","booleanArrayIndex","indexOfNumbers","bool","createFibonacciHeapClass","oneOverLogPhi","FibonacciHeap","_minimum","_cut","degree","_cascadingCut","isFibonacciHeap","insert","isEmpty","extractMinimum","numberOfChildren","tempRight","numRoots","_linkNodes","_findMinimumNode","remove","_decreaseKey","createSpaClass","Spa","_heap","isSpa","accumulate","heap","nodes","swap","nodei","nodej","createBigNumberE","createBigNumberPhi","createBigNumberPi","createBigNumberTau","createUnitClass","fix","skipAutomaticSimplification","BASE_DIMENSIONS","skipWhitespace","isDigit","revert","parseNumber","isDigitDot","tentativeNumber","tentativeIndex","parseUnit","unitName","isValidAlpha","firstC","parseCharacter","toFind","powerMultiplierCurrent","expectingUnit","powerMultiplierStack","powerMultiplierStackProduct","uStr","oldC","_findUnit","power","baseDim","UNIT_SYSTEMS","auto","allowNoUnits","_getNumberConverter","unitValue","unitPrefixValue","unitPower","_denormalize","prefixValue","UNITS","prefixes","prefixLen","prefixName","getNumericIfUnitless","BASE_UNITS","NONE","isValuelessUnit","_other","inverted","valThis","valOther","_numberConverter","nominalOffset","unitOffset","W","thisUnitValue","thisNominalOffset","thisUnitOffset","otherUnitValue","otherNominalOffset","otherUnitOffset","_json$unit","simplify","proposedUnitList","matchingBase","currentUnitSystem","matchingUnit","missingBaseDim","toSI","si","strNum","strDen","nNum","nDen","simp","isImaginary","VAR","VA","_bestPrefix","unitStr","absValue","absUnitValue","bestPrefix","bestDiff","scientific","xNumeric","xRounded","xFixed","testSum","PREFIXES","SHORT","da","G","Z","LONG","deca","hecto","kilo","mega","giga","tera","peta","exa","zetta","yotta","ronna","quetta","deci","centi","milli","micro","nano","pico","femto","atto","zepto","yocto","ronto","quecto","SQUARED","CUBIC","BINARY_SHORT_SI","BINARY_SHORT_IEC","Ki","Mi","Gi","Ti","Pi","Ei","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","ANGLE","BIT","UNIT_NONE","meter","inch","foot","yard","mile","link","rod","chain","angstrom","in","ft","mi","li","mil","m2","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","gram","ton","tonne","grain","dram","ounce","poundmass","hundredweight","stick","stone","gr","dr","oz","lbm","cwt","sec","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","psi","atm","bar","torr","mmHg","mmH2O","cmH2O","coulomb","farad","volt","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","fldr","fluiddrams","floz","fluidounces","gi","gills","cp","cups","pt","pints","qt","quarts","gal","gallons","bbl","beerbarrels","obl","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","mins","hours","hr","hrs","days","weeks","months","years","decades","centuries","millennia","radians","degrees","gradians","cycles","arcsecond","arcseconds","arcminute","arcminutes","BTUs","watts","joules","amperes","amps","amp","coulombs","volts","ohms","farads","webers","teslas","electronvolts","moles","bit","byte","calculateAngleValues","createPi","cgs","us","setUnitSystem","getUnitSystem","typeConverters","alias","createUnit","deleteUnit","aliases","lastUnit","createUnitSingle","assertUnitNameIsValid","baseName","defUnit","newUnit","anyMatch","newBaseUnit","aliasName","createUnitFunction","createSparse","createCreateUnit","def","createAcos","acoshNumber","acotNumber","acothNumber","acscNumber","acschNumber","xInv","asecNumber","asechNumber","asinhNumber","atanhNumber","cotNumber","cothNumber","cscNumber","cschNumber","secNumber","sechNumber","sinhNumber","createAcosh","createAcot","acot","createAcoth","acoth","createAcsc","acsc","createAcsch","acsch","createAsec","asec","createAsech","asech","createAsin","createAsinh","createAtan","createAtan2","BigNumber, BigNumber","createAtanh","createTrigUnit","createCos","trigUnit","createCosh","coshNumber","createCot","cot","createCoth","coth","createCsc","csc","createCsch","csch","createSec","createSech","sech","createSin","createSinh","createTan","createTanh","_tanh","createSetCartesian","a1","a2","b1","b2","createSetDifference","inb2","createSetDistinct","createSetIntersect","createSetIsSubset","createSetMultiplicity","createSetPowerset","_subset","_sort","bitarray","createSetSize","unique","createSetSymDifference","setDifference","createSetUnion","setIntersect","setSymDifference","createAdd","createHypot","_hypot","largest","createNorm","ctranspose","eigs","_norm","sizeX","pinf","_vectorNormPlusInfinity","NEGATIVE_INFINITY","ninf","_vectorNormMinusInfinity","_vectorNorm","maxc","cj","_matrixNormOne","maxr","ri","_matrixNormInfinity","fro","_matrixNormFrobenius","tx","squaredX","eigenVals","rho","_matrixNormTwo","_matrixNorm","createDot","_validateDim","aIsColumn","bIsColumn","xindex","xvalues","yindex","yvalues","xLen","yLen","createTrace","_denseTrace","createIndex","keywords","createNode","mathWithTransform","evaluate","compile","expr","_compile","_validateScope","argNames","_ifNode","traverse","_traverse","path","transform","_transform","cloneDeep","customString","_getCustomString","_toString","toHTML","_toHTML","toTex","_toTex","getIdentifier","getContent","_typeof","_defineProperty","errorTransform","accessFactory","createAccessorNode","Node","access","needParenthesis","AccessorNode","super","evalObject","evalIndex","context","createArrayNode","ArrayNode","evalItems","evalItem","itemsToTex","nested","mixedItems","itemsFormRow","itemSep","itemsTex","AssignmentNode","FunctionAssignmentNode","ConditionalNode","latexLeftParens","latexRightParens","latexParens","associativity","associativeWith","RelationalNode","RangeNode","unwrapParen","_node","parenthesis","getPrecedence","implicit","precedence","leftArg","getAssociativity","isAssociativeWith","nodeA","nodeB","identifierA","identifierB","createAssignmentNode","assignFactory","exprPrecedence","evalValue","childObject","evalParentObject","parentProp","evalParentIndex","parentIndex","createBlockNode","BlockNode","blocks","block","visible","evalBlocks","createConditionalNode","trueExpr","falseExpr","evalCondition","evalTrueExpr","evalFalseExpr","testCondition","conditionPrecedence","truePrecedence","falsePrecedence","latexSymbols","Alpha","alpha","Beta","beta","Gamma","Delta","Epsilon","varepsilon","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","true","false","Inf","infinity","oo","lim","latexOperators","dotPow","unaryPlus","bitNot","dotMultiply","leftShift","rightArithShift","rightLogShift","unequal","bitAnd","bitOr","and","xor","or","latexFunctions","cube","nthRoot","nthRoots","square","bellNumbers","catalan","stirlingS2","cross","det","expm","pinv","sqrtm","trace","combinations","combinationsWithRep","lgamma","erf","variance","sparse","latexUnits","escapeLatex","escapeLatexLib","toSymbol","createConstantNode","ConstantNode","toLatex","createFunctionAssignmentNode","paramNames","childArgNames","evalExpr","childArgs","createIndexNode","IndexNode","dotNotation","evalDimensions","_evalDimension","evalDimension","createObjectNode","ObjectNode","evalEntries","stringifiedKey","parsedKey","createSubScope","parentScope","createOperatorNode","startsWithConstant","curNode","calculateNecessaryParentheses","latex","operandPrecedence","operandIdentifier","rootIdentifier","lhsParens","lhsPrecedence","assocWithLhs","rhsParens","rhsPrecedence","assocWithRhs","lhsIdentifier","rhsIdentifier","argPrecedence","assocWithArg","argAssociativity","OperatorNode","isPercentage","evalArgs","rawArgs","evalArg0","evalArg1","evalArg","isUnary","parens","assoc","operand","opIsNamed","lhs","rhs","stringifiedArgs","lhsTex","rhsTex","texifiedArgs","createParenthesisNode","ParenthesisNode","createRangeNode","startPrecedence","stepPrecedence","endPrecedence","needsEnd","evalStart","evalEnd","evalStep","createRelationalNode","operatorMap","conditionals","compiled","evalLhs","evalRhs","condFn","paramStrings","paramPrecedence","createSymbolNode","SymbolNode","onUndefinedSymbol","createFunctionNode","_FunctionNode","strin","expandTemplate","regex","inputPos","ReferenceError","FunctionNode","getSafeMethod","fnExpr","evalFn","isRaw","resolveFn","onUndefinedFunction","customTex","latexConverter","customToTex","createParse","expression","parseStart","expressions","parseMultiple","extraNodes","TOKENTYPE","NULL","DELIMITER","NUMBER","UNKNOWN","DELIMITERS","NAMED_DELIMITERS","CONSTANTS","NUMERIC_CONSTANTS","ESCAPE_CHARACTERS","currentString","currentCharacter","prevCharacter","nextCharacter","getToken","tokenType","token","comment","isWhitespace","nestingLevel","c2","c3","isHexDigit","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","parseModulusPercentage","tokenStates","parseUnary","CustomNode","parseAccessors","parseStringToken","parseRow","numericType","parseEnd","parseParentheses","parseObject","parseMatrix","parseString","parseSymbol","parseCustomNodes","parseLeftHandOperators","parsePow","quote","char","escapeChar","cPrev","cNext","isValidLatinOrGreek","isValidMathSymbol","high","createCompile","createEvaluate","createParserClass","Parser","isParser","getAll","getAllAsMap","createParser","createLup","_denseLUP","lvalues","lptr","lsize","uvalues","uindex","uptr","usize","pvCo","pvOc","swapIndeces","spa","vkj","vik","pabsv","absv","U","_sparseLUP","ldata","udata","vij","createQr","_denseQR","_sparseQR","_denseQRimpl","Qdata","Rdata","sgn","conjSgn","alphaSquared","u1","csTdfs","post","csFlip","createCsAmd","lemax","dense","cm","at","tindex","tptr","_createTargetMatrix","nz","csFkeep","cnz","nv","elen","hhead","k2","pj","nvi","pk","eln","pn","_wclear","_initializeQuotientGraph","nel","_initializeDegreeLists","mindeg","elenk","nvk","dk","pk1","pk2","wnvi","dext","p3","p4","nvj","jlast","csLeaf","maxfirst","prevleaf","ancestor","sparent","jleaf","jprev","createCsCounts","ata","colcount","createCsSqr","csAmd","csCounts","qr","csPermute","inext","csEtree","csPost","leftmost","nque","lnz","pa","_vcount","unz","csMarked","csMark","csUnflip","csDfs","jnew","createCsSpsolve","lo","gvalues","gindex","gptr","gsize","csReach","createCsLu","csSpsolve","ipiv","xabs","createSlu","csSqr","csLu","threshold","csIpvec","createLusolve","lup","slu","usolve","lsolve","_lusolve","_toMatrix","createPolynomialRoot","number|Complex, ...number|Complex","constant","restCoeffs","coeffs","denom","discriminant","D0_1","D0_2","D1_1","D1_2","Delta0","Delta1","discriminant1","discriminant2","Ccubed","createHelpClass","Help","doc","examples","configChanged","originalConfig","newConfig","mayThrow","seealso","createChainClass","Chain","createLazyProxy","resolver","chainify","sigObject","createProxy","excludedNames","docs","classes","eDocs","piDocs","embeddedDocs","LOG2E","LOG10E","SQRT1_2","SQRT2","speedOfLight","gravitationConstant","planckConstant","reducedPlanckConstant","magneticConstant","electricConstant","vacuumImpedance","elementaryCharge","bohrMagneton","conductanceQuantum","inverseConductanceQuantum","magneticFluxQuantum","nuclearMagneton","klitzing","bohrRadius","classicalElectronRadius","electronMass","fermiCoupling","fineStructure","hartreeEnergy","protonMass","deuteronMass","neutronMass","quantumOfCirculation","rydberg","thomsonCrossSection","weakMixingAngle","efimovFactor","atomicMass","avogadro","boltzmann","faraday","firstRadiation","loschmidt","gasConstant","molarPlanckConstant","molarVolume","sackurTetrode","secondRadiation","stefanBoltzmann","wienDisplacement","molarMass","molarMassC12","gravity","planckLength","planckMass","planckTime","planckCharge","planckTemperature","derivative","lsolveAll","lusolve","leafCount","polynomialRoot","simplifyConstant","simplifyCore","symbolicEqual","rationalize","usolveAll","composition","import","help","distance","intersect","diag","kron","matrixFromFunction","matrixFromRows","matrixFromColumns","ones","partitionSelect","rotate","ifft","sylvester","schur","lyap","solveODE","kldivergence","multinomial","permutations","pickRandom","randomInt","deepEqual","equalText","setCartesian","setDistinct","setIsSubset","setMultiplicity","setPowerset","setSize","setUnion","zpk2tf","freqz","cumsum","mad","mean","median","quantileSeq","std","corr","bin","oct","hex","hasNumericValue","isPrime","print","createHelp","searchName","searchText","createChain","createDet","rowIndices","k_","_k","piv","piv_","i_","_det","createInv","_inv","ABig","rBig","Ac","Bc","Ar","Br","createPinv","_isZeros","_pinv","rref","lead","_isZero","_rref","_rankFact","Cpinv","Fpinv","createEigs","doRealSymmetric","getTheta","aii","ajj","aij","getThetaBig","Sij1","Sij","Ski","Skj","Sij1Big","x1Big","Hij","Aki","Akj","csHij","Aii","Ajj","getAij","Mij","maxMij","maxIJ","getAijBig","sorting","computeVectors","vecs","minID","eigenvectors","prec","e0","Vab","diagBig","createRealSymmetric","doComplexEigs","eigenvalues2x2","trA","detA","jordanBase2x2","l1","l2","big","cplx","na","nd","inflateMatrix","inverseIterate","orthog","largeNum","randomOrthogonalVector","orthogonalComplement","vectorShape","findVectors","realzero","realone","radixSq","Rdiag","colNorm","rowNorm","rowDivRadix","rowMulRadix","balance","maxIndex","tmp1","tmp2","tmp3","reduceToHessenberg","lambdas","Sdiag","Qtotal","Qpartial","lastConvergenceBefore","ll","vectors","blockDiag","iterateUntilTriangular","Cinv","uniqueValues","multiplicities","solutions","approxVec","correction","findEigenvectors","createComplexEigs","doEigs","Array, Object","matricize","useOpts","_opts$precision","isReal","coerceReal","isSymmetric","coerceTypes","computeValuesAndVectors","hasNumber","hasBig","hasComplex","warn","createExpm","infNorm","rowSum","infinityNorm","errorEstimate","findParams","Apos","AposToI","alternate","qfac","twoqfac","twoqp1fac","createSqrtm","_tolerance","_denmanBeavers","iterations","Yk","createSylvester","_sylvester","sA","sB","hc","RHS","gkk","gmk","gkm","gmm","LHS","yAux","createSchur","_schur","A0","QR","createLyap","createDivide","createDistance","_2d","xCoeff","yCoeff","_distancePointLine2D","_objectToArray","lineTwoPtY","lineOnePtY","lineOnePtX","lineTwoPtX","pointX","pointY","_3d","_parametricLine","_distancePointLine3D","_containsOnlyNumbers","_euclideanDistance","xCoeffLine","yCoeffLine","pointZ","x0","z0","pointOneX","pointOneY","pointTwoX","pointTwoY","pointOneZ","pointTwoZ","_isNumber","aI","_pairwise","pointA","pointB","_distancePairwise","den","vectorSize","createIntersect","_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","add1","add2","add3","createSum","_sum","createCumSum","_cumsum","_ncumSumDim","_cumsummap","sums","_cumsumDimensional","initialValue","createMean","_mean","createMedian","_median","mid","middle2","createMad","_mad","med","DEFAULT_NORMALIZATION","createVariance","_var","_varDim","normalization","createQuantileSeq","Array | Matrix, number | BigNumber","_quantileSeqProbNumber","Array | Matrix, number | BigNumber, number","prob","_quantileSeqDim","Array | Matrix, number | BigNumber, boolean, number","sorted","Array | Matrix, Array | Matrix","_quantileSeqProbCollection","Array | Matrix, Array | Matrix, number","Array | Matrix, Array | Matrix, boolean, number","probOrN","probArr","dataArr","_quantileSeq","nPlusOne","probOrNArr","fracPart","createStd","_std","createCorr","_corr","correlations","correlation","sumX","sumY","sumXY","sumXSquare","sumYSquare","half","combinationsNumber","nMinusk","answer","nextdivisor","lastdivisor","nextnumerator","createCombinations","isPositiveInteger","createCombinationsWithRep","nMinusOne","gammaNumber","twoN","threeN","fourN","fiveN","gammaP","gammaG","lnSqrt2PI","lgammaSeries","lgammaNumber","lgammaN","createGamma","gammaComplex","gammaPval","twoPiSqrt","tpow","expt","bigFactorial","createLgamma","lgammaComplex","lgammaStirling","lgammaRecurrence","leftPart","rz","rzz","rightPart","signflips","sb","shiftprod","nsb","createFactorial","createKldivergence","_kldiv","plength","qlength","qnorm","pnorm","createMultinomial","ai","createPermutations","singletonRandom","createRng","randomSeed","createPickRandom","rng","possibles","_pickRandom","weights","elementWise","single","totalWeights","pick","randKey","randomMatrix","createRandom","_random","number, number","_randomMatrix","Array | Matrix, number","Array | Matrix, number, number","createRandomInt","_randomInt","_randomIntMatrix","createStirlingS2","smallCache","bigCache","make","nn","nk","createBellNumbers","createCatalan","createComposition","createLeafCount","countLeaves","isNumericNode","isConstantExpression","createUtil","defaultName","defaultContext","trivial","total","commutative","associative","paren","defaultF","hasProperty","nodeOrName","isAssociative","allChildren","findChildren","createMakeNodeFunction","isCommutative","mergeContext","primary","secondary","merged","unflattenr","makeNode","curnode","unflattenl","realContext","positiveContext","createSimplify","_simplify","Node, Map","Node, Map, Object","removeParens","SUPPORTED_CONSTANTS","_canonicalizeRule","ruleObject","newRule","lr","nonCommutative","leftExpandsym","_getExpandPlaceholderSymbol","expandsym","expanded","expandedNC1","expandedNC2","rules","assuming","repeat","imposeContext","addition","_lastsym","debug","consoleDebug","ruleSet","rule","ruleType","_buildRules","visited","laststr","rulestr","applyRule","newstr","mapRule","resNodes","newNode","mergedContext","newArgs","newContent","newItems","newObj","newIndex","newDims","newProps","repl","_ruleMatch","placeholders","mergeMatch","match1","match2","_exactMatch","combineChildMatches","list1","list2","i1","i2","isSplit","splits","rightArgs","getSplits","splitMatches","matchSet","childMatches","childMatch","leftMatch","rightMatch","sets","uniqueSets","mergeChildMatches","isVariableNode","createSimplifyConstant","_ensureNode","foldFraction","_removeFractions","thing","_eval","fnname","ignore","_toNumber","_toNode","vn","unaryMinusNode","_exactFraction","exactFractions","fractionsLimit","foldOp","reduction","sofar","ignoreandcontinue","newtree","sz","section","consts","vars","remainingDims","tryItems","fromItems","_foldAccessor","foldItems","foldProps","createSimplifyCore","node0","node1","nodeT","nodeF","isAlwaysBoolean","_simplifyCore","nodeToSimplify","simpChild","childCount","getOperator","seclast","a0","finish","createResolve","_resolve","within","variables","nextWithin","Node, Object","selfAM","createSymbolicEqual","_symbolicEqual","e1","e2","simplified","createDerivative","plainDerivative","variable","constNodes","constTag","_derivative","deriv","_derivTex","varName","isConst","funcDerivative","negative","chainDerivative","constantTerms","nonConstantTerms","nonConstantNode","argOuter","argInner","powMinusOne","createRationalize","_rationalize","detailed","setRules","oldRules","rulesFirst","rulesSucDiv","firstRules","distrDivRules","sucDivRules","firstRulesAgain","finalRules","rulesRationalize","polyRet","extended","oper","recPoly","tp","retFunc","polynomial","nVars","noExactFractions","withExactFractions","sBefore","expandPower","eDistrDiv","redoInic","retRationalize","polyToCanonical","Node, boolean","indParent","internal","does","nEsqTopo","nDirTopo","maxExpo","varname","recurPol","noPai","noFil","fire","cte","valor","no","n3","createZpk2tf","_zpk2tf","_multiply","pole","createFreqz","_freqz","createBins","_w","sumNum","sumDen","bins","createReviver","createReplacer","createTrue","createFalse","createNull","createInfinity","recreateFactory","createNaN","_ref3","createTau","_ref4","createE","_ref5","createPhi","_ref6","createLN2","_ref7","createLN10","_ref8","createLOG2E","_ref9","createLOG10E","_ref10","createSQRT1_2","_ref11","createSQRT2","_ref12","createI","_ref13","createUppercasePi","_ref14","createUppercaseE","_ref15","createVersion","recreateOnConfigChange","createSpeedOfLight","unitFactory","createGravitationConstant","createPlanckConstant","createReducedPlanckConstant","createMagneticConstant","createElectricConstant","createVacuumImpedance","createCoulomb","createElementaryCharge","createBohrMagneton","createConductanceQuantum","createInverseConductanceQuantum","createMagneticFluxQuantum","createNuclearMagneton","createKlitzing","createBohrRadius","createClassicalElectronRadius","createElectronMass","createFermiCoupling","createFineStructure","numberFactory","createHartreeEnergy","createProtonMass","createDeuteronMass","createNeutronMass","createQuantumOfCirculation","createRydberg","createThomsonCrossSection","createWeakMixingAngle","createEfimovFactor","createAtomicMass","createAvogadro","createBoltzmann","createFaraday","createFirstRadiation","createLoschmidt","createGasConstant","createMolarPlanckConstant","createMolarVolume","createSackurTetrode","createSecondRadiation","createStefanBoltzmann","createWienDisplacement","createMolarMass","createMolarMassC12","createGravity","createPlanckLength","createPlanckMass","createPlanckTime","createPlanckCharge","createPlanckTemperature","createApplyTransform","isTransformFunction","createColumnTransform","compileInlineExpression","argsScope","subScope","createFilterTransform","filterTransform","_filter","createForEachTransform","forEachTransform","createIndexTransform","isSet","createMapTransform","mapTransform","orig","lastDimToZeroBase","createMaxTransform","createMeanTransform","createMinTransform","createRangeTransform","createRowTransform","createSubsetTransform","createConcatTransform","createDiffTransform","createStdTransform","createSumTransform","createQuantileSeqTransform","dimToZeroBase","createCumSumTransform","createVarianceTransform","createPrintTransform","_convertTemplateToZeroBasedIndex","part","createAndTransform","andTransform","condition1","condition2","createOrTransform","orTransform","createBitAndTransform","bitAndTransform","createBitOrTransform","bitOrTransform","DEFAULT_CONFIG","MATRIX_OPTIONS","NUMBER_OPTIONS","configFactory","_config","optionsFix","validateOption","changes","factories","configInternal","emitter","Emitter","importedFactories","lazyTyped","internalImport","load","_import","_wrap","_importTransform","silent","allowedInExpressions","_deleteTransform","_importFactory","isTransformFunctionFactory","existingTransform","instance","factoryAllowedInExpressions","functions","flatValues","flattenImports","flatName","importFactory"],"sourceRoot":""}
\ No newline at end of file
diff --git a/src/imports/math.min.js b/src/imports/math.min.js
deleted file mode 100644 (file)
index dc0b09a..0000000
+++ /dev/null
@@ -1,3 +0,0 @@
-!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.math=t():e.math=t()}(this,()=>{var r={5716:function(e,t){var r;!function(){"use strict";function u(){throw SyntaxError("Invalid Param")}var n=Math.cosh||function(e){return Math.abs(e)<1e-9?1-e:.5*(Math.exp(e)+Math.exp(-e))},i=Math.sinh||function(e){return Math.abs(e)<1e-9?e:.5*(Math.exp(e)-Math.exp(-e))};function o(e,t){var r=Math.abs(e),n=Math.abs(t);return 0===e?Math.log(n):0===t?Math.log(r):r<3e3&&n<3e3?.5*Math.log(e*e+t*t):(e/=2,t/=2,.5*Math.log(e*e+t*t)+Math.LN2)}function c(e,t){if(!(this instanceof c))return new c(e,t);e=function(e,t){var r={re:0,im:0};if(null==e)r.re=r.im=0;else if(void 0!==t)r.re=e,r.im=t;else switch(typeof e){case"object":if("im"in e&&"re"in e)r.re=e.re,r.im=e.im;else if("abs"in e&&"arg"in e){if(!Number.isFinite(e.abs)&&Number.isFinite(e.arg))return c.INFINITY;r.re=e.abs*Math.cos(e.arg),r.im=e.abs*Math.sin(e.arg)}else if("r"in e&&"phi"in e){if(!Number.isFinite(e.r)&&Number.isFinite(e.phi))return c.INFINITY;r.re=e.r*Math.cos(e.phi),r.im=e.r*Math.sin(e.phi)}else 2===e.length?(r.re=e[0],r.im=e[1]):u();break;case"string":r.im=r.re=0;var n=e.match(/\d+\.?\d*e[+-]?\d+|\d+\.?\d*|\.\d+|./g),i=1,a=0;null===n&&u();for(var o=0;o<n.length;o++){var s=n[o];" "!==s&&"\t"!==s&&"\n"!==s&&("+"===s?i++:"-"===s?a++:i=a=("i"===s||"I"===s?(i+a===0&&u()," "===n[o+1]||isNaN(n[o+1])?r.im+=parseFloat((a%2?"-":"")+"1"):(r.im+=parseFloat((a%2?"-":"")+n[o+1]),o++)):(i+a!==0&&!isNaN(s)||u(),"i"===n[o+1]||"I"===n[o+1]?(r.im+=parseFloat((a%2?"-":"")+s),o++):r.re+=parseFloat((a%2?"-":"")+s)),0))}0<i+a&&u();break;case"number":r.im=0,r.re=e;break;default:u()}return isNaN(r.re)||isNaN(r.im),r}(e,t);this.re=e.re,this.im=e.im}c.prototype={re:0,im:0,sign:function(){var e=this.abs();return new c(this.re/e,this.im/e)},add:function(e,t){e=new c(e,t);return this.isInfinite()&&e.isInfinite()?c.NAN:this.isInfinite()||e.isInfinite()?c.INFINITY:new c(this.re+e.re,this.im+e.im)},sub:function(e,t){e=new c(e,t);return this.isInfinite()&&e.isInfinite()?c.NAN:this.isInfinite()||e.isInfinite()?c.INFINITY:new c(this.re-e.re,this.im-e.im)},mul:function(e,t){e=new c(e,t);return this.isInfinite()&&e.isZero()||this.isZero()&&e.isInfinite()?c.NAN:this.isInfinite()||e.isInfinite()?c.INFINITY:0===e.im&&0===this.im?new c(this.re*e.re,0):new c(this.re*e.re-this.im*e.im,this.re*e.im+this.im*e.re)},div:function(e,t){var r=new c(e,t);if(this.isZero()&&r.isZero()||this.isInfinite()&&r.isInfinite())return c.NAN;if(this.isInfinite()||r.isZero())return c.INFINITY;if(this.isZero()||r.isInfinite())return c.ZERO;e=this.re,t=this.im;var n,i,a=r.re,r=r.im;return 0===r?new c(e/a,t/a):Math.abs(a)<Math.abs(r)?new c((e*(i=a/r)+t)/(n=a*i+r),(t*i-e)/n):new c((e+t*(i=r/a))/(n=r*i+a),(t-e*i)/n)},pow:function(e,t){var r=new c(e,t);if(e=this.re,t=this.im,r.isZero())return c.ONE;if(0===r.im){if(0===t&&0<e)return new c(Math.pow(e,r.re),0);if(0===e)switch((r.re%4+4)%4){case 0:return new c(Math.pow(t,r.re),0);case 1:return new c(0,Math.pow(t,r.re));case 2:return new c(-Math.pow(t,r.re),0);case 3:return new c(0,-Math.pow(t,r.re))}}if(0===e&&0===t&&0<r.re&&0<=r.im)return c.ZERO;var n=Math.atan2(t,e),i=o(e,t);return e=Math.exp(r.re*i-r.im*n),t=r.im*i+r.re*n,new c(e*Math.cos(t),e*Math.sin(t))},sqrt:function(){var e,t=this.re,r=this.im,n=this.abs();if(0<=t){if(0===r)return new c(Math.sqrt(t),0);e=.5*Math.sqrt(2*(n+t))}else e=Math.abs(r)/Math.sqrt(2*(n-t));return n=t<=0?.5*Math.sqrt(2*(n-t)):Math.abs(r)/Math.sqrt(2*(n+t)),new c(e,r<0?-n:n)},exp:function(){var e=Math.exp(this.re);return this.im,new c(e*Math.cos(this.im),e*Math.sin(this.im))},expm1:function(){var e=this.re,t=this.im;return new c(Math.expm1(e)*Math.cos(t)+function(e){var t=Math.PI/4;if(e<-t||t<e)return Math.cos(e)-1;t=e*e;return t*(t*(t*(t*(t*(t*(t*(t/20922789888e3-1/87178291200)+1/479001600)-1/3628800)+1/40320)-1/720)+1/24)-.5)}(t),Math.exp(e)*Math.sin(t))},log:function(){var e=this.re,t=this.im;return new c(o(e,t),Math.atan2(t,e))},abs:function(){return e=this.re,t=this.im,r=Math.abs(e),n=Math.abs(t),r<3e3&&n<3e3?Math.sqrt(r*r+n*n):(n=r<n?(r=n,e/t):t/e,r*Math.sqrt(1+n*n));var e,t,r,n},arg:function(){return Math.atan2(this.im,this.re)},sin:function(){var e=this.re,t=this.im;return new c(Math.sin(e)*n(t),Math.cos(e)*i(t))},cos:function(){var e=this.re,t=this.im;return new c(Math.cos(e)*n(t),-Math.sin(e)*i(t))},tan:function(){var e=2*this.re,t=2*this.im,r=Math.cos(e)+n(t);return new c(Math.sin(e)/r,i(t)/r)},cot:function(){var e=2*this.re,t=2*this.im,r=Math.cos(e)-n(t);return new c(-Math.sin(e)/r,i(t)/r)},sec:function(){var e=this.re,t=this.im,r=.5*n(2*t)+.5*Math.cos(2*e);return new c(Math.cos(e)*n(t)/r,Math.sin(e)*i(t)/r)},csc:function(){var e=this.re,t=this.im,r=.5*n(2*t)-.5*Math.cos(2*e);return new c(Math.sin(e)*n(t)/r,-Math.cos(e)*i(t)/r)},asin:function(){var e=this.re,t=this.im,r=new c(t*t-e*e+1,-2*e*t).sqrt(),t=new c(r.re-t,r.im+e).log();return new c(t.im,-t.re)},acos:function(){var e=this.re,t=this.im,r=new c(t*t-e*e+1,-2*e*t).sqrt(),t=new c(r.re-t,r.im+e).log();return new c(Math.PI/2-t.im,t.re)},atan:function(){var e=this.re,t=this.im;if(0===e){if(1===t)return new c(0,1/0);if(-1===t)return new c(0,-1/0)}var r=e*e+(1-t)*(1-t),t=new c((1-t*t-e*e)/r,-2*e/r).log();return new c(-.5*t.im,.5*t.re)},acot:function(){var e=this.re,t=this.im;if(0===t)return new c(Math.atan2(1,e),0);var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).atan()},asec:function(){var e=this.re,t=this.im;if(0===e&&0===t)return new c(0,1/0);var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).acos()},acsc:function(){var e=this.re,t=this.im;if(0===e&&0===t)return new c(Math.PI/2,1/0);var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).asin()},sinh:function(){var e=this.re,t=this.im;return new c(i(e)*Math.cos(t),n(e)*Math.sin(t))},cosh:function(){var e=this.re,t=this.im;return new c(n(e)*Math.cos(t),i(e)*Math.sin(t))},tanh:function(){var e=2*this.re,t=2*this.im,r=n(e)+Math.cos(t);return new c(i(e)/r,Math.sin(t)/r)},coth:function(){var e=2*this.re,t=2*this.im,r=n(e)-Math.cos(t);return new c(i(e)/r,-Math.sin(t)/r)},csch:function(){var e=this.re,t=this.im,r=Math.cos(2*t)-n(2*e);return new c(-2*i(e)*Math.cos(t)/r,2*n(e)*Math.sin(t)/r)},sech:function(){var e=this.re,t=this.im,r=Math.cos(2*t)+n(2*e);return new c(2*n(e)*Math.cos(t)/r,-2*i(e)*Math.sin(t)/r)},asinh:function(){var e=this.im,t=(this.im=-this.re,this.re=e,this.asin());return this.re=-this.im,this.im=e,e=t.re,t.re=-t.im,t.im=e,t},acosh:function(){var e,t=this.acos();return t.im<=0?(e=t.re,t.re=-t.im,t.im=e):(e=t.im,t.im=-t.re,t.re=e),t},atanh:function(){var e=this.re,t=this.im,r=1<e&&0===t,n=1-e,i=1+e,a=n*n+t*t,n=0!=a?new c((i*n-t*t)/a,(t*n+i*t)/a):new c(-1!==e?e/0:0,0!==t?t/0:0),i=n.re;return n.re=o(n.re,n.im)/2,n.im=Math.atan2(n.im,i)/2,r&&(n.im=-n.im),n},acoth:function(){var e=this.re,t=this.im;if(0===e&&0===t)return new c(0,Math.PI/2);var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).atanh()},acsch:function(){var e=this.re,t=this.im;if(0===t)return new c(0!==e?Math.log(e+Math.sqrt(e*e+1)):1/0,0);var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).asinh()},asech:function(){var e=this.re,t=this.im;if(this.isZero())return c.INFINITY;var r=e*e+t*t;return(0!=r?new c(e/r,-t/r):new c(0!==e?e/0:0,0!==t?-t/0:0)).acosh()},inverse:function(){if(this.isZero())return c.INFINITY;if(this.isInfinite())return c.ZERO;var e=this.re,t=this.im,r=e*e+t*t;return new c(e/r,-t/r)},conjugate:function(){return new c(this.re,-this.im)},neg:function(){return new c(-this.re,-this.im)},ceil:function(e){return e=Math.pow(10,e||0),new c(Math.ceil(this.re*e)/e,Math.ceil(this.im*e)/e)},floor:function(e){return e=Math.pow(10,e||0),new c(Math.floor(this.re*e)/e,Math.floor(this.im*e)/e)},round:function(e){return e=Math.pow(10,e||0),new c(Math.round(this.re*e)/e,Math.round(this.im*e)/e)},equals:function(e,t){e=new c(e,t);return Math.abs(e.re-this.re)<=c.EPSILON&&Math.abs(e.im-this.im)<=c.EPSILON},clone:function(){return new c(this.re,this.im)},toString:function(){var e=this.re,t=this.im,r="";return this.isNaN()?"NaN":this.isInfinite()?"Infinity":(Math.abs(e)<c.EPSILON&&(e=0),0===(t=Math.abs(t)<c.EPSILON?0:t)?r+e:(0!==e?(r=r+e+" ",t<0?(t=-t,r+="-"):r+="+",r+=" "):t<0&&(t=-t,r+="-"),1!==t&&(r+=t),r+"i"))},toVector:function(){return[this.re,this.im]},valueOf:function(){return 0===this.im?this.re:null},isNaN:function(){return isNaN(this.re)||isNaN(this.im)},isZero:function(){return 0===this.im&&0===this.re},isFinite:function(){return isFinite(this.re)&&isFinite(this.im)},isInfinite:function(){return!(this.isNaN()||this.isFinite())}},c.ZERO=new c(0,0),c.ONE=new c(1,0),c.I=new c(0,1),c.PI=new c(Math.PI,0),c.E=new c(Math.E,0),c.INFINITY=new c(1/0,1/0),c.NAN=new c(NaN,NaN),c.EPSILON=1e-15,void 0!==(r=function(){return c}.apply(t,[]))&&(e.exports=r)}()},3144:e=>{"use strict";function s(e,t){return u({},e,t)}var u=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r,n=arguments[t];for(r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},c={"{":"\\{","}":"\\}","\\":"\\textbackslash{}","#":"\\#",$:"\\$","%":"\\%","&":"\\&","^":"\\textasciicircum{}",_:"\\_","~":"\\textasciitilde{}"},l={"–":"\\--","—":"\\---"," ":"~","\t":"\\qquad{}","\r\n":"\\newline{}","\n":"\\newline{}"};e.exports=function(e){for(var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},r=t.preserveFormatting,r=void 0!==r&&r,t=t.escapeMapFn,t=void 0===t?s:t,n=String(e),i="",a=t(u({},c),r?u({},l):{}),o=Object.keys(a);n;)!function(){var r=!1;o.forEach(function(e,t){r||n.length>=e.length&&n.slice(0,e.length)===e&&(i+=a[o[t]],n=n.slice(e.length,n.length),r=!0)}),r||(i+=n.slice(0,1),n=n.slice(1,n.length))}();return i}},1880:e=>{e.exports=function t(e,r){"use strict";function n(e){return t.insensitive&&(""+e).toLowerCase()||""+e}var i,a,o=/(^([+\-]?(?:0|[1-9]\d*)(?:\.\d*)?(?:[eE][+\-]?\d+)?)?$|^0x[0-9a-f]+$|\d+)/gi,s=/(^[ ]*|[ ]*$)/g,u=/(^([\w ]+,?[\w ]+)?[\w ]+,?[\w ]+\d+:\d+(:\d+)?[\w ]?|^\d{1,4}[\/\-]\d{1,4}[\/\-]\d{1,4}|^\w+, \w+ \d+, \d{4})/,c=/^0x[0-9a-f]+$/i,l=/^0/,e=n(e).replace(s,"")||"",r=n(r).replace(s,"")||"",f=e.replace(o,"\0$1\0").replace(/\0$/,"").replace(/^\0/,"").split("\0"),p=r.replace(o,"\0$1\0").replace(/\0$/,"").replace(/^\0/,"").split("\0"),s=parseInt(e.match(c),16)||1!==f.length&&e.match(u)&&Date.parse(e),o=parseInt(r.match(c),16)||s&&r.match(u)&&Date.parse(r)||null;if(o){if(s<o)return-1;if(o<s)return 1}for(var m=0,h=Math.max(f.length,p.length);m<h;m++){if(i=!(f[m]||"").match(l)&&parseFloat(f[m])||f[m]||0,a=!(p[m]||"").match(l)&&parseFloat(p[m])||p[m]||0,isNaN(i)!==isNaN(a))return isNaN(i)?1:-1;if(typeof i!=typeof a&&(i+="",a+=""),i<a)return-1;if(a<i)return 1}return 0}},7391:(e,t,r)=>{var n=r(7180),i=r(3181),a=r(3031),o=r(9067),s=r(6833),u=r(6098),r=r(4801);r.alea=n,r.xor128=i,r.xorwow=a,r.xorshift7=o,r.xor4096=s,r.tychei=u,e.exports=r},7180:function(e,r,n){var o;!function(e){function i(e){var n,t=this,r=(n=4022871197,function(e){e=String(e);for(var t=0;t<e.length;t++){var r=.02519603282416938*(n+=e.charCodeAt(t));n=(r=(r-=n=r>>>0)*n)>>>0,n+=4294967296*(r-=n)}return 2.3283064365386963e-10*(n>>>0)});t.next=function(){var e=2091639*t.s0+2.3283064365386963e-10*t.c;return t.s0=t.s1,t.s1=t.s2,t.s2=e-(t.c=0|e)},t.c=1,t.s0=r(" "),t.s1=r(" "),t.s2=r(" "),t.s0-=r(e),t.s0<0&&(t.s0+=1),t.s1-=r(e),t.s1<0&&(t.s1+=1),t.s2-=r(e),t.s2<0&&(t.s2+=1)}function a(e,t){return t.c=e.c,t.s0=e.s0,t.s1=e.s1,t.s2=e.s2,t}function t(e,t){var r=new i(e),e=t&&t.state,n=r.next;return n.int32=function(){return 4294967296*r.next()|0},n.double=function(){return n()+11102230246251565e-32*(2097152*n()|0)},n.quick=n,e&&("object"==typeof e&&a(e,r),n.state=function(){return a(r,{})}),n}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.alea=t}(e=n.nmd(e),n.amdD)},6098:function(e,r,n){var o;!function(e){function i(e){var i=this,t="";i.next=function(){var e=(e=i.b)<<25^e>>>7^(t=i.c),t=t-(r=i.d)|0,r=r<<24^r>>>8^(n=i.a),n=n-e|0;return i.b=e=e<<20^e>>>12^t,i.c=t=t-r|0,i.d=r<<16^t>>>16^n,i.a=n-e|0},i.a=0,i.b=0,i.c=-1640531527,i.d=1367130551,e===Math.floor(e)?(i.a=e/4294967296|0,i.b=0|e):t+=e;for(var r=0;r<t.length+20;r++)i.b^=0|t.charCodeAt(r),i.next()}function a(e,t){return t.a=e.a,t.b=e.b,t.c=e.c,t.d=e.d,t}function t(e,t){function r(){return(n.next()>>>0)/4294967296}var n=new i(e),e=t&&t.state;return r.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},r.int32=n.next,r.quick=r,e&&("object"==typeof e&&a(e,n),r.state=function(){return a(n,{})}),r}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.tychei=t}(e=n.nmd(e),n.amdD)},3181:function(e,r,n){var o;!function(e){function i(e){var t=this,r="";t.x=0,t.y=0,t.z=0,t.w=0,t.next=function(){var e=t.x^t.x<<11;return t.x=t.y,t.y=t.z,t.z=t.w,t.w^=t.w>>>19^e^e>>>8},e===(0|e)?t.x=e:r+=e;for(var n=0;n<r.length+64;n++)t.x^=0|r.charCodeAt(n),t.next()}function a(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t}function t(e,t){function r(){return(n.next()>>>0)/4294967296}var n=new i(e),e=t&&t.state;return r.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},r.int32=n.next,r.quick=r,e&&("object"==typeof e&&a(e,n),r.state=function(){return a(n,{})}),r}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.xor128=t}(e=n.nmd(e),n.amdD)},6833:function(e,r,n){var o;!function(e){function i(e){var t,r,n,i,a,o=this,s=(o.next=function(){var e,t,r=o.w,n=o.X,i=o.i;return o.w=r=r+1640531527|0,t=n[i+34&127],e=n[i=i+1&127],t=n[i]=(t^=t<<13)^t>>>15^((e^=e<<17)^e>>>12),o.i=i,t+(r^r>>>16)|0},o),u=e,c=[],l=128;for(u===(0|u)?(r=u,u=null):(u+="\0",r=0,l=Math.max(l,u.length)),n=0,i=-32;i<l;++i)u&&(r^=u.charCodeAt((i+32)%u.length)),0===i&&(a=r),r=(r=(r=(r^=r<<10)^r>>>15)^r<<4)^r>>>13,0<=i&&(n=0==(t=c[127&i]^=r+(a=a+1640531527|0))?n+1:0);for(128<=n&&(c[127&(u&&u.length||0)]=-1),n=127,i=512;0<i;--i)r=c[n+34&127],t=c[n=n+1&127],c[n]=(r=(r^=r<<13)^r>>>15)^(t=(t^=t<<17)^t>>>12);s.w=a,s.X=c,s.i=n}function a(e,t){return t.i=e.i,t.w=e.w,t.X=e.X.slice(),t}function t(e,t){function r(){return(n.next()>>>0)/4294967296}var n=new i(e=null==e?+new Date:e),e=t&&t.state;return r.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},r.int32=n.next,r.quick=r,e&&(e.X&&a(e,n),r.state=function(){return a(n,{})}),r}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.xor4096=t}(e=n.nmd(e),n.amdD)},9067:function(e,r,n){var o;!function(e){function i(e){var t,i=this,r=(i.next=function(){var e=i.x,t=i.i,r=e[t],n=(r^=r>>>7)^r<<24;return n=(n=(n^=(r=e[t+1&7])^r>>>10)^((r=e[t+3&7])^r>>>3))^((r=e[t+4&7])^r<<7),r=e[t+7&7],n^=(r^=r<<13)^r<<9,e[t]=n,i.i=t+1&7,n},i),n=e,a=[];if(n===(0|n))a[0]=n;else for(n=""+n,t=0;t<n.length;++t)a[7&t]=a[7&t]<<15^n.charCodeAt(t)+a[t+1&7]<<13;for(;a.length<8;)a.push(0);for(t=0;t<8&&0===a[t];++t);for(8==t?a[7]=-1:a[t],r.x=a,r.i=0,t=256;0<t;--t)r.next()}function a(e,t){return t.x=e.x.slice(),t.i=e.i,t}function t(e,t){function r(){return(n.next()>>>0)/4294967296}var n=new i(e=null==e?+new Date:e),e=t&&t.state;return r.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},r.int32=n.next,r.quick=r,e&&(e.x&&a(e,n),r.state=function(){return a(n,{})}),r}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.xorshift7=t}(e=n.nmd(e),n.amdD)},3031:function(e,r,n){var o;!function(e){function i(e){var t=this,r="";t.next=function(){var e=t.x^t.x>>>2;return t.x=t.y,t.y=t.z,t.z=t.w,t.w=t.v,(t.d=t.d+362437|0)+(t.v=t.v^t.v<<4^e^e<<1)|0},t.x=0,t.y=0,t.z=0,t.w=0,e===((t.v=0)|e)?t.x=e:r+=e;for(var n=0;n<r.length+64;n++)t.x^=0|r.charCodeAt(n),n==r.length&&(t.d=t.x<<10^t.x>>>4),t.next()}function a(e,t){return t.x=e.x,t.y=e.y,t.z=e.z,t.w=e.w,t.v=e.v,t.d=e.d,t}function t(e,t){function r(){return(n.next()>>>0)/4294967296}var n=new i(e),e=t&&t.state;return r.double=function(){do{var e=((n.next()>>>11)+(n.next()>>>0)/4294967296)/(1<<21)}while(0===e);return e},r.int32=n.next,r.quick=r,e&&("object"==typeof e&&a(e,n),r.state=function(){return a(n,{})}),r}e&&e.exports?e.exports=t:n.amdD&&n.amdO?void 0!==(o=function(){return t}.call(r,n,r,e))&&(e.exports=o):this.xorwow=t}(e=n.nmd(e),n.amdD)},4801:function(e,t,r){var o,s="undefined"!=typeof self?self:this,u=[],c=Math,l=256,f=c.pow(l,6),p=c.pow(2,52),m=2*p,h=l-1;function n(e,t,r){function n(){for(var e=a.g(6),t=f,r=0;e<p;)e=(e+r)*l,t*=l,r=a.g(1);for(;m<=e;)e/=2,t/=2,r>>>=1;return(e+r)/t}var i=[],e=y(function e(t,r){var n,i=[],a=typeof t;if(r&&"object"==a)for(n in t)try{i.push(e(t[n],r-1))}catch(t){}return i.length?i:"string"==a?t:t+"\0"}((t=1==t?{entropy:!0}:t||{}).entropy?[e,x(u)]:null==e?function(){try{var e;return o&&(e=o.randomBytes)?e=e(l):(e=new Uint8Array(l),(s.crypto||s.msCrypto).getRandomValues(e)),x(e)}catch(e){var t=s.navigator,t=t&&t.plugins;return[+new Date,s,t,s.screen,x(u)]}}():e,3),i),a=new d(i);return n.int32=function(){return 0|a.g(4)},n.quick=function(){return a.g(4)/4294967296},n.double=n,y(x(a.S),u),(t.pass||r||function(e,t,r,n){return n&&(n.S&&g(n,a),e.state=function(){return g(a,{})}),r?(c.random=e,t):e})(n,e,"global"in t?t.global:this==c,t.state)}function d(e){var t,r=e.length,o=this,n=0,i=o.i=o.j=0,a=o.S=[];for(r||(e=[r++]);n<l;)a[n]=n++;for(n=0;n<l;n++)a[n]=a[i=h&i+e[n%r]+(t=a[n])],a[i]=t;(o.g=function(e){for(var t,r=0,n=o.i,i=o.j,a=o.S;e--;)t=a[n=h&n+1],r=r*l+a[h&(a[n]=a[i=h&i+t])+(a[i]=t)];return o.i=n,o.j=i,r})(l)}function g(e,t){return t.i=e.i,t.j=e.j,t.S=e.S.slice(),t}function y(e,t){for(var r,n=e+"",i=0;i<n.length;)t[h&i]=h&(r^=19*t[h&i])+n.charCodeAt(i++);return x(t)}function x(e){return String.fromCharCode.apply(0,e)}if(y(c.random(),u),e.exports){e.exports=n;try{o=r(1234)}catch(e){}}else void 0!==(r=function(){return n}.call(t,r,t,e))&&(e.exports=r)},1504:e=>{function t(){}t.prototype={on:function(e,t,r){var n=this.e||(this.e={});return(n[e]||(n[e]=[])).push({fn:t,ctx:r}),this},once:function(e,t,r){var n=this;function i(){n.off(e,i),t.apply(r,arguments)}return i._=t,this.on(e,i,r)},emit:function(e){for(var t=[].slice.call(arguments,1),r=((this.e||(this.e={}))[e]||[]).slice(),n=0,i=r.length;n<i;n++)r[n].fn.apply(r[n].ctx,t);return this},off:function(e,t){var r=this.e||(this.e={}),n=r[e],i=[];if(n&&t)for(var a=0,o=n.length;a<o;a++)n[a].fn!==t&&n[a].fn._!==t&&i.push(n[a]);return i.length?r[e]=i:delete r[e],this}},e.exports=t,e.exports.TinyEmitter=t},1234:()=>{},9306:(e,t,r)=>{"use strict";var n=r(4901),i=r(6823),a=TypeError;e.exports=function(e){if(n(e))return e;throw new a(i(e)+" is not a function")}},5548:(e,t,r)=>{"use strict";var n=r(3517),i=r(6823),a=TypeError;e.exports=function(e){if(n(e))return e;throw new a(i(e)+" is not a constructor")}},3506:(e,t,r)=>{"use strict";var n=r(3925),i=String,a=TypeError;e.exports=function(e){if(n(e))return e;throw new a("Can't set "+i(e)+" as a prototype")}},6469:(e,t,r)=>{"use strict";var n=r(8227),i=r(2360),r=r(4913).f,a=n("unscopables"),o=Array.prototype;void 0===o[a]&&r(o,a,{configurable:!0,value:i(null)}),e.exports=function(e){o[a][e]=!0}},7829:(e,t,r)=>{"use strict";var n=r(8183).charAt;e.exports=function(e,t,r){return t+(r?n(e,t).length:1)}},679:(e,t,r)=>{"use strict";var n=r(1625),i=TypeError;e.exports=function(e,t){if(n(t,e))return e;throw new i("Incorrect invocation")}},8551:(e,t,r)=>{"use strict";var n=r(34),i=String,a=TypeError;e.exports=function(e){if(n(e))return e;throw new a(i(e)+" is not an object")}},9617:(e,t,r)=>{"use strict";function n(s){return function(e,t,r){var n=u(e),i=l(n);if(0===i)return!s&&-1;var a,o=c(r,i);if(s&&t!=t){for(;o<i;)if((a=n[o++])!=a)return!0}else for(;o<i;o++)if((s||o in n)&&n[o]===t)return s||o||0;return!s&&-1}}var u=r(5397),c=r(5610),l=r(6198);e.exports={includes:n(!0),indexOf:n(!1)}},4598:(e,t,r)=>{"use strict";var n=r(9039);e.exports=function(e,t){var r=[][e];return!!r&&n(function(){r.call(null,t||function(){return 1},1)})}},926:(e,t,r)=>{"use strict";function n(c){return function(e,t,r,n){var i=f(e),a=p(i),o=m(i);if(l(t),0===o&&r<2)throw new h(d);var s=c?o-1:0,u=c?-1:1;if(r<2)for(;;){if(s in a){n=a[s],s+=u;break}if(s+=u,c?s<0:o<=s)throw new h(d)}for(;c?0<=s:s<o;s+=u)s in a&&(n=t(n,a[s],s,i));return n}}var l=r(9306),f=r(8981),p=r(7055),m=r(6198),h=TypeError,d="Reduce of empty array with no initial value";e.exports={left:n(!1),right:n(!0)}},7680:(e,t,r)=>{"use strict";r=r(9504);e.exports=r([].slice)},4488:(e,t,r)=>{"use strict";function m(e,t){var r=e.length;if(r<8)for(var n,i,a=1;a<r;){for(n=e[i=a];i&&0<t(e[i-1],n);)e[i]=e[--i];i!==a++&&(e[i]=n)}else for(var o=d(r/2),s=m(h(e,0,o),t),u=m(h(e,o),t),c=s.length,l=u.length,f=0,p=0;f<c||p<l;)e[f+p]=f<c&&p<l?t(s[f],u[p])<=0?s[f++]:u[p++]:f<c?s[f++]:u[p++];return e}var h=r(7680),d=Math.floor;e.exports=m},4428:(e,t,r)=>{"use strict";var i=r(8227)("iterator"),a=!1;try{var n=0,o={next:function(){return{done:!!n++}},return:function(){a=!0}};o[i]=function(){return this},Array.from(o,function(){throw 2})}catch(e){}e.exports=function(e,t){try{if(!t&&!a)return!1}catch(e){return!1}var r=!1;try{var n={};n[i]=function(){return{next:function(){return{done:r=!0}}}},e(n)}catch(e){}return r}},4576:(e,t,r)=>{"use strict";var r=r(9504),n=r({}.toString),i=r("".slice);e.exports=function(e){return i(n(e),8,-1)}},6955:(e,t,r)=>{"use strict";var n=r(2140),i=r(4901),a=r(4576),o=r(8227)("toStringTag"),s=Object,u="Arguments"===a(function(){return arguments}());e.exports=n?a:function(e){var t;return void 0===e?"Undefined":null===e?"Null":"string"==typeof(t=function(e,t){try{return e[t]}catch(e){}}(e=s(e),o))?t:u?a(e):"Object"===(t=a(e))&&i(e.callee)?"Arguments":t}},7740:(e,t,r)=>{"use strict";var u=r(9297),c=r(5031),l=r(7347),f=r(4913);e.exports=function(e,t,r){for(var n=c(t),i=f.f,a=l.f,o=0;o<n.length;o++){var s=n[o];u(e,s)||r&&u(r,s)||i(e,s,a(t,s))}}},6699:(e,t,r)=>{"use strict";var n=r(3724),i=r(4913),a=r(6980);e.exports=n?function(e,t,r){return i.f(e,t,a(1,r))}:function(e,t,r){return e[t]=r,e}},6980:e=>{"use strict";e.exports=function(e,t){return{enumerable:!(1&e),configurable:!(2&e),writable:!(4&e),value:t}}},2106:(e,t,r)=>{"use strict";var n=r(283),i=r(4913);e.exports=function(e,t,r){return r.get&&n(r.get,t,{getter:!0}),r.set&&n(r.set,t,{setter:!0}),i.f(e,t,r)}},6840:(e,t,r)=>{"use strict";var o=r(4901),s=r(4913),u=r(283),c=r(9433);e.exports=function(e,t,r,n){var i=(n=n||{}).enumerable,a=void 0!==n.name?n.name:t;if(o(r)&&u(r,a,n),n.global)i?e[t]=r:c(t,r);else{try{n.unsafe?e[t]&&(i=!0):delete e[t]}catch(e){}i?e[t]=r:s.f(e,t,{value:r,enumerable:!1,configurable:!n.nonConfigurable,writable:!n.nonWritable})}return e}},9433:(e,t,r)=>{"use strict";var n=r(4475),i=Object.defineProperty;e.exports=function(t,r){try{i(n,t,{value:r,configurable:!0,writable:!0})}catch(e){n[t]=r}return r}},4606:(e,t,r)=>{"use strict";var n=r(6823),i=TypeError;e.exports=function(e,t){if(!delete e[t])throw new i("Cannot delete property "+n(t)+" of "+n(e))}},3724:(e,t,r)=>{"use strict";r=r(9039);e.exports=!r(function(){return 7!==Object.defineProperty({},1,{get:function(){return 7}})[1]})},4055:(e,t,r)=>{"use strict";var n=r(4475),r=r(34),i=n.document,a=r(i)&&r(i.createElement);e.exports=function(e){return a?i.createElement(e):{}}},8834:(e,t,r)=>{"use strict";r=r(9392).match(/firefox\/(\d+)/i);e.exports=!!r&&+r[1]},7290:(e,t,r)=>{"use strict";var n=r(516),r=r(9088);e.exports=!n&&!r&&"object"==typeof window&&"object"==typeof document},516:e=>{"use strict";e.exports="object"==typeof Deno&&Deno&&"object"==typeof Deno.version},3202:(e,t,r)=>{"use strict";r=r(9392);e.exports=/MSIE|Trident/.test(r)},28:(e,t,r)=>{"use strict";r=r(9392);e.exports=/ipad|iphone|ipod/i.test(r)&&"undefined"!=typeof Pebble},8119:(e,t,r)=>{"use strict";r=r(9392);e.exports=/(?:ipad|iphone|ipod).*applewebkit/i.test(r)},9088:(e,t,r)=>{"use strict";var n=r(4475),r=r(4576);e.exports="process"===r(n.process)},6765:(e,t,r)=>{"use strict";r=r(9392);e.exports=/web0s(?!.*chrome)/i.test(r)},9392:e=>{"use strict";e.exports="undefined"!=typeof navigator&&String(navigator.userAgent)||""},7388:(e,t,r)=>{"use strict";var n,i,a=r(4475),r=r(9392),o=a.process,a=a.Deno,o=o&&o.versions||a&&a.version,a=o&&o.v8;!(i=a?0<(n=a.split("."))[0]&&n[0]<4?1:+(n[0]+n[1]):i)&&r&&(!(n=r.match(/Edge\/(\d+)/))||74<=n[1])&&(n=r.match(/Chrome\/(\d+)/))&&(i=+n[1]),e.exports=i},9160:(e,t,r)=>{"use strict";r=r(9392).match(/AppleWebKit\/(\d+)\./);e.exports=!!r&&+r[1]},8727:e=>{"use strict";e.exports=["constructor","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","toLocaleString","toString","valueOf"]},6518:(e,t,r)=>{"use strict";var c=r(4475),l=r(7347).f,f=r(6699),p=r(6840),m=r(9433),h=r(7740),d=r(2796);e.exports=function(e,t){var r,n,i,a,o=e.target,s=e.global,u=e.stat;if(r=s?c:u?c[o]||m(o,{}):c[o]&&c[o].prototype)for(n in t){if(i=t[n],a=e.dontCallGetSet?(a=l(r,n))&&a.value:r[n],!d(s?n:o+(u?".":"#")+n,e.forced)&&void 0!==a){if(typeof i==typeof a)continue;h(i,a)}(e.sham||a&&a.sham)&&f(i,"sham",!0),p(r,n,i,e)}}},9039:e=>{"use strict";e.exports=function(e){try{return!!e()}catch(e){return!0}}},9228:(e,t,r)=>{"use strict";r(7495);var u=r(9565),c=r(6840),l=r(7323),f=r(9039),p=r(8227),m=r(6699),h=p("species"),d=RegExp.prototype;e.exports=function(r,e,t,n){var o,i=p(r),s=!f(function(){var e={};return e[i]=function(){return 7},7!==""[r](e)}),a=s&&!f(function(){var e=!1,t=/a/;return"split"===r&&((t={}).constructor={},t.constructor[h]=function(){return t},t.flags="",t[i]=/./[i]),t.exec=function(){return e=!0,null},t[i](""),!e});s&&a&&!t||(o=/./[i],a=e(i,""[r],function(e,t,r,n,i){var a=t.exec;return a===l||a===d.exec?s&&!i?{done:!0,value:u(o,t,r,n)}:{done:!0,value:u(e,r,t,n)}:{done:!1}}),c(String.prototype,r,a[0]),c(d,i,a[1])),n&&m(d[i],"sham",!0)}},8745:(e,t,r)=>{"use strict";var r=r(616),n=Function.prototype,i=n.apply,a=n.call;e.exports="object"==typeof Reflect&&Reflect.apply||(r?a.bind(i):function(){return a.apply(i,arguments)})},6080:(e,t,r)=>{"use strict";var n=r(7476),i=r(9306),a=r(616),o=n(n.bind);e.exports=function(e,t){return i(e),void 0===t?e:a?o(e,t):function(){return e.apply(t,arguments)}}},616:(e,t,r)=>{"use strict";r=r(9039);e.exports=!r(function(){var e=function(){}.bind();return"function"!=typeof e||e.hasOwnProperty("prototype")})},9565:(e,t,r)=>{"use strict";var r=r(616),n=Function.prototype.call;e.exports=r?n.bind(n):function(){return n.apply(n,arguments)}},350:(e,t,r)=>{"use strict";var n=r(3724),r=r(9297),i=Function.prototype,a=n&&Object.getOwnPropertyDescriptor,r=r(i,"name"),o=r&&"something"===function(){}.name,n=r&&(!n||a(i,"name").configurable);e.exports={EXISTS:r,PROPER:o,CONFIGURABLE:n}},6706:(e,t,r)=>{"use strict";var n=r(9504),i=r(9306);e.exports=function(e,t,r){try{return n(i(Object.getOwnPropertyDescriptor(e,t)[r]))}catch(e){}}},7476:(e,t,r)=>{"use strict";var n=r(4576),i=r(9504);e.exports=function(e){if("Function"===n(e))return i(e)}},9504:(e,t,r)=>{"use strict";var r=r(616),n=Function.prototype,i=n.call,n=r&&n.bind.bind(i,i);e.exports=r?n:function(e){return function(){return i.apply(e,arguments)}}},7751:(e,t,r)=>{"use strict";var n=r(4475),i=r(4901);e.exports=function(e,t){return arguments.length<2?(r=n[e],i(r)?r:void 0):n[e]&&n[e][t];var r}},851:(e,t,r)=>{"use strict";var n=r(6955),i=r(5966),a=r(4117),o=r(6269),s=r(8227)("iterator");e.exports=function(e){if(!a(e))return i(e,s)||i(e,"@@iterator")||o[n(e)]}},81:(e,t,r)=>{"use strict";var n=r(9565),i=r(9306),a=r(8551),o=r(6823),s=r(851),u=TypeError;e.exports=function(e,t){t=arguments.length<2?s(e):t;if(i(t))return a(n(t,e));throw new u(o(e)+" is not iterable")}},6933:(e,t,r)=>{"use strict";var n=r(9504),s=r(4376),u=r(4901),c=r(4576),l=r(655),f=n([].push);e.exports=function(e){if(u(e))return e;if(s(e)){for(var t=e.length,n=[],r=0;r<t;r++){var i=e[r];"string"==typeof i?f(n,i):"number"!=typeof i&&"Number"!==c(i)&&"String"!==c(i)||f(n,l(i))}var a=n.length,o=!0;return function(e,t){if(o)return o=!1,t;if(s(this))return t;for(var r=0;r<a;r++)if(n[r]===e)return t}}}},5966:(e,t,r)=>{"use strict";var n=r(9306),i=r(4117);e.exports=function(e,t){e=e[t];return i(e)?void 0:n(e)}},2478:(e,t,r)=>{"use strict";var n=r(9504),i=r(8981),p=Math.floor,m=n("".charAt),h=n("".replace),d=n("".slice),g=/\$([$&'`]|\d{1,2}|<[^>]*>)/g,y=/\$([$&'`]|\d{1,2})/g;e.exports=function(a,o,s,u,c,e){var l=s+a.length,f=u.length,t=y;return void 0!==c&&(c=i(c),t=g),h(e,t,function(e,t){var r;switch(m(t,0)){case"$":return"$";case"&":return a;case"`":return d(o,0,s);case"'":return d(o,l);case"<":r=c[d(t,1,-1)];break;default:var n,i=+t;if(0==i)return e;if(f<i)return 0!==(n=p(i/10))&&n<=f?void 0===u[n-1]?m(t,1):u[n-1]+m(t,1):e;r=u[i-1]}return void 0===r?"":r})}},4475:function(e){"use strict";function t(e){return e&&e.Math===Math&&e}e.exports=t("object"==typeof globalThis&&globalThis)||t("object"==typeof window&&window)||t("object"==typeof self&&self)||t("object"==typeof global&&global)||t("object"==typeof this&&this)||function(){return this}()||Function("return this")()},9297:(e,t,r)=>{"use strict";var n=r(9504),i=r(8981),a=n({}.hasOwnProperty);e.exports=Object.hasOwn||function(e,t){return a(i(e),t)}},421:e=>{"use strict";e.exports={}},3138:e=>{"use strict";e.exports=function(e,t){try{1===arguments.length?console.error(e):console.error(e,t)}catch(e){}}},397:(e,t,r)=>{"use strict";r=r(7751);e.exports=r("document","documentElement")},5917:(e,t,r)=>{"use strict";var n=r(3724),i=r(9039),a=r(4055);e.exports=!n&&!i(function(){return 7!==Object.defineProperty(a("div"),"a",{get:function(){return 7}}).a})},7055:(e,t,r)=>{"use strict";var n=r(9504),i=r(9039),a=r(4576),o=Object,s=n("".split);e.exports=i(function(){return!o("z").propertyIsEnumerable(0)})?function(e){return"String"===a(e)?s(e,""):o(e)}:o},3167:(e,t,r)=>{"use strict";var n=r(4901),i=r(34),a=r(2967);e.exports=function(e,t,r){return a&&n(t=t.constructor)&&t!==r&&i(t=t.prototype)&&t!==r.prototype&&a(e,t),e}},3706:(e,t,r)=>{"use strict";var n=r(9504),i=r(4901),r=r(7629),a=n(Function.toString);i(r.inspectSource)||(r.inspectSource=function(e){return a(e)}),e.exports=r.inspectSource},1181:(e,t,r)=>{"use strict";var n,i,a,o,s=r(8622),u=r(4475),c=r(34),l=r(6699),f=r(9297),p=r(7629),m=r(6119),r=r(421),h="Object already initialized",d=u.TypeError,u=u.WeakMap,g=s||p.state?((a=p.state||(p.state=new u)).get=a.get,a.has=a.has,a.set=a.set,n=function(e,t){if(a.has(e))throw new d(h);return t.facade=e,a.set(e,t),t},i=function(e){return a.get(e)||{}},function(e){return a.has(e)}):(r[o=m("state")]=!0,n=function(e,t){if(f(e,o))throw new d(h);return t.facade=e,l(e,o,t),t},i=function(e){return f(e,o)?e[o]:{}},function(e){return f(e,o)});e.exports={set:n,get:i,has:g,enforce:function(e){return g(e)?i(e):n(e,{})},getterFor:function(t){return function(e){if(c(e)&&(e=i(e)).type===t)return e;throw new d("Incompatible receiver, "+t+" required")}}}},4209:(e,t,r)=>{"use strict";var n=r(8227),i=r(6269),a=n("iterator"),o=Array.prototype;e.exports=function(e){return void 0!==e&&(i.Array===e||o[a]===e)}},4376:(e,t,r)=>{"use strict";var n=r(4576);e.exports=Array.isArray||function(e){return"Array"===n(e)}},4901:e=>{"use strict";var t="object"==typeof document&&document.all;e.exports=void 0===t&&void 0!==t?function(e){return"function"==typeof e||e===t}:function(e){return"function"==typeof e}},3517:(e,t,r)=>{"use strict";function n(){}function i(e){if(!u(e))return!1;try{return p(n,[],e),!0}catch(e){return!1}}function a(e){if(!u(e))return!1;switch(c(e)){case"AsyncFunction":case"GeneratorFunction":case"AsyncGeneratorFunction":return!1}try{return d||!!h(m,f(e))}catch(e){return!0}}var o=r(9504),s=r(9039),u=r(4901),c=r(6955),l=r(7751),f=r(3706),p=l("Reflect","construct"),m=/^\s*(?:class|function)\b/,h=o(m.exec),d=!m.test(n);a.sham=!0,e.exports=!p||s(function(){var e;return i(i.call)||!i(Object)||!i(function(){e=!0})||e})?a:i},2796:(e,t,r)=>{"use strict";function n(e,t){return(e=u[s(e)])===l||e!==c&&(a(t)?i(t):!!t)}var i=r(9039),a=r(4901),o=/#|\.prototype\./,s=n.normalize=function(e){return String(e).replace(o,".").toLowerCase()},u=n.data={},c=n.NATIVE="N",l=n.POLYFILL="P";e.exports=n},4117:e=>{"use strict";e.exports=function(e){return null==e}},34:(e,t,r)=>{"use strict";var n=r(4901);e.exports=function(e){return"object"==typeof e?null!==e:n(e)}},3925:(e,t,r)=>{"use strict";var n=r(34);e.exports=function(e){return n(e)||null===e}},6395:e=>{"use strict";e.exports=!1},788:(e,t,r)=>{"use strict";var n=r(34),i=r(4576),a=r(8227)("match");e.exports=function(e){var t;return n(e)&&(void 0!==(t=e[a])?!!t:"RegExp"===i(e))}},757:(e,t,r)=>{"use strict";var n=r(7751),i=r(4901),a=r(1625),r=r(7040),o=Object;e.exports=r?function(e){return"symbol"==typeof e}:function(e){var t=n("Symbol");return i(t)&&a(t.prototype,o(e))}},2652:(e,t,r)=>{"use strict";function y(e,t){this.stopped=e,this.result=t}var x=r(6080),b=r(9565),v=r(8551),w=r(6823),N=r(4209),E=r(6198),A=r(1625),S=r(81),M=r(851),C=r(9539),T=TypeError,D=y.prototype;e.exports=function(e,t,r){function n(e){return a&&C(a,"normal",e),new y(!0,e)}function i(e){return p?(v(e),d?g(e[0],e[1],n):g(e[0],e[1])):d?g(e,n):g(e)}var a,o,s,u,c,l,f=r&&r.that,p=!(!r||!r.AS_ENTRIES),m=!(!r||!r.IS_RECORD),h=!(!r||!r.IS_ITERATOR),d=!(!r||!r.INTERRUPTED),g=x(t,f);if(m)a=e.iterator;else if(h)a=e;else{if(!(r=M(e)))throw new T(w(e)+" is not iterable");if(N(r)){for(o=0,s=E(e);o<s;o++)if((u=i(e[o]))&&A(D,u))return u;return new y(!1)}a=S(e,r)}for(c=(m?e:a).next;!(l=b(c,a)).done;){try{u=i(l.value)}catch(e){C(a,"throw",e)}if("object"==typeof u&&u&&A(D,u))return u}return new y(!1)}},9539:(e,t,r)=>{"use strict";var a=r(9565),o=r(8551),s=r(5966);e.exports=function(e,t,r){var n,i;o(e);try{if(!(n=s(e,"return"))){if("throw"===t)throw r;return r}n=a(n,e)}catch(e){i=!0,n=e}if("throw"===t)throw r;if(i)throw n;return o(n),r}},6269:e=>{"use strict";e.exports={}},6198:(e,t,r)=>{"use strict";var n=r(8014);e.exports=function(e){return n(e.length)}},283:(e,t,r)=>{"use strict";var n=r(9504),i=r(9039),a=r(4901),o=r(9297),s=r(3724),u=r(350).CONFIGURABLE,c=r(3706),r=r(1181),l=r.enforce,f=r.get,p=String,m=Object.defineProperty,h=n("".slice),d=n("".replace),g=n([].join),y=s&&!i(function(){return 8!==m(function(){},"length",{value:8}).length}),x=String(String).split("String"),r=e.exports=function(e,t,r){"Symbol("===h(p(t),0,7)&&(t="["+d(p(t),/^Symbol\(([^)]*)\).*$/,"$1")+"]"),r&&r.getter&&(t="get "+t),r&&r.setter&&(t="set "+t),(!o(e,"name")||u&&e.name!==t)&&(s?m(e,"name",{value:t,configurable:!0}):e.name=t),y&&r&&o(r,"arity")&&e.length!==r.arity&&m(e,"length",{value:r.arity});try{r&&o(r,"constructor")&&r.constructor?s&&m(e,"prototype",{writable:!1}):e.prototype&&(e.prototype=void 0)}catch(e){}r=l(e);return o(r,"source")||(r.source=g(x,"string"==typeof t?t:"")),e};Function.prototype.toString=r(function(){return a(this)&&f(this).source||c(this)},"toString")},741:e=>{"use strict";var t=Math.ceil,r=Math.floor;e.exports=Math.trunc||function(e){e=+e;return(0<e?r:t)(e)}},1955:(e,t,r)=>{"use strict";var n,i,a,o,s,u,c=r(4475),l=r(3389),f=r(6080),p=r(9225).set,m=r(8265),h=r(8119),d=r(28),g=r(6765),y=r(9088),r=c.MutationObserver||c.WebKitMutationObserver,x=c.document,b=c.process,v=c.Promise,l=l("queueMicrotask");l||(o=new m,s=function(){var e,t;for(y&&(e=b.domain)&&e.exit();t=o.get();)try{t()}catch(e){throw o.head&&u(),e}e&&e.enter()},u=h||y||g||!r||!x?!d&&v&&v.resolve?((m=v.resolve(void 0)).constructor=v,a=f(m.then,m),function(){a(s)}):y?function(){b.nextTick(s)}:(p=f(p,c),function(){p(s)}):(n=!0,i=x.createTextNode(""),new r(s).observe(i,{characterData:!0}),function(){i.data=n=!n}),l=function(e){o.head||u(),o.add(e)}),e.exports=l},6043:(e,t,r)=>{"use strict";function n(e){var r,n;this.promise=new e(function(e,t){if(void 0!==r||void 0!==n)throw new a("Bad Promise constructor");r=e,n=t}),this.resolve=i(r),this.reject=i(n)}var i=r(9306),a=TypeError;e.exports.f=function(e){return new n(e)}},2360:(e,t,r)=>{"use strict";function n(){}function i(e){e.write(d("")),e.close();var t=e.parentWindow.Object;return e=null,t}var a,o=r(8551),s=r(6801),u=r(8727),c=r(421),l=r(397),f=r(4055),r=r(6119),p="prototype",m="script",h=r("IE_PROTO"),d=function(e){return"<"+m+">"+e+"</"+m+">"},g=function(){try{a=new ActiveXObject("htmlfile")}catch(e){}var e,t,r;g="undefined"==typeof document||document.domain&&a?i(a):(t=f("iframe"),r="java"+m+":",t.style.display="none",l.appendChild(t),t.src=String(r),(e=t.contentWindow.document).open(),e.write(d("document.F=Object")),e.close(),e.F);for(var n=u.length;n--;)delete g[p][u[n]];return g()};c[h]=!0,e.exports=Object.create||function(e,t){var r;return null!==e?(n[p]=o(e),r=new n,n[p]=null,r[h]=e):r=g(),void 0===t?r:s.f(r,t)}},6801:(e,t,r)=>{"use strict";var n=r(3724),i=r(8686),s=r(4913),u=r(8551),c=r(5397),l=r(1072);t.f=n&&!i?Object.defineProperties:function(e,t){u(e);for(var r,n=c(t),i=l(t),a=i.length,o=0;o<a;)s.f(e,r=i[o++],n[r]);return e}},4913:(e,t,r)=>{"use strict";var n=r(3724),i=r(5917),a=r(8686),o=r(8551),s=r(6969),u=TypeError,c=Object.defineProperty,l=Object.getOwnPropertyDescriptor,f="enumerable",p="configurable",m="writable";t.f=n?a?function(e,t,r){var n;return o(e),t=s(t),o(r),"function"==typeof e&&"prototype"===t&&"value"in r&&m in r&&!r[m]&&(n=l(e,t))&&n[m]&&(e[t]=r.value,r={configurable:(p in r?r:n)[p],enumerable:(f in r?r:n)[f],writable:!1}),c(e,t,r)}:c:function(e,t,r){if(o(e),t=s(t),o(r),i)try{return c(e,t,r)}catch(e){}if("get"in r||"set"in r)throw new u("Accessors not supported");return"value"in r&&(e[t]=r.value),e}},7347:(e,t,r)=>{"use strict";var n=r(3724),i=r(9565),a=r(8773),o=r(6980),s=r(5397),u=r(6969),c=r(9297),l=r(5917),f=Object.getOwnPropertyDescriptor;t.f=n?f:function(e,t){if(e=s(e),t=u(t),l)try{return f(e,t)}catch(e){}if(c(e,t))return o(!i(a.f,e,t),e[t])}},8480:(e,t,r)=>{"use strict";var n=r(1828),i=r(8727).concat("length","prototype");t.f=Object.getOwnPropertyNames||function(e){return n(e,i)}},3717:(e,t)=>{"use strict";t.f=Object.getOwnPropertySymbols},1625:(e,t,r)=>{"use strict";r=r(9504);e.exports=r({}.isPrototypeOf)},1828:(e,t,r)=>{"use strict";var n=r(9504),o=r(9297),s=r(5397),u=r(9617).indexOf,c=r(421),l=n([].push);e.exports=function(e,t){var r,n=s(e),i=0,a=[];for(r in n)!o(c,r)&&o(n,r)&&l(a,r);for(;t.length>i;)!o(n,r=t[i++])||~u(a,r)||l(a,r);return a}},1072:(e,t,r)=>{"use strict";var n=r(1828),i=r(8727);e.exports=Object.keys||function(e){return n(e,i)}},8773:(e,t)=>{"use strict";var r={}.propertyIsEnumerable,n=Object.getOwnPropertyDescriptor,i=n&&!r.call({1:2},1);t.f=i?function(e){e=n(this,e);return!!e&&e.enumerable}:r},2967:(e,t,r)=>{"use strict";var i=r(6706),a=r(34),o=r(7750),s=r(3506);e.exports=Object.setPrototypeOf||("__proto__"in{}?function(){var r,n=!1,e={};try{(r=i(Object.prototype,"__proto__","set"))(e,[]),n=e instanceof Array}catch(r){}return function(e,t){return o(e),s(t),a(e)&&(n?r(e,t):e.__proto__=t),e}}():void 0)},4270:(e,t,r)=>{"use strict";var i=r(9565),a=r(4901),o=r(34),s=TypeError;e.exports=function(e,t){var r,n;if("string"===t&&a(r=e.toString)&&!o(n=i(r,e)))return n;if(a(r=e.valueOf)&&!o(n=i(r,e)))return n;if("string"!==t&&a(r=e.toString)&&!o(n=i(r,e)))return n;throw new s("Can't convert object to primitive value")}},5031:(e,t,r)=>{"use strict";var n=r(7751),i=r(9504),a=r(8480),o=r(3717),s=r(8551),u=i([].concat);e.exports=n("Reflect","ownKeys")||function(e){var t=a.f(s(e)),r=o.f;return r?u(t,r(e)):t}},1103:e=>{"use strict";e.exports=function(e){try{return{error:!1,value:e()}}catch(e){return{error:!0,value:e}}}},916:(e,t,r)=>{"use strict";var n=r(4475),i=r(550),a=r(4901),o=r(2796),s=r(3706),u=r(8227),c=r(7290),l=r(516),f=r(6395),p=r(7388),m=i&&i.prototype,h=u("species"),d=!1,g=a(n.PromiseRejectionEvent),r=o("Promise",function(){var e=s(i),t=e!==String(i);if(!t&&66===p)return!0;if(f&&(!m.catch||!m.finally))return!0;if(!p||p<51||!/native code/.test(e)){var e=new i(function(e){e(1)}),r=function(e){e(function(){},function(){})};if((e.constructor={})[h]=r,!(d=e.then(function(){})instanceof r))return!0}return!t&&(c||l)&&!g});e.exports={CONSTRUCTOR:r,REJECTION_EVENT:g,SUBCLASSING:d}},550:(e,t,r)=>{"use strict";r=r(4475);e.exports=r.Promise},3438:(e,t,r)=>{"use strict";var n=r(8551),i=r(34),a=r(6043);e.exports=function(e,t){if(n(e),i(t)&&t.constructor===e)return t;e=a.f(e);return(0,e.resolve)(t),e.promise}},537:(e,t,r)=>{"use strict";var n=r(550),i=r(4428),r=r(916).CONSTRUCTOR;e.exports=r||!i(function(e){n.all(e).then(void 0,function(){})})},1056:(e,t,r)=>{"use strict";var n=r(4913).f;e.exports=function(e,t,r){r in e||n(e,r,{configurable:!0,get:function(){return t[r]},set:function(e){t[r]=e}})}},8265:e=>{"use strict";function t(){this.head=null,this.tail=null}t.prototype={add:function(e){var e={item:e,next:null},t=this.tail;t?t.next=e:this.head=e,this.tail=e},get:function(){var e=this.head;if(e)return null===(this.head=e.next)&&(this.tail=null),e.item}},e.exports=t},6682:(e,t,r)=>{"use strict";var n=r(9565),i=r(8551),a=r(4901),o=r(4576),s=r(7323),u=TypeError;e.exports=function(e,t){var r=e.exec;if(a(r))return null!==(r=n(r,e,t))&&i(r),r;if("RegExp"===o(e))return n(s,e,t);throw new u("RegExp#exec called on incompatible receiver")}},7323:(e,t,r)=>{"use strict";var h=r(9565),n=r(9504),d=r(655),g=r(7979),i=r(8429),a=r(5745),y=r(2360),x=r(1181).get,o=r(3635),r=r(8814),b=a("native-string-replace",String.prototype.replace),v=RegExp.prototype.exec,w=v,N=n("".charAt),E=n("".indexOf),A=n("".replace),S=n("".slice),M=(a=/b*/g,h(v,n=/a/,"a"),h(v,a,"a"),0!==n.lastIndex||0!==a.lastIndex),C=i.BROKEN_CARET,T=void 0!==/()??/.exec("")[1];(M||T||C||o||r)&&(w=function(e){var t,r,n,i,a,o,s=this,u=x(s),e=d(e),c=u.raw;if(c)return c.lastIndex=s.lastIndex,f=h(w,c,e),s.lastIndex=c.lastIndex,f;var l=u.groups,c=C&&s.sticky,f=h(g,s),u=s.source,p=0,m=e;if(c&&(f=A(f,"y",""),-1===E(f,"g")&&(f+="g"),m=S(e,s.lastIndex),0<s.lastIndex&&(!s.multiline||s.multiline&&"\n"!==N(e,s.lastIndex-1))&&(u="(?: "+u+")",m=" "+m,p++),t=new RegExp("^(?:"+u+")",f)),T&&(t=new RegExp("^"+u+"$(?!\\s)",f)),M&&(r=s.lastIndex),n=h(v,c?t:s,m),c?n?(n.input=S(n.input,p),n[0]=S(n[0],p),n.index=s.lastIndex,s.lastIndex+=n[0].length):s.lastIndex=0:M&&n&&(s.lastIndex=s.global?n.index+n[0].length:r),T&&n&&1<n.length&&h(b,n[0],t,function(){for(i=1;i<arguments.length-2;i++)void 0===arguments[i]&&(n[i]=void 0)}),n&&l)for(n.groups=a=y(null),i=0;i<l.length;i++)a[(o=l[i])[0]]=n[o[1]];return n}),e.exports=w},7979:(e,t,r)=>{"use strict";var n=r(8551);e.exports=function(){var e=n(this),t="";return e.hasIndices&&(t+="d"),e.global&&(t+="g"),e.ignoreCase&&(t+="i"),e.multiline&&(t+="m"),e.dotAll&&(t+="s"),e.unicode&&(t+="u"),e.unicodeSets&&(t+="v"),e.sticky&&(t+="y"),t}},1034:(e,t,r)=>{"use strict";var n=r(9565),i=r(9297),a=r(1625),o=r(7979),s=RegExp.prototype;e.exports=function(e){var t=e.flags;return void 0!==t||"flags"in s||i(e,"flags")||!a(s,e)?t:n(o,e)}},8429:(e,t,r)=>{"use strict";var n=r(9039),i=r(4475).RegExp,r=n(function(){var e=i("a","y");return e.lastIndex=2,null!==e.exec("abcd")}),a=r||n(function(){return!i("a","y").sticky}),n=r||n(function(){var e=i("^r","gy");return e.lastIndex=2,null!==e.exec("str")});e.exports={BROKEN_CARET:n,MISSED_STICKY:a,UNSUPPORTED_Y:r}},3635:(e,t,r)=>{"use strict";var n=r(9039),i=r(4475).RegExp;e.exports=n(function(){var e=i(".","s");return!(e.dotAll&&e.test("\n")&&"s"===e.flags)})},8814:(e,t,r)=>{"use strict";var n=r(9039),i=r(4475).RegExp;e.exports=n(function(){var e=i("(?<a>b)","g");return"b"!==e.exec("b").groups.a||"bc"!=="b".replace(e,"$<a>c")})},7750:(e,t,r)=>{"use strict";var n=r(4117),i=TypeError;e.exports=function(e){if(n(e))throw new i("Can't call method on "+e);return e}},3389:(e,t,r)=>{"use strict";var n=r(4475),i=r(3724),a=Object.getOwnPropertyDescriptor;e.exports=function(e){if(!i)return n[e];e=a(n,e);return e&&e.value}},7633:(e,t,r)=>{"use strict";var n=r(7751),i=r(2106),a=r(8227),o=r(3724),s=a("species");e.exports=function(e){e=n(e);o&&e&&!e[s]&&i(e,s,{configurable:!0,get:function(){return this}})}},687:(e,t,r)=>{"use strict";var n=r(4913).f,i=r(9297),a=r(8227)("toStringTag");e.exports=function(e,t,r){(e=e&&!r?e.prototype:e)&&!i(e,a)&&n(e,a,{configurable:!0,value:t})}},6119:(e,t,r)=>{"use strict";var n=r(5745),i=r(3392),a=n("keys");e.exports=function(e){return a[e]||(a[e]=i(e))}},7629:(e,t,r)=>{"use strict";var n=r(6395),i=r(4475),r=r(9433),a="__core-js_shared__",e=e.exports=i[a]||r(a,{});(e.versions||(e.versions=[])).push({version:"3.37.1",mode:n?"pure":"global",copyright:"© 2014-2024 Denis Pushkarev (zloirock.ru)",license:"https://github.com/zloirock/core-js/blob/v3.37.1/LICENSE",source:"https://github.com/zloirock/core-js"})},5745:(e,t,r)=>{"use strict";var n=r(7629);e.exports=function(e,t){return n[e]||(n[e]=t||{})}},2293:(e,t,r)=>{"use strict";var n=r(8551),i=r(5548),a=r(4117),o=r(8227)("species");e.exports=function(e,t){var e=n(e).constructor;return void 0===e||a(e=n(e)[o])?t:i(e)}},8183:(e,t,r)=>{"use strict";function n(i){return function(e,t){var r,e=o(s(e)),t=a(t),n=e.length;return t<0||n<=t?i?"":void 0:(r=c(e,t))<55296||56319<r||t+1===n||(n=c(e,t+1))<56320||57343<n?i?u(e,t):r:i?l(e,t,t+2):n-56320+(r-55296<<10)+65536}}var i=r(9504),a=r(1291),o=r(655),s=r(7750),u=i("".charAt),c=i("".charCodeAt),l=i("".slice);e.exports={codeAt:n(!1),charAt:n(!0)}},4495:(e,t,r)=>{"use strict";var n=r(7388),i=r(9039),a=r(4475).String;e.exports=!!Object.getOwnPropertySymbols&&!i(function(){var e=Symbol("symbol detection");return!a(e)||!(Object(e)instanceof Symbol)||!Symbol.sham&&n&&n<41})},9225:(e,t,r)=>{"use strict";function n(e){return function(){D(e)}}function i(e){D(e.data)}function a(e){u.postMessage(S(e),o.protocol+"//"+o.host)}var o,s,u=r(4475),c=r(8745),l=r(6080),f=r(4901),p=r(9297),m=r(9039),h=r(397),d=r(7680),g=r(4055),y=r(2812),x=r(8119),r=r(9088),b=u.setImmediate,v=u.clearImmediate,w=u.process,N=u.Dispatch,E=u.Function,A=u.MessageChannel,S=u.String,M=0,C={},T="onreadystatechange",D=(m(function(){o=u.location}),function(e){var t;p(C,e)&&(t=C[e],delete C[e],t())});b&&v||(b=function(e){y(arguments.length,1);var t=f(e)?e:E(e),r=d(arguments,1);return C[++M]=function(){c(t,void 0,r)},s(M),M},v=function(e){delete C[e]},r?s=function(e){w.nextTick(n(e))}:N&&N.now?s=function(e){N.now(n(e))}:A&&!x?(x=(r=new A).port2,r.port1.onmessage=i,s=l(x.postMessage,x)):u.addEventListener&&f(u.postMessage)&&!u.importScripts&&o&&"file:"!==o.protocol&&!m(a)?(s=a,u.addEventListener("message",i,!1)):s=T in g("script")?function(e){h.appendChild(g("script"))[T]=function(){h.removeChild(this),D(e)}}:function(e){setTimeout(n(e),0)}),e.exports={set:b,clear:v}},5610:(e,t,r)=>{"use strict";var n=r(1291),i=Math.max,a=Math.min;e.exports=function(e,t){e=n(e);return e<0?i(e+t,0):a(e,t)}},5397:(e,t,r)=>{"use strict";var n=r(7055),i=r(7750);e.exports=function(e){return n(i(e))}},1291:(e,t,r)=>{"use strict";var n=r(741);e.exports=function(e){e=+e;return e!=e||0==e?0:n(e)}},8014:(e,t,r)=>{"use strict";var n=r(1291),i=Math.min;e.exports=function(e){e=n(e);return 0<e?i(e,9007199254740991):0}},8981:(e,t,r)=>{"use strict";var n=r(7750),i=Object;e.exports=function(e){return i(n(e))}},2777:(e,t,r)=>{"use strict";var n=r(9565),i=r(34),a=r(757),o=r(5966),s=r(4270),r=r(8227),u=TypeError,c=r("toPrimitive");e.exports=function(e,t){if(!i(e)||a(e))return e;var r=o(e,c);if(r){if(r=n(r,e,t=void 0===t?"default":t),!i(r)||a(r))return r;throw new u("Can't convert object to primitive value")}return s(e,t=void 0===t?"number":t)}},6969:(e,t,r)=>{"use strict";var n=r(2777),i=r(757);e.exports=function(e){e=n(e,"string");return i(e)?e:e+""}},2140:(e,t,r)=>{"use strict";var n={};n[r(8227)("toStringTag")]="z",e.exports="[object z]"===String(n)},655:(e,t,r)=>{"use strict";var n=r(6955),i=String;e.exports=function(e){if("Symbol"===n(e))throw new TypeError("Cannot convert a Symbol value to a string");return i(e)}},6823:e=>{"use strict";var t=String;e.exports=function(e){try{return t(e)}catch(e){return"Object"}}},3392:(e,t,r)=>{"use strict";var r=r(9504),n=0,i=Math.random(),a=r(1..toString);e.exports=function(e){return"Symbol("+(void 0===e?"":e)+")_"+a(++n+i,36)}},7040:(e,t,r)=>{"use strict";r=r(4495);e.exports=r&&!Symbol.sham&&"symbol"==typeof Symbol.iterator},8686:(e,t,r)=>{"use strict";var n=r(3724),r=r(9039);e.exports=n&&r(function(){return 42!==Object.defineProperty(function(){},"prototype",{value:42,writable:!1}).prototype})},2812:e=>{"use strict";var r=TypeError;e.exports=function(e,t){if(e<t)throw new r("Not enough arguments");return e}},8622:(e,t,r)=>{"use strict";var n=r(4475),r=r(4901),n=n.WeakMap;e.exports=r(n)&&/native code/.test(String(n))},8227:(e,t,r)=>{"use strict";var n=r(4475),i=r(5745),a=r(9297),o=r(3392),s=r(4495),r=r(7040),u=n.Symbol,c=i("wks"),l=r?u.for||u:u&&u.withoutSetter||o;e.exports=function(e){return a(c,e)||(c[e]=s&&a(u,e)?u[e]:l("Symbol."+e)),c[e]}},4423:(e,t,r)=>{"use strict";var n=r(6518),i=r(9617).includes,a=r(9039),r=r(6469);n({target:"Array",proto:!0,forced:a(function(){return!Array(1).includes()})},{includes:function(e){return i(this,e,1<arguments.length?arguments[1]:void 0)}}),r("includes")},2712:(e,t,r)=>{"use strict";var n=r(6518),i=r(926).left,a=r(4598),o=r(7388);n({target:"Array",proto:!0,forced:!r(9088)&&79<o&&o<83||!a("reduce")},{reduce:function(e){var t=arguments.length;return i(this,e,t,1<t?arguments[1]:void 0)}})},6910:(e,t,r)=>{"use strict";var n=r(6518),i=r(9504),s=r(9306),u=r(8981),c=r(6198),l=r(4606),f=r(655),a=r(9039),p=r(4488),o=r(4598),m=r(8834),h=r(3202),d=r(7388),g=r(9160),y=[],x=i(y.sort),b=i(y.push),r=a(function(){y.sort(void 0)}),i=a(function(){y.sort(null)}),o=o("sort"),v=!a(function(){if(d)return d<70;if(!(m&&3<m)){if(h)return!0;if(g)return g<603;for(var e,t,r,n="",i=65;i<76;i++){switch(e=String.fromCharCode(i),i){case 66:case 69:case 70:case 72:t=3;break;case 68:case 71:t=4;break;default:t=2}for(r=0;r<47;r++)y.push({k:e+r,v:t})}for(y.sort(function(e,t){return t.v-e.v}),r=0;r<y.length;r++)e=y[r].k.charAt(0),n.charAt(n.length-1)!==e&&(n+=e);return"DGBEFHACIJK"!==n}});n({target:"Array",proto:!0,forced:r||!i||!o||!v},{sort:function(e){void 0!==e&&s(e);var t=u(this);if(v)return void 0===e?x(t):x(t,e);for(var r,n,i=[],a=c(t),o=0;o<a;o++)o in t&&b(i,t[o]);for(p(i,(n=e,function(e,t){return void 0===t?-1:void 0===e?1:void 0!==n?+n(e,t)||0:f(e)>f(t)?1:-1})),r=c(i),o=0;o<r;)t[o]=i[o++];for(;o<a;)l(t,o++);return t}})},3110:(e,t,r)=>{"use strict";function i(e,t){var r=m(arguments),n=h(t);if(f(n)||void 0!==e&&!p(e))return r[1]=function(e,t){if(f(n)&&(t=u(n,this,d(e),t)),!p(t))return t},s(g,null,r)}function a(e,t,r){var n=x(r,t-1),r=x(r,t+1);return y(E,e)&&!y(A,r)||y(A,e)&&!y(E,n)?"\\u"+w(b(e,0),16):e}var n=r(6518),o=r(7751),s=r(8745),u=r(9565),c=r(9504),l=r(9039),f=r(4901),p=r(757),m=r(7680),h=r(6933),r=r(4495),d=String,g=o("JSON","stringify"),y=c(/./.exec),x=c("".charAt),b=c("".charCodeAt),v=c("".replace),w=c(1..toString),N=/[\uD800-\uDFFF]/g,E=/^[\uD800-\uDBFF]$/,A=/^[\uDC00-\uDFFF]$/,S=!r||l(function(){var e=o("Symbol")("stringify detection");return"[null]"!==g([e])||"{}"!==g({a:e})||"{}"!==g(Object(e))}),M=l(function(){return'"\\udf06\\ud834"'!==g("\udf06\ud834")||'"\\udead"'!==g("\udead")});g&&n({target:"JSON",stat:!0,arity:3,forced:S||M},{stringify:function(e,t,r){var n=m(arguments),n=s(S?i:g,null,n);return M&&"string"==typeof n?v(n,N,a):n}})},6499:(e,t,r)=>{"use strict";var n=r(6518),l=r(9565),f=r(9306),i=r(6043),a=r(1103),p=r(2652);n({target:"Promise",stat:!0,forced:r(537)},{all:function(e){var s=this,t=i.f(s),u=t.resolve,c=t.reject,r=a(function(){var n=f(s.resolve),i=[],a=0,o=1;p(e,function(e){var t=a++,r=!1;o++,l(n,s,e).then(function(e){r||(r=!0,i[t]=e,--o||u(i))},c)}),--o||u(i)});return r.error&&c(r.value),t.promise}})},2003:(e,t,r)=>{"use strict";var n=r(6518),i=r(6395),a=r(916).CONSTRUCTOR,o=r(550),s=r(7751),u=r(4901),r=r(6840),c=o&&o.prototype;n({target:"Promise",proto:!0,forced:a,real:!0},{catch:function(e){return this.then(void 0,e)}}),!i&&u(o)&&(n=s("Promise").prototype.catch,c.catch!==n&&r(c,"catch",n,{unsafe:!0}))},436:(e,k,t)=>{"use strict";function a(e,t){var r,n,i,a,o=t.value,s=1===t.state,u=s?e.ok:e.fail,c=e.resolve,l=e.reject,f=e.domain;try{u?(s||(2===t.rejection&&(a=t,h(d,m,function(){var e=a.facade;p?M.emit("rejectionHandled",e):B("rejectionhandled",e,a.value)})),t.rejection=1),!0===u?r=o:(f&&f.enter(),r=u(o),f&&(f.exit(),i=!0)),r===e.promise?l(new A("Promise-chain cycle")):(n=D(r))?h(n,r,c,l):c(r)):l(o)}catch(e){f&&!i&&f.exit(),l(e)}}var r,n,i,o=t(6518),s=t(6395),p=t(9088),m=t(4475),h=t(9565),u=t(6840),c=t(2967),q=t(687),R=t(7633),P=t(9306),l=t(4901),j=t(34),U=t(679),L=t(2293),d=t(9225).set,f=t(1955),$=t(3138),H=t(1103),G=t(8265),g=t(1181),y=t(550),x=t(916),t=t(6043),b="Promise",v=x.CONSTRUCTOR,Z=x.REJECTION_EVENT,x=x.SUBCLASSING,w=g.getterFor(b),V=g.set,g=y&&y.prototype,N=y,E=g,A=m.TypeError,S=m.document,M=m.process,C=t.f,W=C,Y=!!(S&&S.createEvent&&m.dispatchEvent),T="unhandledrejection",D=function(e){var t;return!(!j(e)||!l(t=e.then))&&t},F=function(r,i){r.notified||(r.notified=!0,f(function(){for(var e,n,t=r.reactions;e=t.get();)a(e,r);r.notified=!1,i&&!r.rejection&&(n=r,h(d,m,function(){var e,t=n.facade,r=n.value;if(O(n)&&(e=H(function(){p?M.emit("unhandledRejection",r,t):B(T,t,r)}),n.rejection=p||O(n)?2:1,e.error))throw e.value}))}))},B=function(e,t,r){var n;Y?((n=S.createEvent("Event")).promise=t,n.reason=r,n.initEvent(e,!1,!0),m.dispatchEvent(n)):n={promise:t,reason:r},!Z&&(t=m["on"+e])?t(n):e===T&&$("Unhandled promise rejection",r)},O=function(e){return 1!==e.rejection&&!e.parent},_=function(t,r,n){return function(e){t(r,e,n)}},z=function(e,t,r){e.done||(e.done=!0,(e=r?r:e).value=t,e.state=2,F(e,!0))},I=function(r,e,t){if(!r.done){r.done=!0,t&&(r=t);try{if(r.facade===e)throw new A("Promise can't be resolved itself");var n=D(e);n?f(function(){var t={done:!1};try{h(n,e,_(I,t,r),_(z,t,r))}catch(e){z(t,e,r)}}):(r.value=e,r.state=1,F(r,!1))}catch(e){z({done:!1},e,r)}}};if(v&&(E=(N=function(e){U(this,E),P(e),h(r,this);var t=w(this);try{e(_(I,t),_(z,t))}catch(e){z(t,e)}}).prototype,(r=function(e){V(this,{type:b,done:!1,notified:!1,parent:!1,reactions:new G,rejection:!1,state:0,value:void 0})}).prototype=u(E,"then",function(e,t){var r=w(this),n=C(L(this,N));return r.parent=!0,n.ok=!l(e)||e,n.fail=l(t)&&t,n.domain=p?M.domain:void 0,0===r.state?r.reactions.add(n):f(function(){a(n,r)}),n.promise}),n=function(){var e=new r,t=w(e);this.promise=e,this.resolve=_(I,t),this.reject=_(z,t)},t.f=C=function(e){return e===N||void 0===e?new n:W(e)},!s&&l(y)&&g!==Object.prototype)){i=g.then,x||u(g,"then",function(e,t){var r=this;return new N(function(e,t){h(i,r,e,t)}).then(e,t)},{unsafe:!0});try{delete g.constructor}catch(e){}c&&c(g,E)}o({global:!0,constructor:!0,wrap:!0,forced:v},{Promise:N}),q(N,b,!1,!0),R(b)},3362:(e,t,r)=>{"use strict";r(436),r(6499),r(2003),r(7743),r(1481),r(280)},7743:(e,t,r)=>{"use strict";var n=r(6518),a=r(9565),o=r(9306),s=r(6043),u=r(1103),c=r(2652);n({target:"Promise",stat:!0,forced:r(537)},{race:function(e){var r=this,n=s.f(r),i=n.reject,t=u(function(){var t=o(r.resolve);c(e,function(e){a(t,r,e).then(n.resolve,i)})});return t.error&&i(t.value),n.promise}})},1481:(e,t,r)=>{"use strict";var n=r(6518),i=r(6043);n({target:"Promise",stat:!0,forced:r(916).CONSTRUCTOR},{reject:function(e){var t=i.f(this);return(0,t.reject)(e),t.promise}})},280:(e,t,r)=>{"use strict";var n=r(6518),i=r(7751),a=r(6395),o=r(550),s=r(916).CONSTRUCTOR,u=r(3438),c=i("Promise"),l=a&&!s;n({target:"Promise",stat:!0,forced:a||s},{resolve:function(e){return u(l&&this===c?o:this,e)}})},4864:(k,q,e)=>{"use strict";var t=e(3724),r=e(4475),n=e(9504),i=e(2796),c=e(3167),l=e(6699),f=e(2360),a=e(8480).f,p=e(1625),m=e(788),h=e(655),d=e(1034),o=e(8429),s=e(1056),u=e(6840),g=e(9039),y=e(9297),x=e(1181).enforce,b=e(7633),v=e(8227),w=e(3635),N=e(8814),E=v("match"),A=r.RegExp,S=A.prototype,M=r.SyntaxError,R=n(S.exec),C=n("".charAt),T=n("".replace),D=n("".indexOf),P=n("".slice),j=/^\?<[^\s\d!#%&*+<=>@^][^\s!#%&*+<=>@^]*>/,F=/a/g,B=/a/g,e=new A(F)!==F,O=o.MISSED_STICKY,U=o.UNSUPPORTED_Y;if(i("RegExp",t&&(!e||O||w||N||g(function(){return B[E]=!1,A(F)!==F||A(B)===B||"/a/i"!==String(A(F,"i"))})))){for(var _=function(e,t){var r,n,i=p(S,this),a=m(e),o=void 0===t,s=[],u=e;if(!i&&a&&o&&e.constructor===_)return e;if((a||p(S,e))&&(e=e.source,o&&(t=d(u))),e=void 0===e?"":h(e),t=void 0===t?"":h(t),u=e,a=t=w&&"dotAll"in F&&(r=!!t&&-1<D(t,"s"))?T(t,/s/g,""):t,O&&"sticky"in F&&(n=!!t&&-1<D(t,"y"))&&U&&(t=T(t,/y/g,"")),N&&(e=(o=function(e){for(var t,r=e.length,n=0,i="",a=[],o=f(null),s=!1,u=!1,c=0,l="";n<=r;n++){if("\\"===(t=C(e,n)))t+=C(e,++n);else if("]"===t)s=!1;else if(!s)switch(!0){case"["===t:s=!0;break;case"("===t:R(j,P(e,n+1))&&(n+=2,u=!0),i+=t,c++;continue;case">"===t&&u:if(""===l||y(o,l))throw new M("Invalid capture group name");o[l]=!0,u=!(a[a.length]=[l,c]),l="";continue}u?l+=t:i+=t}return[i,a]}(e))[0],s=o[1]),o=c(A(e,t),i?this:S,_),(r||n||s.length)&&(t=x(o),r&&(t.dotAll=!0,t.raw=_(function(e){for(var t,r=e.length,n=0,i="",a=!1;n<=r;n++)"\\"!==(t=C(e,n))?a||"."!==t?("["===t?a=!0:"]"===t&&(a=!1),i+=t):i+="[\\s\\S]":i+=t+C(e,++n);return i}(e),a)),n&&(t.sticky=!0),s.length&&(t.groups=s)),e!==u)try{l(o,"source",""===u?"(?:)":u)}catch(e){}return o},z=a(A),I=0;z.length>I;)s(_,A,z[I++]);(S.constructor=_).prototype=S,u(r,"RegExp",_,{constructor:!0})}b("RegExp")},7465:(e,t,r)=>{"use strict";var n=r(3724),i=r(3635),a=r(4576),o=r(2106),s=r(1181).get,u=RegExp.prototype,c=TypeError;n&&i&&o(u,"dotAll",{configurable:!0,get:function(){if(this!==u){if("RegExp"===a(this))return!!s(this).dotAll;throw new c("Incompatible receiver, RegExp required")}}})},7495:(e,t,r)=>{"use strict";var n=r(6518),r=r(7323);n({target:"RegExp",proto:!0,forced:/./.exec!==r},{exec:r})},5440:(e,t,r)=>{"use strict";var N=r(8745),i=r(9565),n=r(9504),a=r(9228),o=r(9039),E=r(8551),A=r(4901),s=r(4117),S=r(1291),M=r(8014),C=r(655),u=r(7750),T=r(7829),c=r(5966),D=r(2478),F=r(6682),l=r(8227)("replace"),B=Math.max,O=Math.min,_=n([].concat),z=n([].push),I=n("".indexOf),k=n("".slice),r="$0"==="a".replace(/./,"$0"),f=!!/./[l]&&""===/./[l]("a","$0");a("replace",function(e,b,v){var w=f?"$":"$0";return[function(e,t){var r=u(this),n=s(e)?void 0:c(e,l);return n?i(n,e,r,t):i(b,C(r),e,t)},function(e,t){var r=E(this),n=C(e);if("string"==typeof t&&-1===I(t,w)&&-1===I(t,"$<")){e=v(b,r,n,t);if(e.done)return e.value}var i=A(t);i||(t=C(t));var a,o=r.global;o&&(a=r.unicode,r.lastIndex=0);for(var s,u=[];null!==(s=F(r,n))&&(z(u,s),o);)""===C(s[0])&&(r.lastIndex=T(n,M(r.lastIndex),a));for(var c,l="",f=0,p=0;p<u.length;p++){for(var m=C((s=u[p])[0]),h=B(O(S(s.index),n.length),0),d=[],g=1;g<s.length;g++)z(d,void 0===(c=s[g])?c:String(c));var y=s.groups,x=i?(x=_([m],d,h,n),void 0!==y&&z(x,y),C(N(t,void 0,x))):D(m,n,h,d,y,t);f<=h&&(l+=k(n,f,h)+x,f=h+m.length)}return l+k(n,f)}]},!!o(function(){var e=/./;return e.exec=function(){var e=[];return e.groups={a:"7"},e},"7"!=="".replace(e,"$<a>")})||!r||f)},9463:(e,t,r)=>{"use strict";var n,i,a,o,s,u,c,l=r(6518),f=r(3724),p=r(4475),m=r(9504),h=r(9297),d=r(4901),g=r(1625),y=r(655),x=r(2106),r=r(7740),b=p.Symbol,v=b&&b.prototype;!f||!d(b)||"description"in v&&void 0===b().description||(n={},r(p=function(){var e=arguments.length<1||void 0===arguments[0]?void 0:y(arguments[0]),t=g(v,this)?new b(e):void 0===e?b():b(e);return""===e&&(n[t]=!0),t},b),(p.prototype=v).constructor=p,i="Symbol(description detection)"===String(b("description detection")),a=m(v.valueOf),o=m(v.toString),s=/^Symbol\((.*)\)[^)]+$/,u=m("".replace),c=m("".slice),x(v,"description",{configurable:!0,get:function(){var e=a(this);if(h(n,e))return"";e=o(e),e=i?c(e,7,-1):u(e,s,"$1");return""===e?void 0:e}}),l({global:!0,constructor:!0,forced:!0},{Symbol:p}))},2369:function(e){e.exports=function(){"use strict";function T(){return!0}function le(){return!1}function fe(){}const D="Argument is not a typed-function.";return function e(){function l(e){return"object"==typeof e&&null!==e&&e.constructor===Object}const t=[{name:"number",test:function(e){return"number"==typeof e}},{name:"string",test:function(e){return"string"==typeof e}},{name:"boolean",test:function(e){return"boolean"==typeof e}},{name:"Function",test:function(e){return"function"==typeof e}},{name:"Array",test:Array.isArray},{name:"Date",test:function(e){return e instanceof Date}},{name:"RegExp",test:function(e){return e instanceof RegExp}},{name:"Object",test:l},{name:"null",test:function(e){return null===e}},{name:"undefined",test:function(e){return void 0===e}}],r={name:"any",test:T,isAny:!0};let a,o,i=0,J={createCount:0};function s(e){var t=a.get(e);if(t)return t;let r='Unknown type "'+e+'"';var n=e.toLowerCase();let i;for(i of o)if(i.toLowerCase()===n){r+='. Did you mean "'+i+'" ?';break}throw new TypeError(r)}function n(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"any";const r=e?s(e).index:o.length,n=[];for(let e=0;e<t.length;++e){if(!t[e]||"string"!=typeof t[e].name||"function"!=typeof t[e].test)throw new TypeError("Object with properties {name: string, test: function} expected");const i=t[e].name;if(a.has(i))throw new TypeError('Duplicate type name "'+i+'"');n.push(i),a.set(i,{name:i,test:t[e].test,isAny:t[e].isAny,index:r+e,conversionsTo:[]})}const i=o.slice(r);o=o.slice(0,r).concat(n).concat(i);for(let e=r+n.length;e<o.length;++e)a.get(o[e]).index=e}function u(){a=new Map,o=[],i=0,n([r],!1)}function c(r){var e=o.filter(e=>{const t=a.get(e);return!t.isAny&&t.test(r)});return e.length?e:["any"]}function f(e){return e&&"function"==typeof e&&"_typedFunctionData"in e}function p(r,n,i){if(!f(r))throw new TypeError(D);const a=i&&i.exact,o=Q(Array.isArray(n)?n.join(","):n),e=X(o);if(!a||e in r.signatures){const n=r._typedFunctionData.signatureMap.get(e);if(n)return n}var s=o.length;let u,t;if(a){let e;for(e in u=[],r.signatures)u.push(r._typedFunctionData.signatureMap.get(e))}else u=r._typedFunctionData.signatures;for(let t=0;t<s;++t){const n=o[t],i=[];let e;for(e of u){const a=h(e.params,t);if(a&&(!n.restParam||a.restParam)){if(!a.hasAny){const r=m(a);if(n.types.some(e=>!r.has(e.name)))continue}i.push(e)}}if(0===(u=i).length)break}for(t of u)if(t.params.length<=s)return t;throw new TypeError("Signature not found (signature: "+(r.name||"unnamed")+"("+X(o,", ")+"))")}function X(e,t){t=1<arguments.length&&void 0!==t?t:",";return e.map(e=>e.name).join(t)}function oe(e){const t=function(e){if(0===e.length)return[];const r=e.map(s);1<e.length&&r.sort((e,t)=>e.index-t.index);let n=r[0].conversionsTo;if(1===e.length)return n;n=n.concat([]);const i=new Set(e);for(let t=1;t<r.length;++t){let e;for(e of r[t].conversionsTo)i.has(e.from)||(n.push(e),i.add(e.from))}return n}(e.types.map(e=>e.name));let r=e.hasAny,n=e.name;var i=t.map(function(e){var t=s(e.from);return r=t.isAny||r,n+="|"+e.from,{name:e.from,typeIndex:t.index,test:t.test,isAny:t.isAny,conversion:e,conversionIndex:e.index}});return{types:e.types.concat(i),name:n,hasAny:r,hasConversion:0<i.length,restParam:e.restParam}}function m(t){return t.typeSet||(t.typeSet=new Set,t.types.forEach(e=>t.typeSet.add(e.name))),t.typeSet}function Q(e){const t=[];if("string"!=typeof e)throw new TypeError("Signatures must be strings");const r=e.trim();if(""===r)return t;const n=r.split(",");for(let e=0;e<n.length;++e){const r=function(e){const t=0===e.indexOf("..."),r=(t?3<e.length?e.slice(3):"any":e).split("|").map(e=>s(e.trim()));let n=!1,i=t?"...":"";return{types:r.map(function(e){return n=e.isAny||n,i+=e.name+"|",{name:e.name,typeIndex:e.index,test:e.test,isAny:e.isAny,conversion:null,conversionIndex:-1}}),name:i.slice(0,-1),hasAny:n,hasConversion:!1,restParam:t}}(n[e].trim());if(r.restParam&&e!==n.length-1)throw new SyntaxError('Unexpected rest parameter "'+n[e]+'": only allowed for the last parameter');if(0===r.types.length)return null;t.push(r)}return t}function K(e){e=ie(e);return!!e&&e.restParam}function ee(e){if(e&&0!==e.types.length){if(1===e.types.length)return s(e.types[0].name).test;if(2===e.types.length){const T=s(e.types[0].name).test,t=s(e.types[1].name).test;return function(e){return T(e)||t(e)}}{const T=e.types.map(function(e){return s(e.name).test});return function(t){for(let e=0;e<T.length;e++)if(T[e](t))return!0;return!1}}}return T}function h(e,t){return t<e.length?e[t]:K(e)?ie(e):null}function te(e,t){e=h(e,t);return e?m(e):new Set}function re(e){return null===e.conversion||void 0===e.conversion}function d(e,r){const n=new Set;return e.forEach(e=>{let t;for(t of te(e.params,r))n.add(t)}),n.has("any")?["any"]:Array.from(n)}function g(r,n,e){let t,i;var a=r||"unnamed";let o,s=e;for(o=0;o<n.length;o++){const r=[];if(s.forEach(e=>{const t=ee(h(e.params,o));(o<e.params.length||K(e.params))&&t(n[o])&&r.push(e)}),0===r.length){if(0<(i=d(s,o)).length){const r=c(n[o]);return(t=new TypeError("Unexpected type of argument in function "+a+" (expected: "+i.join(" or ")+", actual: "+r.join(" | ")+", index: "+o+")")).data={category:"wrongType",fn:a,index:o,actual:r,expected:i},t}}else s=r}r=s.map(function(e){return K(e.params)?1/0:e.params.length});if(n.length<Math.min.apply(null,r))return i=d(s,o),(t=new TypeError("Too few arguments in function "+a+" (expected: "+i.join(" or ")+", index: "+n.length+")")).data={category:"tooFewArgs",fn:a,index:n.length,expected:i},t;e=Math.max.apply(null,r);if(n.length>e)return(t=new TypeError("Too many arguments in function "+a+" (expected: "+e+", actual: "+n.length+")")).data={category:"tooManyArgs",fn:a,index:n.length,expectedLength:e},t;const u=[];for(let e=0;e<n.length;++e)u.push(c(n[e]).join("|"));return(t=new TypeError('Arguments of type "'+u.join(", ")+'" do not match any of the defined signatures of function '+a+".")).data={category:"mismatch",actual:u},t}function y(t){let r=o.length+1;for(let e=0;e<t.types.length;e++)re(t.types[e])&&(r=Math.min(r,t.types[e].typeIndex));return r}function x(t){let r=i+1;for(let e=0;e<t.types.length;e++)re(t.types[e])||(r=Math.min(r,t.types[e].conversionIndex));return r}function se(e,t){var r=e.params,n=t.params,e=ie(r),t=ie(n),i=K(r),a=K(n);if(i&&e.hasAny){if(!a||!t.hasAny)return 1}else if(a&&t.hasAny)return-1;let o,s=0,u=0;for(o of r)o.hasAny&&++s,o.hasConversion&&++u;let c=0,l=0;for(o of n)o.hasAny&&++c,o.hasConversion&&++l;if(s!==c)return s-c;if(i&&e.hasConversion){if(!a||!t.hasConversion)return 1}else if(a&&t.hasConversion)return-1;if(u!==l)return u-l;if(i){if(!a)return 1}else if(a)return-1;e=(r.length-n.length)*(i?-1:1);if(0!=e)return e;const f=[];let p,m=0;for(let e=0;e<r.length;++e){const t=function(e,t){if(e.hasAny){if(!t.hasAny)return 1}else if(t.hasAny)return-1;if(e.restParam){if(!t.restParam)return 1}else if(t.restParam)return-1;if(e.hasConversion){if(!t.hasConversion)return 1}else if(t.hasConversion)return-1;var r=y(e)-y(t);return r<0?-1:0<r?1:(r=x(e)-x(t))<0?-1:0<r?1:0}(r[e],n[e]);f.push(t),m+=t}if(0!==m)return m;for(p of f)if(0!==p)return p;return 0}function ue(e){let t,r,n,i;const a=[],o=[];switch(e.types.forEach(function(e){e.conversion&&(a.push(s(e.conversion.from).test),o.push(e.conversion.convert))}),o.length){case 0:return function(e){return e};case 1:return t=a[0],n=o[0],function(e){return t(e)?n(e):e};case 2:return t=a[0],r=a[1],n=o[0],i=o[1],function(e){return t(e)?n(e):r(e)?i(e):e};default:return function(t){for(let e=0;e<o.length;e++)if(a[e](t))return o[e](t);return t}}}function ce(e,r,n){const i=e.map(e=>E(e)?w(e.referToSelf.callback):N(e)?v(e.referTo.references,e.referTo.callback):e),a=new Array(i.length).fill(!1);let o=!0;for(;o;){let t=!(o=!1);for(let e=0;e<i.length;++e)if(!a[e]){const s=i[e];if(E(s))i[e]=s.referToSelf.callback(n),i[e].referToSelf=s.referToSelf,a[e]=!0,t=!1;else if(N(s)){const n=function(e,t,r){const n=[];let i;for(i of e){var a=r[i];if("number"!=typeof a)throw new TypeError('No definition for referenced signature "'+i+'"');if("function"!=typeof(a=t[a]))return!1;n.push(a)}return n}(s.referTo.references,i,r);n?(i[e]=s.referTo.callback.apply(this,n),i[e].referTo=s.referTo,a[e]=!0,t=!1):o=!0}}if(t&&o)throw new SyntaxError("Circular reference detected in resolving typed.referTo")}return i}function M(t,r){if(J.createCount++,0===Object.keys(r).length)throw new SyntaxError("No signatures provided");if(J.warnAgainstDeprecatedThis){var n=r;const I=/\bthis(\(|\.signatures\b)/;Object.keys(n).forEach(e=>{const t=n[e];if(I.test(t.toString()))throw new SyntaxError("Using `this` to self-reference a function is deprecated since typed-function@3. Use typed.referTo and typed.referToSelf instead.")})}const i=[],a=[],o={},s=[];let u;for(u in r)if(Object.prototype.hasOwnProperty.call(r,u)){const t=Q(u);if(t){i.forEach(function(e){if(function(n,i){const a=Math.max(n.length,i.length);for(let r=0;r<a;r++){const a=te(n,r),o=te(i,r);let e,t=!1;for(e of o)if(a.has(e)){t=!0;break}if(!t)return}const e=n.length,o=i.length,t=K(n),r=K(i);return t?r?e===o:o>=e:r?e>=o:e===o}(e,t))throw new TypeError('Conflicting signatures "'+X(e)+'" and "'+X(t)+'".')}),i.push(t);const le=a.length,fe=(a.push(r[u]),t.map(oe));let e;for(e of function t(r,n,i){if(n<r.length){const o=r[n];let e=[];if(o.restParam){const t=o.types.filter(re);t.length<o.types.length&&e.push({types:t,name:"..."+t.map(e=>e.name).join("|"),hasAny:t.some(e=>e.isAny),hasConversion:!1,restParam:!0}),e.push(o)}else e=o.types.map(function(e){return{types:[e],name:e.name,hasAny:e.isAny,hasConversion:e.conversion,restParam:!1}});return a=e,Array.prototype.concat.apply([],a.map(function(e){return t(r,n+1,i.concat([e]))}))}var a;return[i]}(fe,0,[])){const t=X(e);s.push({params:e,name:t,fn:le}),e.every(e=>!e.hasConversion)&&(o[t]=le)}}}s.sort(se);var e=ce(a,o,z);let c;for(c in o)Object.prototype.hasOwnProperty.call(o,c)&&(o[c]=e[o[c]]);const l=[],f=new Map;for(c of s)f.has(c.name)||(c.fn=e[c.fn],l.push(c),f.set(c.name,c));var p=l[0]&&l[0].params.length<=2&&!K(l[0].params),m=l[1]&&l[1].params.length<=2&&!K(l[1].params),h=l[2]&&l[2].params.length<=2&&!K(l[2].params),d=l[3]&&l[3].params.length<=2&&!K(l[3].params),g=l[4]&&l[4].params.length<=2&&!K(l[4].params),y=l[5]&&l[5].params.length<=2&&!K(l[5].params),x=p&&m&&h&&d&&g&&y;for(let e=0;e<l.length;++e)l[e].test=function(e){let r,n,i;if(K(e)){const n=(r=ne(e).map(ee)).length,i=ee(ie(e)),a=function(t){for(let e=n;e<t.length;e++)if(!i(t[e]))return!1;return!0};return function(t){for(let e=0;e<r.length;e++)if(!r[e](t[e]))return!1;return a(t)&&t.length>=n+1}}return 0===e.length?function(e){return 0===e.length}:1===e.length?(n=ee(e[0]),function(e){return n(e[0])&&1===e.length}):2===e.length?(n=ee(e[0]),i=ee(e[1]),function(e){return n(e[0])&&i(e[1])&&2===e.length}):(r=e.map(ee),function(t){for(let e=0;e<r.length;e++)if(!r[e](t[e]))return!1;return t.length===r.length})}(l[e].params);const b=p?ee(l[0].params[0]):le,v=m?ee(l[1].params[0]):le,w=h?ee(l[2].params[0]):le,N=d?ee(l[3].params[0]):le,E=g?ee(l[4].params[0]):le,A=y?ee(l[5].params[0]):le,S=p?ee(l[0].params[1]):le,M=m?ee(l[1].params[1]):le,C=h?ee(l[2].params[1]):le,T=d?ee(l[3].params[1]):le,D=g?ee(l[4].params[1]):le,F=y?ee(l[5].params[1]):le;for(let e=0;e<l.length;++e)l[e].implementation=function(e,n){let t=n;if(e.some(e=>e.hasConversion)){const i=K(e),a=e.map(ue);t=function(){const t=[],r=i?arguments.length-1:arguments.length;for(let e=0;e<r;e++)t[e]=a[e](arguments[e]);return i&&(t[r]=arguments[r].map(a[r])),n.apply(this,t)}}let i=t;if(K(e)){const n=e.length-1;i=function(){return t.apply(this,ae(arguments,0,n).concat([ae(arguments,n)]))}}return i}(l[e].params,l[e].fn);const B=p?l[0].implementation:fe,O=m?l[1].implementation:fe,_=h?l[2].implementation:fe,k=d?l[3].implementation:fe,q=g?l[4].implementation:fe,R=y?l[5].implementation:fe,P=p?l[0].params.length:-1,j=m?l[1].params.length:-1,U=h?l[2].params.length:-1,L=d?l[3].params.length:-1,$=g?l[4].params.length:-1,H=y?l[5].params.length:-1,G=x?6:0,Z=l.length,V=l.map(e=>e.test),W=l.map(e=>e.implementation),Y=function(){for(let e=G;e<Z;e++)if(V[e](arguments))return W[e].apply(this,arguments);return J.onMismatch(t,arguments,l)};function z(e,t){return(arguments.length===P&&b(e)&&S(t)?B:arguments.length===j&&v(e)&&M(t)?O:arguments.length===U&&w(e)&&C(t)?_:arguments.length===L&&N(e)&&T(t)?k:arguments.length===$&&E(e)&&D(t)?q:arguments.length===H&&A(e)&&F(t)?R:Y).apply(this,arguments)}try{Object.defineProperty(z,"name",{value:t})}catch(t){}return z.signatures=o,z._typedFunctionData={signatures:l,signatureMap:f},z}function b(e,t,r){throw g(e,t,r)}function ne(e){return ae(e,0,e.length-1)}function ie(e){return e[e.length-1]}function ae(e,t,r){return Array.prototype.slice.call(e,t,r)}function v(e,t){return{referTo:{references:e,callback:t}}}function w(e){if("function"!=typeof e)throw new TypeError("Callback function expected as first argument");return{referToSelf:{callback:e}}}function N(e){return e&&"object"==typeof e.referTo&&Array.isArray(e.referTo.references)&&"function"==typeof e.referTo.callback}function E(e){return e&&"object"==typeof e.referToSelf&&"function"==typeof e.referToSelf.callback}function A(e,t){if(!e)return t;if(t&&t!==e){const r=new Error("Function names do not match (expected: "+e+", actual: "+t+")");throw r.data={actual:t,expected:e},r}return e}u(),n(t);var C=J;function S(e){if(!e||"string"!=typeof e.from||"string"!=typeof e.to||"function"!=typeof e.convert)throw new TypeError("Object with properties {from: string, to: string, convert: function} expected");if(e.to===e.from)throw new SyntaxError('Illegal to define conversion from "'+e.from+'" to itself.')}return(J=function(e){const n="string"==typeof e;let i=n?e:"";var a={};for(let r=n?1:0;r<arguments.length;++r){var o=arguments[r];let e,t={};if("function"==typeof o?(e=o.name,"string"==typeof o.signature?t[o.signature]=o:f(o)&&(t=o.signatures)):l(o)&&(t=o,n||(e=function(e){let t;for(const r in e)Object.prototype.hasOwnProperty.call(e,r)&&(f(e[r])||"string"==typeof e[r].signature)&&(t=A(t,e[r].name));return t}(o))),0===Object.keys(t).length){const n=new TypeError("Argument to 'typed' at index "+r+" is not a (typed) function, nor an object with signatures as keys and functions as values.");throw n.data={index:r,argument:o},n}n||(i=A(i,e));{s=void 0;u=void 0;var s=a;var u=t;let e;for(e in u)if(Object.prototype.hasOwnProperty.call(u,e)){if(e in s&&u[e]!==s[e]){const c=new Error('Signature "'+e+'" is defined twice');throw c.data={signature:e,sourceFunction:u[e],destFunction:s[e]},c}s[e]=u[e]}}}return M(i||"",a)}).create=e,J.createCount=C.createCount,J.onMismatch=b,J.throwMismatchError=b,J.createError=g,J.clear=u,J.clearConversions=function(){let e;for(e of o)a.get(e).conversionsTo=[];i=0},J.addTypes=n,J._findType=s,J.referTo=function(){var e=ne(arguments).map(e=>X(Q(e))),t=ie(arguments);if("function"!=typeof t)throw new TypeError("Callback function expected as last argument");return v(e,t)},J.referToSelf=w,J.convert=function(t,e){const r=s(e);if(r.test(t))return t;const n=r.conversionsTo;if(0===n.length)throw new Error("There are no conversions to "+e+" defined.");for(let e=0;e<n.length;e++)if(s(n[e].from).test(t))return n[e].convert(t);throw new Error("Cannot convert "+t+" to "+e)},J.findSignature=p,J.find=function(e,t,r){return p(e,t,r).implementation},J.isTypedFunction=f,J.warnAgainstDeprecatedThis=!0,J.addType=function(e,t){let r="any";!1!==t&&a.has("Object")&&(r="Object"),J.addTypes([e],r)},J.addConversion=function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{override:!1};S(t);const r=s(t.to),n=r.conversionsTo.find(e=>e.from===t.from);if(n){if(!e||!e.override)throw new Error('There is already a conversion from "'+t.from+'" to "'+r.name+'"');J.removeConversion({from:n.from,to:t.to,convert:n.convert})}r.conversionsTo.push({from:t.from,convert:t.convert,index:i++})},J.addConversions=function(e,t){e.forEach(e=>J.addConversion(e,t))},J.removeConversion=function(r){S(r);const e=s(r.to),t=function(t){for(let e=0;e<t.length;e++)if(t[e].from===r.from)return t[e]}(e.conversionsTo);if(!t)throw new Error("Attempt to remove nonexistent conversion from "+r.from+" to "+r.to);if(t.convert!==r.convert)throw new Error("Conversion to remove does not match existing conversion");var n=e.conversionsTo.indexOf(t);e.conversionsTo.splice(n,1)},J.resolve=function(e,t){if(!f(e))throw new TypeError(D);const r=e._typedFunctionData.signatures;for(let e=0;e<r.length;++e)if(r[e].test(t))return r[e];return null},J}()}()}},n={};function kh(e){var t=n[e];if(void 0!==t)return t.exports;t=n[e]={id:e,loaded:!1,exports:{}};return r[e].call(t.exports,t,t.exports,kh),t.loaded=!0,t.exports}kh.amdD=function(){throw new Error("define cannot be used indirect")},kh.amdO={},kh.d=(e,t)=>{for(var r in t)kh.o(t,r)&&!kh.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},kh.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),kh.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},kh.nmd=e=>(e.paths=[],e.children||(e.children=[]),e);var qh={};return(()=>{"use strict";kh.d(qh,{default:()=>Ih});var t={};function E(e){return"number"==typeof e}function Q(e){return!(!e||"object"!=typeof e||"function"!=typeof e.constructor)&&(!0===e.isBigNumber&&"object"==typeof e.constructor.prototype&&!0===e.constructor.prototype.isBigNumber||"function"==typeof e.constructor.isDecimal&&!0===e.constructor.isDecimal(e))}function c(e){return"bigint"==typeof e}function te(e){return e&&"object"==typeof e&&!0===Object.getPrototypeOf(e).isComplex||!1}function I(e){return e&&"object"==typeof e&&!0===Object.getPrototypeOf(e).isFraction||!1}function L(e){return e&&!0===e.constructor.prototype.isUnit||!1}function k(e){return"string"==typeof e}kh.r(t),kh.d(t,{createAbs:()=>ea,createAccessorNode:()=>Rl,createAcos:()=>gc,createAcosh:()=>zc,createAcot:()=>Ic,createAcoth:()=>kc,createAcsc:()=>qc,createAcsch:()=>Rc,createAdd:()=>Sl,createAddScalar:()=>ia,createAnd:()=>bu,createAndTransform:()=>Sh,createApply:()=>ta,createApplyTransform:()=>th,createArg:()=>xo,createArrayNode:()=>jl,createAsec:()=>Pc,createAsech:()=>jc,createAsin:()=>Uc,createAsinh:()=>Lc,createAssignmentNode:()=>Zl,createAtan:()=>$c,createAtan2:()=>Hc,createAtanh:()=>Gc,createAtomicMass:()=>_0,createAvogadro:()=>z0,createBellNumbers:()=>lm,createBigNumberClass:()=>Hr,createBigint:()=>mi,createBignumber:()=>yi,createBin:()=>ks,createBitAnd:()=>po,createBitAndTransform:()=>Ch,createBitNot:()=>mo,createBitOr:()=>ho,createBitOrTransform:()=>Th,createBitXor:()=>yo,createBlockNode:()=>Wl,createBohrMagneton:()=>m0,createBohrRadius:()=>b0,createBoltzmann:()=>I0,createBoolean:()=>gi,createCatalan:()=>pm,createCbrt:()=>sa,createCeil:()=>fa,createChain:()=>Kf,createChainClass:()=>Wf,createClassicalElectronRadius:()=>v0,createClone:()=>Pn,createColumn:()=>Bo,createColumnTransform:()=>rh,createCombinations:()=>Fp,createCombinationsWithRep:()=>_p,createCompare:()=>wu,createCompareNatural:()=>Su,createCompareText:()=>Cu,createCompile:()=>Mf,createComplex:()=>xi,createComplexClass:()=>Zr,createComposition:()=>hm,createConcat:()=>Fo,createConcatTransform:()=>yh,createConditionalNode:()=>Jl,createConductanceQuantum:()=>h0,createConj:()=>bo,createConstantNode:()=>af,createCorr:()=>Mp,createCos:()=>Vc,createCosh:()=>Wc,createCot:()=>Yc,createCoth:()=>Jc,createCoulomb:()=>f0,createCount:()=>Oo,createCreateUnit:()=>dc,createCross:()=>_o,createCsc:()=>Xc,createCsch:()=>Qc,createCtranspose:()=>vs,createCube:()=>pa,createCumSum:()=>gp,createCumSumTransform:()=>Nh,createDeepEqual:()=>Zu,createDenseMatrixClass:()=>Rn,createDerivative:()=>Tm,createDet:()=>ep,createDeuteronMass:()=>M0,createDiag:()=>zo,createDiff:()=>Jo,createDiffTransform:()=>xh,createDistance:()=>pp,createDivide:()=>lp,createDivideScalar:()=>Vs,createDot:()=>Tl,createDotDivide:()=>nu,createDotMultiply:()=>Ya,createDotPow:()=>tu,createE:()=>Gm,createEfimovFactor:()=>O0,createEigs:()=>np,createElectricConstant:()=>c0,createElectronMass:()=>w0,createElementaryCharge:()=>p0,createEqual:()=>Du,createEqualScalar:()=>li,createEqualText:()=>Ou,createErf:()=>Ss,createEvaluate:()=>Tf,createExp:()=>ma,createExpm:()=>ip,createExpm1:()=>ha,createFactorial:()=>Hp,createFalse:()=>Pm,createFaraday:()=>k0,createFermiCoupling:()=>N0,createFft:()=>Ns,createFibonacciHeapClass:()=>ic,createFilter:()=>ko,createFilterTransform:()=>ih,createFineStructure:()=>E0,createFirstRadiation:()=>q0,createFix:()=>ga,createFlatten:()=>Po,createFloor:()=>ba,createForEach:()=>Uo,createForEachTransform:()=>oh,createFormat:()=>Is,createFraction:()=>bi,createFractionClass:()=>tn,createFreqz:()=>Om,createFunctionAssignmentNode:()=>sf,createFunctionNode:()=>Ef,createGamma:()=>Up,createGasConstant:()=>P0,createGcd:()=>Fa,createGetMatrixDataType:()=>Ho,createGravitationConstant:()=>a0,createGravity:()=>W0,createHartreeEnergy:()=>A0,createHasNumericValue:()=>ri,createHelp:()=>Qf,createHelpClass:()=>Vf,createHex:()=>Rs,createHypot:()=>Ml,createI:()=>Km,createIdentity:()=>Zo,createIfft:()=>Es,createIm:()=>vo,createImmutableDenseMatrixClass:()=>tc,createIndex:()=>Fl,createIndexClass:()=>rc,createIndexNode:()=>cf,createIndexTransform:()=>sh,createInfinity:()=>Um,createIntersect:()=>mp,createInv:()=>tp,createInverseConductanceQuantum:()=>d0,createInvmod:()=>Za,createIsInteger:()=>Vn,createIsNaN:()=>oi,createIsNegative:()=>Qn,createIsNumeric:()=>ei,createIsPositive:()=>ii,createIsPrime:()=>Hs,createIsZero:()=>ai,createKldivergence:()=>Zp,createKlitzing:()=>x0,createKron:()=>Vo,createLN10:()=>Wm,createLN2:()=>Vm,createLOG10E:()=>Jm,createLOG2E:()=>Ym,createLarger:()=>ju,createLargerEq:()=>$u,createLcm:()=>Oa,createLeafCount:()=>gm,createLeftShift:()=>hu,createLgamma:()=>Lp,createLog:()=>Xs,createLog10:()=>_a,createLog1p:()=>Qs,createLog2:()=>za,createLoschmidt:()=>R0,createLsolve:()=>au,createLsolveAll:()=>uu,createLup:()=>Bf,createLusolve:()=>Hf,createLyap:()=>cp,createMad:()=>bp,createMagneticConstant:()=>u0,createMagneticFluxQuantum:()=>g0,createMap:()=>Wo,createMapTransform:()=>uh,createMatrix:()=>vi,createMatrixClass:()=>nn,createMatrixFromColumns:()=>Mi,createMatrixFromFunction:()=>Ni,createMatrixFromRows:()=>Ai,createMax:()=>Ku,createMaxTransform:()=>fh,createMean:()=>yp,createMeanTransform:()=>ph,createMedian:()=>xp,createMin:()=>ec,createMinTransform:()=>mh,createMod:()=>Aa,createMode:()=>Os,createMolarMass:()=>Z0,createMolarMassC12:()=>V0,createMolarPlanckConstant:()=>j0,createMolarVolume:()=>U0,createMultinomial:()=>Wp,createMultiply:()=>qa,createMultiplyScalar:()=>Ia,createNaN:()=>Lm,createNeutronMass:()=>C0,createNode:()=>Ol,createNorm:()=>Cl,createNot:()=>Co,createNthRoot:()=>Pa,createNthRoots:()=>eu,createNuclearMagneton:()=>y0,createNull:()=>jm,createNumber:()=>pi,createNumeric:()=>Gs,createObjectNode:()=>ff,createOct:()=>qs,createOnes:()=>Xo,createOperatorNode:()=>hf,createOr:()=>To,createOrTransform:()=>Mh,createParenthesisNode:()=>gf,createParse:()=>Af,createParser:()=>Ff,createParserClass:()=>Df,createPartitionSelect:()=>Xu,createPermutations:()=>Jp,createPhi:()=>Zm,createPi:()=>$m,createPickRandom:()=>rm,createPinv:()=>rp,createPlanckCharge:()=>Q0,createPlanckConstant:()=>o0,createPlanckLength:()=>Y0,createPlanckMass:()=>J0,createPlanckTemperature:()=>K0,createPlanckTime:()=>X0,createPolynomialRoot:()=>Zf,createPow:()=>Ws,createPrint:()=>js,createPrintTransform:()=>Ah,createProd:()=>zs,createProtonMass:()=>S0,createQr:()=>Of,createQuantileSeq:()=>Ap,createQuantileSeqTransform:()=>wh,createQuantumOfCirculation:()=>T0,createRandom:()=>im,createRandomInt:()=>om,createRange:()=>ts,createRangeClass:()=>rn,createRangeNode:()=>xf,createRangeTransform:()=>hh,createRationalize:()=>Fm,createRe:()=>wo,createReducedPlanckConstant:()=>s0,createRelationalNode:()=>vf,createReplacer:()=>zm,createReshape:()=>ns,createResize:()=>is,createResolve:()=>Am,createResultSet:()=>lt,createReviver:()=>_m,createRightArithShift:()=>gu,createRightLogShift:()=>xu,createRotate:()=>as,createRotationMatrix:()=>ss,createRound:()=>Js,createRow:()=>us,createRowTransform:()=>dh,createRydberg:()=>D0,createSQRT1_2:()=>Xm,createSQRT2:()=>Qm,createSackurTetrode:()=>L0,createSchur:()=>up,createSec:()=>Kc,createSech:()=>el,createSecondRadiation:()=>$0,createSetCartesian:()=>ol,createSetDifference:()=>ul,createSetDistinct:()=>ll,createSetIntersect:()=>pl,createSetIsSubset:()=>hl,createSetMultiplicity:()=>gl,createSetPowerset:()=>xl,createSetSize:()=>vl,createSetSymDifference:()=>Nl,createSetUnion:()=>Al,createSign:()=>ja,createSimplify:()=>vm,createSimplifyConstant:()=>wm,createSimplifyCore:()=>Em,createSin:()=>tl,createSinh:()=>rl,createSize:()=>cs,createSlu:()=>Uf,createSmaller:()=>zu,createSmallerEq:()=>qu,createSolveODE:()=>As,createSort:()=>Qu,createSpaClass:()=>ac,createSparse:()=>mc,createSparseMatrixClass:()=>fi,createSpeedOfLight:()=>i0,createSplitUnit:()=>Ti,createSqrt:()=>Ua,createSqrtm:()=>ap,createSquare:()=>La,createSqueeze:()=>fs,createStd:()=>Sp,createStdTransform:()=>bh,createStefanBoltzmann:()=>H0,createStirlingS2:()=>um,createString:()=>hi,createSubset:()=>ps,createSubsetTransform:()=>gh,createSubtract:()=>Ha,createSubtractScalar:()=>oa,createSum:()=>hp,createSumTransform:()=>vh,createSylvester:()=>sp,createSymbolNode:()=>wf,createSymbolicEqual:()=>Mm,createTan:()=>nl,createTanh:()=>il,createTau:()=>Hm,createThomsonCrossSection:()=>F0,createTo:()=>Ls,createTrace:()=>Dl,createTranspose:()=>xs,createTrue:()=>Rm,createTypeOf:()=>si,createTyped:()=>ot,createUnaryMinus:()=>Xi,createUnaryPlus:()=>Ki,createUnequal:()=>Wu,createUnitClass:()=>fc,createUnitFunction:()=>pc,createUppercaseE:()=>t0,createUppercasePi:()=>e0,createUsolve:()=>ou,createUsolveAll:()=>lu,createVacuumImpedance:()=>l0,createVariance:()=>Np,createVarianceTransform:()=>Eh,createVersion:()=>r0,createWeakMixingAngle:()=>B0,createWienDisplacement:()=>G0,createXgcd:()=>Ga,createXor:()=>Do,createZeros:()=>ws,createZeta:()=>Bs,createZpk2tf:()=>Bm}),kh(4423),kh(7495),kh(4864),kh(7465);const g=Array.isArray;function _(e){return e&&!0===e.constructor.prototype.isMatrix||!1}function q(e){return Array.isArray(e)||_(e)}function R(e){return e&&e.isDenseMatrix&&!0===e.constructor.prototype.isMatrix||!1}function P(e){return e&&e.isSparseMatrix&&!0===e.constructor.prototype.isMatrix||!1}function h(e){return e&&!0===e.constructor.prototype.isRange||!1}function j(e){return e&&!0===e.constructor.prototype.isIndex||!1}function U(e){return"boolean"==typeof e}function $(e){return e&&!0===e.constructor.prototype.isResultSet||!1}function H(e){return e&&!0===e.constructor.prototype.isHelp||!1}function G(e){return"function"==typeof e}function Z(e){return e instanceof Date}function V(e){return e instanceof RegExp}function W(e){return!(!e||"object"!=typeof e||e.constructor!==Object||te(e)||I(e))}function Y(e){return null===e}function J(e){return void 0===e}function le(e){return e&&!0===e.isAccessorNode&&!0===e.constructor.prototype.isNode||!1}function X(e){return e&&!0===e.isArrayNode&&!0===e.constructor.prototype.isNode||!1}function re(e){return e&&!0===e.isAssignmentNode&&!0===e.constructor.prototype.isNode||!1}function ne(e){return e&&!0===e.isBlockNode&&!0===e.constructor.prototype.isNode||!1}function ie(e){return e&&!0===e.isConditionalNode&&!0===e.constructor.prototype.isNode||!1}function ae(e){return e&&!0===e.isConstantNode&&!0===e.constructor.prototype.isNode||!1}function fe(e){return ae(e)||oe(e)&&1===e.args.length&&ae(e.args[0])&&"-+~".includes(e.op)}function pe(e){return e&&!0===e.isFunctionAssignmentNode&&!0===e.constructor.prototype.isNode||!1}function me(e){return e&&!0===e.isFunctionNode&&!0===e.constructor.prototype.isNode||!1}function he(e){return e&&!0===e.isIndexNode&&!0===e.constructor.prototype.isNode||!1}function O(e){return e&&!0===e.isNode&&!0===e.constructor.prototype.isNode||!1}function de(e){return e&&!0===e.isObjectNode&&!0===e.constructor.prototype.isNode||!1}function oe(e){return e&&!0===e.isOperatorNode&&!0===e.constructor.prototype.isNode||!1}function ge(e){return e&&!0===e.isParenthesisNode&&!0===e.constructor.prototype.isNode||!1}function ye(e){return e&&!0===e.isRangeNode&&!0===e.constructor.prototype.isNode||!1}function xe(e){return e&&!0===e.isRelationalNode&&!0===e.constructor.prototype.isNode||!1}function se(e){return e&&!0===e.isSymbolNode&&!0===e.constructor.prototype.isNode||!1}function be(e){return e&&!0===e.constructor.prototype.isChain||!1}function K(e){var t=typeof e;return"object"==t?null===e?"null":Q(e)?"BigNumber":e.constructor&&e.constructor.name?e.constructor.name:"Object":t}var ve=kh(2369);function v(e){return"boolean"==typeof e||!!isFinite(e)&&e===Math.round(e)}function we(e,t){return"bigint"!==t.number||/^-?\d+$/.test(e)?t.number:t.numberFallback}kh(5440);const n=Math.sign||function(e){return 0<e?1:e<0?-1:0},r=Math.log2||function(e){return Math.log(e)/Math.LN2},i=Math.log10||function(e){return Math.log(e)/Math.LN10},Ne=Math.log1p||function(e){return Math.log(e+1)},a=Math.cbrt||function(e){if(0===e)return e;var t=e<0;let r;return t&&(e=-e),r=isFinite(e)?(e/((r=Math.exp(Math.log(e)/3))*r)+2*r)/3:e,t?-r:r},Ee=Math.expm1||function(e){return 2e-4<=e||e<=-2e-4?Math.exp(e)-1:e+e*e/2+e*e*e/6};function Ae(e,t,r){var n={2:"0b",8:"0o",16:"0x"}[t];let i="";if(r){if(r<1)throw new Error("size must be in greater than 0");if(!v(r))throw new Error("size must be an integer");if(2**(r-1)-1<e||e<-(2**(r-1)))throw new Error(`Value must be in range [-2^${r-1}, 2^${r-1}-1]`);if(!v(e))throw new Error("Value must be an integer");e<0&&(e+=2**r),i="i"+r}let a="";return e<0&&(e=-e,a="-"),""+a+n+e.toString(t)+i}function Se(r,e){if("function"==typeof e)return e(r);if(r===1/0)return"Infinity";if(r===-1/0)return"-Infinity";if(isNaN(r))return"NaN";var{notation:t,precision:n,wordSize:i}=Me(e);switch(t){case"fixed":return Te(r,n);case"exponential":return De(r,n);case"engineering":{var a=r;var o=n;if(isNaN(a)||!isFinite(a))return String(a);const s=Fe(Ce(a),o),u=s.exponent,c=s.coefficients,l=u%3==0?u:u<0?u-3-u%3:u-u%3;if(E(o))for(;o>c.length||u-l+1>c.length;)c.push(0);else{const a=Math.abs(u-l)-(c.length-1);for(let e=0;e<a;e++)c.push(0)}let e=Math.abs(u-l),t=1;for(;0<e;)t++,e--;const f=c.slice(t).join(""),p=E(o)&&f.length||f.match(/[1-9]/)?"."+f:"",m=c.slice(0,t).join("")+p+"e"+(0<=u?"+":"")+l.toString();return s.sign+m;return}case"bin":return Ae(r,2,i);case"oct":return Ae(r,8,i);case"hex":return Ae(r,16,i);case"auto":return function(e,t,r){if(isNaN(e)||!isFinite(e))return String(e);const n=Pe(null==r?void 0:r.lowerExp,-3),i=Pe(null==r?void 0:r.upperExp,5),a=Ce(e),o=t?Fe(a,t):a;if(o.exponent<n||o.exponent>=i)return De(e,t);{let e=o.coefficients;const r=o.exponent,n=(e=(e=e.length<t?e.concat(Be(t-e.length)):e).concat(Be(r-e.length+1+(e.length<t?t-e.length:0))),0<r?r:0);return n<(e=Be(-r).concat(e)).length-1&&e.splice(n+1,0,"."),o.sign+e.join("")}}(r,n,e).replace(/((\.\d*?)(0+))($|e)/,function(){var e=arguments[2],t=arguments[4];return"."!==e?e+t:t});default:throw new Error('Unknown notation "'+t+'". Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.')}}function Me(e){let t,r,n="auto";if(void 0!==e)if(E(e))t=e;else if(Q(e))t=e.toNumber();else{if(!W(e))throw new Error("Unsupported type of options, number, BigNumber, or object expected");void 0!==e.precision&&(t=Re(e.precision,()=>{throw new Error('Option "precision" must be a number or BigNumber')})),void 0!==e.wordSize&&(r=Re(e.wordSize,()=>{throw new Error('Option "wordSize" must be a number or BigNumber')})),e.notation&&(n=e.notation)}return{notation:n,precision:t,wordSize:r}}function Ce(e){var t=String(e).toLowerCase().match(/^(-?)(\d+\.?\d*)(e([+-]?\d+))?$/);if(!t)throw new SyntaxError("Invalid number "+e);const r=t[1],n=t[2];let i=parseFloat(t[4]||"0");e=n.indexOf(".");i+=-1!==e?e-1:n.length-1;const a=n.replace(".","").replace(/^0*/,function(e){return i-=e.length,""}).replace(/0*$/,"").split("").map(function(e){return parseInt(e)});return 0===a.length&&(a.push(0),i++),{sign:r,coefficients:a,exponent:i}}function Te(e,t){if(isNaN(e)||!isFinite(e))return String(e);e=Ce(e),e="number"==typeof t?Fe(e,e.exponent+1+t):e;let r=e.coefficients,n=e.exponent+1;t=n+(t||0);return r.length<t&&(r=r.concat(Be(t-r.length))),n<0&&(r=Be(1-n).concat(r),n=1),n<r.length&&r.splice(n,0,0===n?"0.":"."),e.sign+r.join("")}function De(e,t){if(isNaN(e)||!isFinite(e))return String(e);e=Ce(e),e=t?Fe(e,t):e;let r=e.coefficients;var n=e.exponent,t=(r=r.length<t?r.concat(Be(t-r.length)):r).shift();return e.sign+t+(0<r.length?"."+r.join(""):"")+"e"+(0<=n?"+":"")+n}function Fe(e,t){const r={sign:e.sign,coefficients:e.coefficients,exponent:e.exponent},n=r.coefficients;for(;t<=0;)n.unshift(0),r.exponent++,t++;if(n.length>t&&5<=n.splice(t,n.length-t)[0]){let e=t-1;for(n[e]++;10===n[e];)n.pop(),0===e&&(n.unshift(0),r.exponent++,e++),e--,n[e]++}return r}function Be(t){const r=[];for(let e=0;e<t;e++)r.push(0);return r}function p(e,t,r,n){r=2<arguments.length&&void 0!==r?r:1e-8,n=3<arguments.length&&void 0!==n?n:0;if(r<=0)throw new Error("Relative tolerance must be greater than 0");if(n<0)throw new Error("Absolute tolerance must be at least 0");return!isNaN(e)&&!isNaN(t)&&(isFinite(e)&&isFinite(t)?e===t||Math.abs(e-t)<=Math.max(r*Math.max(Math.abs(e),Math.abs(t)),n):e===t)}Number.EPSILON;const Oe=Math.acosh||function(e){return Math.log(Math.sqrt(e*e-1)+e)},_e=Math.asinh||function(e){return Math.log(Math.sqrt(e*e+1)+e)},ze=Math.atanh||function(e){return Math.log((1+e)/(1-e))/2},Ie=Math.cosh||function(e){return(Math.exp(e)+Math.exp(-e))/2},ke=Math.sinh||function(e){return(Math.exp(e)-Math.exp(-e))/2},qe=Math.tanh||function(e){e=Math.exp(2*e);return(e-1)/(e+1)};function Re(e,t){return E(e)?e:Q(e)?e.toNumber():void t()}function Pe(e,t){return E(e)?e:Q(e)?e.toNumber():t}function ee(e){var t=typeof e;if("number"==t||"bigint"==t||"string"==t||"boolean"==t||null==e)return e;if("function"==typeof e.clone)return e.clone();if(Array.isArray(e))return e.map(ee);if(e instanceof Date)return new Date(e.valueOf());if(Q(e))return e;if(W(e)){var r=e,n=ee;const i={};for(const a in r)ue(r,a)&&(i[a]=n(r[a]));return i}throw new TypeError(`Cannot clone: unknown type of value (value: ${e})`)}function je(e,t){for(const r in t)ue(t,r)&&(e[r]=t[r]);return e}function Ue(e,t){let r,n,i;if(Array.isArray(e)){if(!Array.isArray(t))return!1;if(e.length!==t.length)return!1;for(n=0,i=e.length;n<i;n++)if(!Ue(e[n],t[n]))return!1;return!0}if("function"==typeof e)return e===t;if(e instanceof Object){if(Array.isArray(t)||!(t instanceof Object))return!1;for(r in e)if(!(r in t&&Ue(e[r],t[r])))return!1;for(r in t)if(!(r in e))return!1;return!0}return e===t}function Le(e){var t={};return function e(t,r){for(const n in t)if(ue(t,n)){const i=t[n];"object"==typeof i&&null!==i?e(i,r):r[n]=i}}(e,t),t}function $e(e,t,r){let n,i=!0;Object.defineProperty(e,t,{get:function(){return i&&(n=r(),i=!1),n},set:function(e){n=e,i=!1},configurable:!0,enumerable:!0})}function ue(e,t){return e&&Object.hasOwnProperty.call(e,t)}function s(o,s,u,e){function t(e){var t=function(t,r){const n={};for(let e=0;e<r.length;e++){var i=r[e],a=t[i];void 0!==a&&(n[i]=a)}return n}(e,s.map(Ge)),r=o,n=s,i=e;if(n.filter(e=>!(e&&"?"===e[0])).every(e=>void 0!==i[e]))return u(t);{const a=n.filter(e=>void 0===i[e]);throw new Error(`Cannot create function "${r}", some dependencies are missing: ${a.map(e=>`"${e}"`).join(", ")}.`)}}return t.isFactory=!0,t.fn=o,t.dependencies=s.slice().sort(),e&&(t.meta=e),t}function He(e){return"function"==typeof e&&"string"==typeof e.fn&&Array.isArray(e.dependencies)}function Ge(e){return e&&"?"===e[0]?e.slice(1):e}function Ze(e,t){if(Je(e)&&We(e,t))return e[t];if("function"==typeof e[t]&&Ye(e,t))throw new Error('Cannot access method "'+t+'" as a property');throw new Error('No access to property "'+t+'"')}function Ve(e,t,r){if(Je(e)&&We(e,t))return e[t]=r;throw new Error('No access to property "'+t+'"')}function We(e,t){return e&&"object"==typeof e&&(ue(Xe,t)||!(t in Object.prototype||t in Function.prototype))}function Ye(e,t){return!(null==e||"function"!=typeof e[t]||ue(e,t)&&Object.getPrototypeOf&&t in Object.getPrototypeOf(e)||!ue(Qe,t)&&(t in Object.prototype||t in Function.prototype))}function Je(e){return"object"==typeof e&&e&&e.constructor===Object}kh(6910);const Xe={length:!0,name:!0},Qe={toString:!0,valueOf:!0,toLocaleString:!0};class Ke{constructor(e){this.wrappedObject=e,this[Symbol.iterator]=this.entries}keys(){return Object.keys(this.wrappedObject).values()}get(e){return Ze(this.wrappedObject,e)}set(e,t){return Ve(this.wrappedObject,e,t),this}has(e){return e in this.wrappedObject}entries(){return tt(this.keys(),e=>[e,this.get(e)])}forEach(e){for(const t of this.keys())e(this.get(t),t,this)}delete(e){delete this.wrappedObject[e]}clear(){for(const e of this.keys())this.delete(e)}get size(){return Object.keys(this.wrappedObject).length}}class et{constructor(e,t,r){this.a=e,this.b=t,this.bKeys=r,this[Symbol.iterator]=this.entries}get(e){return(this.bKeys.has(e)?this.b:this.a).get(e)}set(e,t){return(this.bKeys.has(e)?this.b:this.a).set(e,t),this}has(e){return this.b.has(e)||this.a.has(e)}keys(){return new Set([...this.a.keys(),...this.b.keys()])[Symbol.iterator]()}entries(){return tt(this.keys(),e=>[e,this.get(e)])}forEach(e){for(const t of this.keys())e(this.get(t),t,this)}delete(e){return(this.bKeys.has(e)?this.b:this.a).delete(e)}clear(){this.a.clear(),this.b.clear()}get size(){return[...this.keys()].length}}function tt(t,r){return{next:()=>{var e=t.next();return e.done?e:{value:r(e.value),done:!1}}}}function rt(){return new Map}function nt(e){if(!e)return rt();if(it(e))return e;if(W(e))return new Ke(e);throw new Error("createMap can create maps from objects or Maps")}function it(e){return!!e&&(e instanceof Map||e instanceof Ke||"function"==typeof e.set&&"function"==typeof e.get&&"function"==typeof e.keys&&"function"==typeof e.has)}let at=function(){return at=ve.create,ve};const ot=s("typed",["?BigNumber","?Complex","?DenseMatrix","?Fraction"],function(e){let{BigNumber:r,Complex:n,DenseMatrix:t,Fraction:i}=e;const a=at();return a.clear(),a.addTypes([{name:"number",test:E},{name:"Complex",test:te},{name:"BigNumber",test:Q},{name:"bigint",test:c},{name:"Fraction",test:I},{name:"Unit",test:L},{name:"identifier",test:e=>/^[A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}][0-9A-Za-z\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16F1-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC\u{10000}-\u{1000B}\u{1000D}-\u{10026}\u{10028}-\u{1003A}\u{1003C}\u{1003D}\u{1003F}-\u{1004D}\u{10050}-\u{1005D}\u{10080}-\u{100FA}\u{10280}-\u{1029C}\u{102A0}-\u{102D0}\u{10300}-\u{1031F}\u{1032D}-\u{10340}\u{10342}-\u{10349}\u{10350}-\u{10375}\u{10380}-\u{1039D}\u{103A0}-\u{103C3}\u{103C8}-\u{103CF}\u{10400}-\u{1049D}\u{104B0}-\u{104D3}\u{104D8}-\u{104FB}\u{10500}-\u{10527}\u{10530}-\u{10563}\u{10570}-\u{1057A}\u{1057C}-\u{1058A}\u{1058C}-\u{10592}\u{10594}\u{10595}\u{10597}-\u{105A1}\u{105A3}-\u{105B1}\u{105B3}-\u{105B9}\u{105BB}\u{105BC}\u{10600}-\u{10736}\u{10740}-\u{10755}\u{10760}-\u{10767}\u{10780}-\u{10785}\u{10787}-\u{107B0}\u{107B2}-\u{107BA}\u{10800}-\u{10805}\u{10808}\u{1080A}-\u{10835}\u{10837}\u{10838}\u{1083C}\u{1083F}-\u{10855}\u{10860}-\u{10876}\u{10880}-\u{1089E}\u{108E0}-\u{108F2}\u{108F4}\u{108F5}\u{10900}-\u{10915}\u{10920}-\u{10939}\u{10980}-\u{109B7}\u{109BE}\u{109BF}\u{10A00}\u{10A10}-\u{10A13}\u{10A15}-\u{10A17}\u{10A19}-\u{10A35}\u{10A60}-\u{10A7C}\u{10A80}-\u{10A9C}\u{10AC0}-\u{10AC7}\u{10AC9}-\u{10AE4}\u{10B00}-\u{10B35}\u{10B40}-\u{10B55}\u{10B60}-\u{10B72}\u{10B80}-\u{10B91}\u{10C00}-\u{10C48}\u{10C80}-\u{10CB2}\u{10CC0}-\u{10CF2}\u{10D00}-\u{10D23}\u{10E80}-\u{10EA9}\u{10EB0}\u{10EB1}\u{10F00}-\u{10F1C}\u{10F27}\u{10F30}-\u{10F45}\u{10F70}-\u{10F81}\u{10FB0}-\u{10FC4}\u{10FE0}-\u{10FF6}\u{11003}-\u{11037}\u{11071}\u{11072}\u{11075}\u{11083}-\u{110AF}\u{110D0}-\u{110E8}\u{11103}-\u{11126}\u{11144}\u{11147}\u{11150}-\u{11172}\u{11176}\u{11183}-\u{111B2}\u{111C1}-\u{111C4}\u{111DA}\u{111DC}\u{11200}-\u{11211}\u{11213}-\u{1122B}\u{1123F}\u{11240}\u{11280}-\u{11286}\u{11288}\u{1128A}-\u{1128D}\u{1128F}-\u{1129D}\u{1129F}-\u{112A8}\u{112B0}-\u{112DE}\u{11305}-\u{1130C}\u{1130F}\u{11310}\u{11313}-\u{11328}\u{1132A}-\u{11330}\u{11332}\u{11333}\u{11335}-\u{11339}\u{1133D}\u{11350}\u{1135D}-\u{11361}\u{11400}-\u{11434}\u{11447}-\u{1144A}\u{1145F}-\u{11461}\u{11480}-\u{114AF}\u{114C4}\u{114C5}\u{114C7}\u{11580}-\u{115AE}\u{115D8}-\u{115DB}\u{11600}-\u{1162F}\u{11644}\u{11680}-\u{116AA}\u{116B8}\u{11700}-\u{1171A}\u{11740}-\u{11746}\u{11800}-\u{1182B}\u{118A0}-\u{118DF}\u{118FF}-\u{11906}\u{11909}\u{1190C}-\u{11913}\u{11915}\u{11916}\u{11918}-\u{1192F}\u{1193F}\u{11941}\u{119A0}-\u{119A7}\u{119AA}-\u{119D0}\u{119E1}\u{119E3}\u{11A00}\u{11A0B}-\u{11A32}\u{11A3A}\u{11A50}\u{11A5C}-\u{11A89}\u{11A9D}\u{11AB0}-\u{11AF8}\u{11C00}-\u{11C08}\u{11C0A}-\u{11C2E}\u{11C40}\u{11C72}-\u{11C8F}\u{11D00}-\u{11D06}\u{11D08}\u{11D09}\u{11D0B}-\u{11D30}\u{11D46}\u{11D60}-\u{11D65}\u{11D67}\u{11D68}\u{11D6A}-\u{11D89}\u{11D98}\u{11EE0}-\u{11EF2}\u{11F02}\u{11F04}-\u{11F10}\u{11F12}-\u{11F33}\u{11FB0}\u{12000}-\u{12399}\u{12480}-\u{12543}\u{12F90}-\u{12FF0}\u{13000}-\u{1342F}\u{13441}-\u{13446}\u{14400}-\u{14646}\u{16800}-\u{16A38}\u{16A40}-\u{16A5E}\u{16A70}-\u{16ABE}\u{16AD0}-\u{16AED}\u{16B00}-\u{16B2F}\u{16B40}-\u{16B43}\u{16B63}-\u{16B77}\u{16B7D}-\u{16B8F}\u{16E40}-\u{16E7F}\u{16F00}-\u{16F4A}\u{16F50}\u{16F93}-\u{16F9F}\u{16FE0}\u{16FE1}\u{16FE3}\u{17000}-\u{187F7}\u{18800}-\u{18CD5}\u{18D00}-\u{18D08}\u{1AFF0}-\u{1AFF3}\u{1AFF5}-\u{1AFFB}\u{1AFFD}\u{1AFFE}\u{1B000}-\u{1B122}\u{1B132}\u{1B150}-\u{1B152}\u{1B155}\u{1B164}-\u{1B167}\u{1B170}-\u{1B2FB}\u{1BC00}-\u{1BC6A}\u{1BC70}-\u{1BC7C}\u{1BC80}-\u{1BC88}\u{1BC90}-\u{1BC99}\u{1D400}-\u{1D454}\u{1D456}-\u{1D49C}\u{1D49E}\u{1D49F}\u{1D4A2}\u{1D4A5}\u{1D4A6}\u{1D4A9}-\u{1D4AC}\u{1D4AE}-\u{1D4B9}\u{1D4BB}\u{1D4BD}-\u{1D4C3}\u{1D4C5}-\u{1D505}\u{1D507}-\u{1D50A}\u{1D50D}-\u{1D514}\u{1D516}-\u{1D51C}\u{1D51E}-\u{1D539}\u{1D53B}-\u{1D53E}\u{1D540}-\u{1D544}\u{1D546}\u{1D54A}-\u{1D550}\u{1D552}-\u{1D6A5}\u{1D6A8}-\u{1D6C0}\u{1D6C2}-\u{1D6DA}\u{1D6DC}-\u{1D6FA}\u{1D6FC}-\u{1D714}\u{1D716}-\u{1D734}\u{1D736}-\u{1D74E}\u{1D750}-\u{1D76E}\u{1D770}-\u{1D788}\u{1D78A}-\u{1D7A8}\u{1D7AA}-\u{1D7C2}\u{1D7C4}-\u{1D7CB}\u{1DF00}-\u{1DF1E}\u{1DF25}-\u{1DF2A}\u{1E030}-\u{1E06D}\u{1E100}-\u{1E12C}\u{1E137}-\u{1E13D}\u{1E14E}\u{1E290}-\u{1E2AD}\u{1E2C0}-\u{1E2EB}\u{1E4D0}-\u{1E4EB}\u{1E7E0}-\u{1E7E6}\u{1E7E8}-\u{1E7EB}\u{1E7ED}\u{1E7EE}\u{1E7F0}-\u{1E7FE}\u{1E800}-\u{1E8C4}\u{1E900}-\u{1E943}\u{1E94B}\u{1EE00}-\u{1EE03}\u{1EE05}-\u{1EE1F}\u{1EE21}\u{1EE22}\u{1EE24}\u{1EE27}\u{1EE29}-\u{1EE32}\u{1EE34}-\u{1EE37}\u{1EE39}\u{1EE3B}\u{1EE42}\u{1EE47}\u{1EE49}\u{1EE4B}\u{1EE4D}-\u{1EE4F}\u{1EE51}\u{1EE52}\u{1EE54}\u{1EE57}\u{1EE59}\u{1EE5B}\u{1EE5D}\u{1EE5F}\u{1EE61}\u{1EE62}\u{1EE64}\u{1EE67}-\u{1EE6A}\u{1EE6C}-\u{1EE72}\u{1EE74}-\u{1EE77}\u{1EE79}-\u{1EE7C}\u{1EE7E}\u{1EE80}-\u{1EE89}\u{1EE8B}-\u{1EE9B}\u{1EEA1}-\u{1EEA3}\u{1EEA5}-\u{1EEA9}\u{1EEAB}-\u{1EEBB}\u{20000}-\u{2A6DF}\u{2A700}-\u{2B739}\u{2B740}-\u{2B81D}\u{2B820}-\u{2CEA1}\u{2CEB0}-\u{2EBE0}\u{2EBF0}-\u{2EE5D}\u{2F800}-\u{2FA1D}\u{30000}-\u{3134A}\u{31350}-\u{323AF}]*$/u.test(e)},{name:"string",test:k},{name:"Chain",test:be},{name:"Array",test:g},{name:"Matrix",test:_},{name:"DenseMatrix",test:R},{name:"SparseMatrix",test:P},{name:"Range",test:h},{name:"Index",test:j},{name:"boolean",test:U},{name:"ResultSet",test:$},{name:"Help",test:H},{name:"function",test:G},{name:"Date",test:Z},{name:"RegExp",test:V},{name:"null",test:Y},{name:"undefined",test:J},{name:"AccessorNode",test:le},{name:"ArrayNode",test:X},{name:"AssignmentNode",test:re},{name:"BlockNode",test:ne},{name:"ConditionalNode",test:ie},{name:"ConstantNode",test:ae},{name:"FunctionNode",test:me},{name:"FunctionAssignmentNode",test:pe},{name:"IndexNode",test:he},{name:"Node",test:O},{name:"ObjectNode",test:de},{name:"OperatorNode",test:oe},{name:"ParenthesisNode",test:ge},{name:"RangeNode",test:ye},{name:"RelationalNode",test:xe},{name:"SymbolNode",test:se},{name:"Map",test:it},{name:"Object",test:W}]),a.addConversions([{from:"number",to:"BigNumber",convert:function(e){if(r||st(e),15<e.toExponential().replace(/e.*$/,"").replace(/^0\.?0*|\./,"").length)throw new TypeError("Cannot implicitly convert a number with >15 significant digits to BigNumber (value: "+e+"). Use function bignumber(x) to convert to BigNumber.");return new r(e)}},{from:"number",to:"Complex",convert:function(e){return n||ut(e),new n(e,0)}},{from:"BigNumber",to:"Complex",convert:function(e){return n||ut(e),new n(e.toNumber(),0)}},{from:"bigint",to:"number",convert:function(e){if(e>Number.MAX_SAFE_INTEGER)throw new TypeError("Cannot implicitly convert bigint to number: value exceeds the max safe integer value (value: "+e+")");return Number(e)}},{from:"bigint",to:"BigNumber",convert:function(e){return r||st(e),new r(e.toString())}},{from:"bigint",to:"Fraction",convert:function(e){return i||ct(e),new i(e.toString())}},{from:"Fraction",to:"BigNumber",convert:function(e){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.")}},{from:"Fraction",to:"Complex",convert:function(e){return n||ut(e),new n(e.valueOf(),0)}},{from:"number",to:"Fraction",convert:function(e){i||ct(e);const t=new i(e);if(t.valueOf()!==e)throw new TypeError("Cannot implicitly convert a number to a Fraction when there will be a loss of precision (value: "+e+"). Use function fraction(x) to convert to Fraction.");return t}},{from:"string",to:"number",convert:function(e){var t=Number(e);if(isNaN(t))throw new Error('Cannot convert "'+e+'" to a number');return t}},{from:"string",to:"BigNumber",convert:function(t){r||st(t);try{return new r(t)}catch(e){throw new Error('Cannot convert "'+t+'" to BigNumber')}}},{from:"string",to:"bigint",convert:function(t){try{return BigInt(t)}catch(e){throw new Error('Cannot convert "'+t+'" to BigInt')}}},{from:"string",to:"Fraction",convert:function(t){i||ct(t);try{return new i(t)}catch(e){throw new Error('Cannot convert "'+t+'" to Fraction')}}},{from:"string",to:"Complex",convert:function(t){n||ut(t);try{return new n(t)}catch(e){throw new Error('Cannot convert "'+t+'" to Complex')}}},{from:"boolean",to:"number",convert:function(e){return+e}},{from:"boolean",to:"BigNumber",convert:function(e){return r||st(e),new r(+e)}},{from:"boolean",to:"bigint",convert:function(e){return BigInt(+e)}},{from:"boolean",to:"Fraction",convert:function(e){return i||ct(e),new i(+e)}},{from:"boolean",to:"string",convert:function(e){return String(e)}},{from:"Array",to:"Matrix",convert:function(e){if(t)return new t(e);throw new Error("Cannot convert array into a Matrix: no class 'DenseMatrix' provided")}},{from:"Matrix",to:"Array",convert:function(e){return e.valueOf()}}]),a.onMismatch=(e,t,r)=>{var n=a.createError(e,t,r);if(["wrongType","mismatch"].includes(n.data.category)&&1===t.length&&q(t[0])&&r.some(e=>!e.params.includes(","))){const t=new TypeError(`Function '${e}' doesn't apply to matrices. To call it elementwise on a matrix 'M', try 'map(M, ${e})'.`);throw t.data=n.data,t}throw n},a.onMismatch=(e,t,r)=>{var n=a.createError(e,t,r);if(["wrongType","mismatch"].includes(n.data.category)&&1===t.length&&q(t[0])&&r.some(e=>!e.params.includes(","))){const t=new TypeError(`Function '${e}' doesn't apply to matrices. To call it elementwise on a matrix 'M', try 'map(M, ${e})'.`);throw t.data=n.data,t}throw n},a});function st(e){throw new Error(`Cannot convert value ${e} into a BigNumber: no class 'BigNumber' provided`)}function ut(e){throw new Error(`Cannot convert value ${e} into a Complex number: no class 'Complex' provided`)}function ct(e){throw new Error(`Cannot convert value ${e} into a Fraction, no class 'Fraction' provided.`)}const lt=s("ResultSet",[],()=>{function t(e){if(!(this instanceof t))throw new SyntaxError("Constructor must be called with the new operator");this.entries=e||[]}return t.prototype.type="ResultSet",t.prototype.isResultSet=!0,t.prototype.valueOf=function(){return this.entries},t.prototype.toString=function(){return"["+this.entries.join(", ")+"]"},t.prototype.toJSON=function(){return{mathjs:"ResultSet",entries:this.entries}},t.fromJSON=function(e){return new t(e.entries)},t},{isClass:!0});var ft,pt,mt=9e15,ht=1e9,dt="0123456789abcdef",gt="2.3025850929940456840179914546843642076011014886287729760333279009675726096773524802359972050895982983419677840422862486334095254650828067566662873690987816894829072083255546808437998948262331985283935053089653777326288461633662222876982198867465436674744042432743651550489343149393914796194044002221051017141748003688084012647080685567743216228355220114804663715659121373450747856947683463616792101806445070648000277502684916746550586856935673420670581136429224554405758925724208241314695689016758940256776311356919292033376587141660230105703089634572075440370847469940168269282808481184289314848524948644871927809676271275775397027668605952496716674183485704422507197965004714951050492214776567636938662976979522110718264549734772662425709429322582798502585509785265383207606726317164309505995087807523710333101197857547331541421808427543863591778117054309827482385045648019095610299291824318237525357709750539565187697510374970888692180205189339507238539205144634197265287286965110862571492198849978748873771345686209167058",yt="3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989380952572010654858632789",xt={precision:20,rounding:4,modulo:1,toExpNeg:-7,toExpPos:21,minE:-mt,maxE:mt,crypto:!1},b=!0,bt="[DecimalError] ",vt=bt+"Invalid argument: ",wt=bt+"Precision limit exceeded",Nt=bt+"crypto unavailable",Et="[object Decimal]",At=Math.floor,d=Math.pow,St=/^0b([01]+(\.[01]*)?|\.[01]+)(p[+-]?\d+)?$/i,Mt=/^0x([0-9a-f]+(\.[0-9a-f]*)?|\.[0-9a-f]+)(p[+-]?\d+)?$/i,Ct=/^0o([0-7]+(\.[0-7]*)?|\.[0-7]+)(p[+-]?\d+)?$/i,Tt=/^(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,Dt=1e7,D=7,Ft=gt.length-1,Bt=yt.length-1,o={toStringTag:Et};function w(e){var t,r,n,i=e.length-1,a="",o=e[0];if(0<i){for(a+=o,t=1;t<i;t++)n=e[t]+"",(r=D-n.length)&&(a+=$t(r)),a+=n;o=e[t],(r=D-(n=o+"").length)&&(a+=$t(r))}else if(0===o)return"0";for(;o%10==0;)o/=10;return a+o}function Ot(e,t,r){if(e!==~~e||e<t||r<e)throw Error(vt+e)}function _t(e,t,r,n){for(var i,a,o=e[0];10<=o;o/=10)--t;return--t<0?(t+=D,i=0):(i=Math.ceil((t+1)/D),t%=D),o=d(10,D-t),a=e[i]%o|0,null==n?t<3?(0==t?a=a/100|0:1==t&&(a=a/10|0),r<4&&99999==a||3<r&&49999==a||5e4==a||0==a):(r<4&&a+1==o||3<r&&a+1==o/2)&&(e[i+1]/o/100|0)==d(10,t-2)-1||(a==o/2||0==a)&&!(e[i+1]/o/100|0):t<4?(0==t?a=a/1e3|0:1==t?a=a/100|0:2==t&&(a=a/10|0),(n||r<4)&&9999==a||!n&&3<r&&4999==a):((n||r<4)&&a+1==o||!n&&3<r&&a+1==o/2)&&(e[i+1]/o/1e3|0)==d(10,t-3)-1}function zt(e,t,r){for(var n,i,a=[0],o=0,s=e.length;o<s;){for(i=a.length;i--;)a[i]*=t;for(a[0]+=dt.indexOf(e.charAt(o++)),n=0;n<a.length;n++)a[n]>r-1&&(void 0===a[n+1]&&(a[n+1]=0),a[n+1]+=a[n]/r|0,a[n]%=r)}return a.reverse()}o.absoluteValue=o.abs=function(){var e=new this.constructor(this);return e.s<0&&(e.s=1),F(e)},o.ceil=function(){return F(new this.constructor(this),this.e+1,2)},o.clampedTo=o.clamp=function(e,t){var r=this.constructor;if(e=new r(e),t=new r(t),!e.s||!t.s)return new r(NaN);if(e.gt(t))throw Error(vt+t);return this.cmp(e)<0?e:0<this.cmp(t)?t:new r(this)},o.comparedTo=o.cmp=function(e){var t,r,n=this.d,i=(e=new this.constructor(e)).d,a=this.s,o=e.s;if(!n||!i)return a&&o?a!==o?a:n===i?0:!n^a<0?1:-1:NaN;if(!n[0]||!i[0])return n[0]?a:i[0]?-o:0;if(a!==o)return a;if(this.e!==e.e)return this.e>e.e^a<0?1:-1;for(t=0,r=(o=n.length)<(e=i.length)?o:e;t<r;++t)if(n[t]!==i[t])return n[t]>i[t]^a<0?1:-1;return o===e?0:e<o^a<0?1:-1},o.cosine=o.cos=function(){var e,t,r=this,n=r.constructor;return r.d?r.d[0]?(e=n.precision,t=n.rounding,n.precision=e+Math.max(r.e,r.sd())+D,n.rounding=1,r=function(e,t){var r,n;if(t.isZero())return t;n=(n=t.d.length)<32?(1/Qt(4,r=Math.ceil(n/3))).toString():(r=16,"2.3283064365386962890625e-10"),e.precision+=r,t=Xt(e,1,t.times(n),new e(1));for(var i=r;i--;){var a=t.times(t);t=a.times(a).minus(a).times(8).plus(1)}return e.precision-=r,t}(n,Kt(n,r)),n.precision=e,n.rounding=t,F(2==pt||3==pt?r.neg():r,e,t,!0)):new n(1):new n(NaN)},o.cubeRoot=o.cbrt=function(){var e,t,r,n,i,a,o,s,u,c,l=this,f=l.constructor;if(!l.isFinite()||l.isZero())return new f(l);for(b=!1,(a=l.s*d(l.s*l,1/3))&&Math.abs(a)!=1/0?n=new f(a.toString()):(r=w(l.d),(a=((e=l.e)-r.length+1)%3)&&(r+=1==a||-2==a?"0":"00"),a=d(r,1/3),e=At((e+1)/3)-(e%3==(e<0?-1:2)),(n=new f(r=a==1/0?"5e"+e:(r=a.toExponential()).slice(0,r.indexOf("e")+1)+e)).s=l.s),o=(e=f.precision)+3;;)if(c=(u=(s=n).times(s).times(s)).plus(l),n=N(c.plus(l).times(s),c.plus(u),o+2,1),w(s.d).slice(0,o)===(r=w(n.d)).slice(0,o)){if("9999"!=(r=r.slice(o-3,o+1))&&(i||"4999"!=r)){+r&&(+r.slice(1)||"5"!=r.charAt(0))||(F(n,e+1,1),t=!n.times(n).times(n).eq(l));break}if(!i&&(F(s,e+1,0),s.times(s).times(s).eq(l))){n=s;break}o+=4,i=1}return b=!0,F(n,e,f.rounding,t)},o.decimalPlaces=o.dp=function(){var e,t=this.d,r=NaN;if(t){if(r=((e=t.length-1)-At(this.e/D))*D,e=t[e])for(;e%10==0;e/=10)r--;r<0&&(r=0)}return r},o.dividedBy=o.div=function(e){return N(this,new this.constructor(e))},o.dividedToIntegerBy=o.divToInt=function(e){var t=this.constructor;return F(N(this,new t(e),0,1,1),t.precision,t.rounding)},o.equals=o.eq=function(e){return 0===this.cmp(e)},o.floor=function(){return F(new this.constructor(this),this.e+1,3)},o.greaterThan=o.gt=function(e){return 0<this.cmp(e)},o.greaterThanOrEqualTo=o.gte=function(e){e=this.cmp(e);return 1==e||0===e},o.hyperbolicCosine=o.cosh=function(){var e,t,r,n=(s=this).constructor,i=new n(1);if(!s.isFinite())return new n(s.s?1/0:NaN);if(s.isZero())return i;t=n.precision,r=n.rounding,n.precision=t+Math.max(s.e,s.sd())+4,n.rounding=1;for(var a,o=(o=s.d.length)<32?(1/Qt(4,e=Math.ceil(o/3))).toString():(e=16,"2.3283064365386962890625e-10"),s=Xt(n,1,s.times(o),new n(1),!0),u=e,c=new n(8);u--;)a=s.times(s),s=i.minus(a.times(c.minus(a.times(c))));return F(s,n.precision=t,n.rounding=r,!0)},o.hyperbolicSine=o.sinh=function(){var e,t,r,n=(o=this).constructor;if(!o.isFinite()||o.isZero())return new n(o);if(e=n.precision,t=n.rounding,n.precision=e+Math.max(o.e,o.sd())+4,n.rounding=1,(r=o.d.length)<3)o=Xt(n,2,o,o,!0);else for(var i,a=16<(a=1.4*Math.sqrt(r))?16:0|a,o=Xt(n,2,o=o.times(1/Qt(5,a)),o,!0),s=new n(5),u=new n(16),c=new n(20);a--;)i=o.times(o),o=o.times(s.plus(i.times(u.times(i).plus(c))));return F(o,n.precision=e,n.rounding=t,!0)},o.hyperbolicTangent=o.tanh=function(){var e,t,r=this.constructor;return this.isFinite()?this.isZero()?new r(this):(e=r.precision,t=r.rounding,r.precision=e+7,r.rounding=1,N(this.sinh(),this.cosh(),r.precision=e,r.rounding=t)):new r(this.s)},o.inverseCosine=o.acos=function(){var e=this,t=e.constructor,r=e.abs().cmp(1),n=t.precision,i=t.rounding;return-1!==r?0===r?e.isNeg()?Ut(t,n,i):new t(0):new t(NaN):e.isZero()?Ut(t,n+4,i).times(.5):(t.precision=n+6,t.rounding=1,e=e.asin(),r=Ut(t,n+4,i).times(.5),t.precision=n,t.rounding=i,r.minus(e))},o.inverseHyperbolicCosine=o.acosh=function(){var e,t,r=this,n=r.constructor;return r.lte(1)?new n(r.eq(1)?0:NaN):r.isFinite()?(e=n.precision,t=n.rounding,n.precision=e+Math.max(Math.abs(r.e),r.sd())+4,n.rounding=1,b=!1,r=r.times(r).minus(1).sqrt().plus(r),b=!0,n.precision=e,n.rounding=t,r.ln()):new n(r)},o.inverseHyperbolicSine=o.asinh=function(){var e,t,r=this,n=r.constructor;return!r.isFinite()||r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+2*Math.max(Math.abs(r.e),r.sd())+6,n.rounding=1,b=!1,r=r.times(r).plus(1).sqrt().plus(r),b=!0,n.precision=e,n.rounding=t,r.ln())},o.inverseHyperbolicTangent=o.atanh=function(){var e,t,r,n=this,i=n.constructor;return n.isFinite()?0<=n.e?new i(n.abs().eq(1)?n.s/0:n.isZero()?n:NaN):(e=i.precision,t=i.rounding,r=n.sd(),Math.max(r,e)<2*-n.e-1?F(new i(n),e,t,!0):(i.precision=r=r-n.e,n=N(n.plus(1),new i(1).minus(n),r+e,1),i.precision=e+4,i.rounding=1,n=n.ln(),i.precision=e,i.rounding=t,n.times(.5))):new i(NaN)},o.inverseSine=o.asin=function(){var e,t,r,n=this,i=n.constructor;return n.isZero()?new i(n):(e=n.abs().cmp(1),t=i.precision,r=i.rounding,-1!==e?0===e?((e=Ut(i,t+4,r).times(.5)).s=n.s,e):new i(NaN):(i.precision=t+6,i.rounding=1,n=n.div(new i(1).minus(n.times(n)).sqrt().plus(1)).atan(),i.precision=t,i.rounding=r,n.times(2)))},o.inverseTangent=o.atan=function(){var e,t,r,n,i,a,o,s,u,c=this,l=c.constructor,f=l.precision,p=l.rounding;if(c.isFinite()){if(c.isZero())return new l(c);if(c.abs().eq(1)&&f+4<=Bt)return(o=Ut(l,f+4,p).times(.25)).s=c.s,o}else{if(!c.s)return new l(NaN);if(f+4<=Bt)return(o=Ut(l,f+4,p).times(.5)).s=c.s,o}for(l.precision=s=f+10,l.rounding=1,e=r=Math.min(28,s/D+2|0);e;--e)c=c.div(c.times(c).plus(1).sqrt().plus(1));for(b=!1,t=Math.ceil(s/D),n=1,u=c.times(c),o=new l(c),i=c;-1!==e;)if(i=i.times(u),a=o.minus(i.div(n+=2)),i=i.times(u),void 0!==(o=a.plus(i.div(n+=2))).d[t])for(e=t;o.d[e]===a.d[e]&&e--;);return r&&(o=o.times(2<<r-1)),b=!0,F(o,l.precision=f,l.rounding=p,!0)},o.isFinite=function(){return!!this.d},o.isInteger=o.isInt=function(){return!!this.d&&At(this.e/D)>this.d.length-2},o.isNaN=function(){return!this.s},o.isNegative=o.isNeg=function(){return this.s<0},o.isPositive=o.isPos=function(){return 0<this.s},o.isZero=function(){return!!this.d&&0===this.d[0]},o.lessThan=o.lt=function(e){return this.cmp(e)<0},o.lessThanOrEqualTo=o.lte=function(e){return this.cmp(e)<1},o.logarithm=o.log=function(e){var t,r,n,i,a,o,s,u,c=this.constructor,l=c.precision,f=c.rounding;if(null==e)e=new c(10),t=!0;else{if(r=(e=new c(e)).d,e.s<0||!r||!r[0]||e.eq(1))return new c(NaN);t=e.eq(10)}if(r=this.d,this.s<0||!r||!r[0]||this.eq(1))return new c(r&&!r[0]?-1/0:1!=this.s?NaN:r?0:1/0);if(t)if(1<r.length)a=!0;else{for(i=r[0];i%10==0;)i/=10;a=1!==i}if(b=!1,o=Wt(this,s=l+5),n=t?jt(c,s+10):Wt(e,s),_t((u=N(o,n,s,1)).d,i=l,f))do{if(o=Wt(this,s+=10),n=t?jt(c,s+10):Wt(e,s),u=N(o,n,s,1),!a){+w(u.d).slice(i+1,i+15)+1==1e14&&(u=F(u,l+1,0));break}}while(_t(u.d,i+=10,f));return b=!0,F(u,l,f)},o.minus=o.sub=function(e){var t,r,n,i,a,o,s,u,c,l,f,p=this,m=p.constructor;if(e=new m(e),!p.d||!e.d)return p.s&&e.s?p.d?e.s=-e.s:e=new m(e.d||p.s!==e.s?p:NaN):e=new m(NaN),e;if(p.s!=e.s)return e.s=-e.s,p.plus(e);if(c=p.d,f=e.d,s=m.precision,u=m.rounding,!c[0]||!f[0]){if(f[0])e.s=-e.s;else{if(!c[0])return new m(3===u?-0:0);e=new m(p)}return b?F(e,s,u):e}if(r=At(e.e/D),p=At(p.e/D),c=c.slice(),a=p-r){for(o=(l=a<0)?(t=c,a=-a,f.length):(t=f,r=p,c.length),a>(n=Math.max(Math.ceil(s/D),o)+2)&&(a=n,t.length=1),t.reverse(),n=a;n--;)t.push(0);t.reverse()}else{for((l=(n=c.length)<(o=f.length))&&(o=n),n=0;n<o;n++)if(c[n]!=f[n]){l=c[n]<f[n];break}a=0}for(l&&(t=c,c=f,f=t,e.s=-e.s),o=c.length,n=f.length-o;0<n;--n)c[o++]=0;for(n=f.length;a<n;){if(c[--n]<f[n]){for(i=n;i&&0===c[--i];)c[i]=Dt-1;--c[i],c[n]+=Dt}c[n]-=f[n]}for(;0===c[--o];)c.pop();for(;0===c[0];c.shift())--r;return c[0]?(e.d=c,e.e=Pt(c,r),b?F(e,s,u):e):new m(3===u?-0:0)},o.modulo=o.mod=function(e){var t,r=this.constructor;return e=new r(e),!this.d||!e.s||e.d&&!e.d[0]?new r(NaN):!e.d||this.d&&!this.d[0]?F(new r(this),r.precision,r.rounding):(b=!1,9==r.modulo?(t=N(this,e.abs(),0,3,1)).s*=e.s:t=N(this,e,0,r.modulo,1),t=t.times(e),b=!0,this.minus(t))},o.naturalExponential=o.exp=function(){return Vt(this)},o.naturalLogarithm=o.ln=function(){return Wt(this)},o.negated=o.neg=function(){var e=new this.constructor(this);return e.s=-e.s,F(e)},o.plus=o.add=function(e){var t,r,n,i,a,o,s,u,c=this,l=c.constructor;if(e=new l(e),!c.d||!e.d)return c.s&&e.s?c.d||(e=new l(e.d||c.s===e.s?c:NaN)):e=new l(NaN),e;if(c.s!=e.s)return e.s=-e.s,c.minus(e);if(s=c.d,u=e.d,a=l.precision,o=l.rounding,!s[0]||!u[0])return u[0]||(e=new l(c)),b?F(e,a,o):e;if(l=At(c.e/D),c=At(e.e/D),s=s.slice(),n=l-c){for(i=n<0?(r=s,n=-n,u.length):(r=u,c=l,s.length),n>(i=(l=Math.ceil(a/D))>i?l+1:i+1)&&(n=i,r.length=1),r.reverse();n--;)r.push(0);r.reverse()}for((i=s.length)-(n=u.length)<0&&(n=i,r=u,u=s,s=r),t=0;n;)t=(s[--n]=s[n]+u[n]+t)/Dt|0,s[n]%=Dt;for(t&&(s.unshift(t),++c),i=s.length;0==s[--i];)s.pop();return e.d=s,e.e=Pt(s,c),b?F(e,a,o):e},o.precision=o.sd=function(e){var t;if(void 0!==e&&e!==!!e&&1!==e&&0!==e)throw Error(vt+e);return this.d?(t=Lt(this.d),e&&this.e+1>t&&(t=this.e+1)):t=NaN,t},o.round=function(){var e=this.constructor;return F(new e(this),this.e+1,e.rounding)},o.sine=o.sin=function(){var e,t,r=this,n=r.constructor;return r.isFinite()?r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+Math.max(r.e,r.sd())+D,n.rounding=1,r=function(e,t){var r,n=t.d.length;if(n<3)return t.isZero()?t:Xt(e,2,t,t);r=16<(r=1.4*Math.sqrt(n))?16:0|r,t=Xt(e,2,t=t.times(1/Qt(5,r)),t);for(var i,a=new e(5),o=new e(16),s=new e(20);r--;)i=t.times(t),t=t.times(a.plus(i.times(o.times(i).minus(s))));return t}(n,Kt(n,r)),n.precision=e,n.rounding=t,F(2<pt?r.neg():r,e,t,!0)):new n(NaN)},o.squareRoot=o.sqrt=function(){var e,t,r,n,i,a,o=this.d,s=this.e,u=this.s,c=this.constructor;if(1!==u||!o||!o[0])return new c(!u||u<0&&(!o||o[0])?NaN:o?this:1/0);for(b=!1,n=0==(u=Math.sqrt(+this))||u==1/0?(((t=w(o)).length+s)%2==0&&(t+="0"),u=Math.sqrt(t),s=At((s+1)/2)-(s<0||s%2),new c(t=u==1/0?"5e"+s:(t=u.toExponential()).slice(0,t.indexOf("e")+1)+s)):new c(u.toString()),r=(s=c.precision)+3;;)if(n=(a=n).plus(N(this,a,r+2,1)).times(.5),w(a.d).slice(0,r)===(t=w(n.d)).slice(0,r)){if("9999"!=(t=t.slice(r-3,r+1))&&(i||"4999"!=t)){+t&&(+t.slice(1)||"5"!=t.charAt(0))||(F(n,s+1,1),e=!n.times(n).eq(this));break}if(!i&&(F(a,s+1,0),a.times(a).eq(this))){n=a;break}r+=4,i=1}return b=!0,F(n,s,c.rounding,e)},o.tangent=o.tan=function(){var e,t,r=this,n=r.constructor;return r.isFinite()?r.isZero()?new n(r):(e=n.precision,t=n.rounding,n.precision=e+10,n.rounding=1,(r=r.sin()).s=1,r=N(r,new n(1).minus(r.times(r)).sqrt(),e+10,0),n.precision=e,n.rounding=t,F(2==pt||4==pt?r.neg():r,e,t,!0)):new n(NaN)},o.times=o.mul=function(e){var t,r,n,i,a,o,s,u,c,l=this.constructor,f=this.d,p=(e=new l(e)).d;if(e.s*=this.s,!(f&&f[0]&&p&&p[0]))return new l(!e.s||f&&!f[0]&&!p||p&&!p[0]&&!f?NaN:f&&p?0*e.s:e.s/0);for(r=At(this.e/D)+At(e.e/D),(u=f.length)<(c=p.length)&&(a=f,f=p,p=a,o=u,u=c,c=o),a=[],n=o=u+c;n--;)a.push(0);for(n=c;0<=--n;){for(t=0,i=u+n;n<i;)s=a[i]+p[n]*f[i-n-1]+t,a[i--]=s%Dt|0,t=s/Dt|0;a[i]=(a[i]+t)%Dt|0}for(;!a[--o];)a.pop();return t?++r:a.shift(),e.d=a,e.e=Pt(a,r),b?F(e,l.precision,l.rounding):e},o.toBinary=function(e,t){return er(this,2,e,t)},o.toDecimalPlaces=o.toDP=function(e,t){var r=this.constructor,n=new r(this);return void 0===e?n:(Ot(e,0,ht),void 0===t?t=r.rounding:Ot(t,0,8),F(n,e+n.e+1,t))},o.toExponential=function(e,t){var r=this,n=r.constructor,n=void 0===e?Rt(r,!0):(Ot(e,0,ht),void 0===t?t=n.rounding:Ot(t,0,8),Rt(r=F(new n(r),e+1,t),!0,e+1));return r.isNeg()&&!r.isZero()?"-"+n:n},o.toFixed=function(e,t){var r=this.constructor,t=void 0===e?Rt(this):(Ot(e,0,ht),void 0===t?t=r.rounding:Ot(t,0,8),Rt(r=F(new r(this),e+this.e+1,t),!1,e+r.e+1));return this.isNeg()&&!this.isZero()?"-"+t:t},o.toFraction=function(e){var t,r,n,i,a,o,s,u,c,l,f=this.d,p=this.constructor;if(!f)return new p(this);if(u=r=new p(1),n=s=new p(0),c=(a=(t=new p(n)).e=Lt(f)-this.e-1)%D,t.d[0]=d(10,c<0?D+c:c),null==e)e=0<a?t:u;else{if(!(o=new p(e)).isInt()||o.lt(u))throw Error(vt+o);e=o.gt(t)?0<a?t:u:o}for(b=!1,o=new p(w(f)),c=p.precision,p.precision=a=f.length*D*2;l=N(o,t,0,1,1),1!=(i=r.plus(l.times(n))).cmp(e);)r=n,n=i,i=u,u=s.plus(l.times(i)),s=i,i=t,t=o.minus(l.times(i)),o=i;return i=N(e.minus(r),n,0,1,1),s=s.plus(i.times(u)),r=r.plus(i.times(n)),s.s=u.s=this.s,f=N(u,n,a,1).minus(this).abs().cmp(N(s,r,a,1).minus(this).abs())<1?[u,n]:[s,r],p.precision=c,b=!0,f},o.toHexadecimal=o.toHex=function(e,t){return er(this,16,e,t)},o.toNearest=function(e,t){var r=(n=this).constructor,n=new r(n);if(null==e){if(!n.d)return n;e=new r(1),t=r.rounding}else{if(e=new r(e),void 0===t?t=r.rounding:Ot(t,0,8),!n.d)return e.s?n:e;if(!e.d)return e.s&&(e.s=n.s),e}return e.d[0]?(b=!1,n=N(n,e,0,t,1).times(e),b=!0,F(n)):(e.s=n.s,n=e),n},o.toNumber=function(){return+this},o.toOctal=function(e,t){return er(this,8,e,t)},o.toPower=o.pow=function(e){var t,r,n,i,a,o,s=this,u=s.constructor,c=+(e=new u(e));if(!(s.d&&e.d&&s.d[0]&&e.d[0]))return new u(d(+s,c));if((s=new u(s)).eq(1))return s;if(n=u.precision,a=u.rounding,e.eq(1))return F(s,n,a);if((t=At(e.e/D))>=e.d.length-1&&(r=c<0?-c:c)<=9007199254740991)return i=Ht(u,s,r,n),e.s<0?new u(1).div(i):F(i,n,a);if((o=s.s)<0){if(t<e.d.length-1)return new u(NaN);if(1&e.d[t]||(o=1),0==s.e&&1==s.d[0]&&1==s.d.length)return s.s=o,s}return(t=0!=(r=d(+s,c))&&isFinite(r)?new u(r+"").e:At(c*(Math.log("0."+w(s.d))/Math.LN10+s.e+1)))>u.maxE+1||t<u.minE-1?new u(0<t?o/0:0):(b=!1,u.rounding=s.s=1,r=Math.min(12,(t+"").length),(i=Vt(e.times(Wt(s,n+r)),n)).d&&_t((i=F(i,n+5,1)).d,n,a)&&(+w((i=F(Vt(e.times(Wt(s,(t=n+10)+r)),t),t+5,1)).d).slice(n+1,n+15)+1==1e14&&(i=F(i,n+1,0))),i.s=o,b=!0,F(i,n,u.rounding=a))},o.toPrecision=function(e,t){var r=this,n=r.constructor,t=void 0===e?Rt(r,r.e<=n.toExpNeg||r.e>=n.toExpPos):(Ot(e,1,ht),void 0===t?t=n.rounding:Ot(t,0,8),Rt(r=F(new n(r),e,t),e<=r.e||r.e<=n.toExpNeg,e));return r.isNeg()&&!r.isZero()?"-"+t:t},o.toSignificantDigits=o.toSD=function(e,t){var r=this.constructor;return void 0===e?(e=r.precision,t=r.rounding):(Ot(e,1,ht),void 0===t?t=r.rounding:Ot(t,0,8)),F(new r(this),e,t)},o.toString=function(){var e=this.constructor,e=Rt(this,this.e<=e.toExpNeg||this.e>=e.toExpPos);return this.isNeg()&&!this.isZero()?"-"+e:e},o.truncated=o.trunc=function(){return F(new this.constructor(this),this.e+1,1)},o.valueOf=o.toJSON=function(){var e=this.constructor,e=Rt(this,this.e<=e.toExpNeg||this.e>=e.toExpPos);return this.isNeg()?"-"+e:e};var N=function(e,t,r,n,i,a){var o,s,u,c,l,f,p,m,h,d,g,y,x,b,v,w,N,E,A,S=e.constructor,M=e.s==t.s?1:-1,C=e.d,T=t.d;if(!(C&&C[0]&&T&&T[0]))return new S(e.s&&t.s&&(C?!T||C[0]!=T[0]:T)?C&&0==C[0]||!T?0*M:M/0:NaN);for(s=a?(l=1,e.e-t.e):(a=Dt,At(e.e/(l=D))-At(t.e/l)),E=T.length,w=C.length,h=(M=new S(M)).d=[],u=0;T[u]==(C[u]||0);u++);if(T[u]>(C[u]||0)&&s--,null==r?(x=r=S.precision,n=S.rounding):x=i?r+(e.e-t.e)+1:r,x<0)h.push(1),f=!0;else{if(x=x/l+2|0,u=0,1==E){for(T=T[c=0],x++;(u<w||c)&&x--;u++)b=c*a+(C[u]||0),h[u]=b/T|0,c=b%T|0;f=c||u<w}else{for(1<(c=a/(T[0]+1)|0)&&(T=It(T,c,a),C=It(C,c,a),E=T.length,w=C.length),v=E,g=(d=C.slice(0,E)).length;g<E;)d[g++]=0;for((A=T.slice()).unshift(0),N=T[0],T[1]>=a/2&&++N;c=0,(o=kt(T,d,E,g))<0?(y=d[0],1<(c=(y=E!=g?y*a+(d[1]||0):y)/N|0)?1==(o=kt(p=It(T,c=a<=c?a-1:c,a),d,m=p.length,g=d.length))&&(c--,qt(p,E<m?A:T,m,a)):(0==c&&(o=c=1),p=T.slice()),(m=p.length)<g&&p.unshift(0),qt(d,p,g,a),-1==o&&(o=kt(T,d,E,g=d.length))<1&&(c++,qt(d,E<g?A:T,g,a)),g=d.length):0===o&&(c++,d=[0]),h[u++]=c,o&&d[0]?d[g++]=C[v]||0:(d=[C[v]],g=1),(v++<w||void 0!==d[0])&&x--;);f=void 0!==d[0]}h[0]||h.shift()}if(1==l)M.e=s,ft=f;else{for(u=1,c=h[0];10<=c;c/=10)u++;M.e=u+s*l-1,F(M,i?r+M.e+1:r,n,f)}return M};function It(e,t,r){var n,i=0,a=e.length;for(e=e.slice();a--;)n=e[a]*t+i,e[a]=n%r|0,i=n/r|0;return i&&e.unshift(i),e}function kt(e,t,r,n){var i,a;if(r!=n)a=n<r?1:-1;else for(i=a=0;i<r;i++)if(e[i]!=t[i]){a=e[i]>t[i]?1:-1;break}return a}function qt(e,t,r,n){for(var i=0;r--;)e[r]-=i,i=e[r]<t[r]?1:0,e[r]=i*n+e[r]-t[r];for(;!e[0]&&1<e.length;)e.shift()}function F(e,t,r,n){var i,a,o,s,u,c,l,f,p=e.constructor;e:if(null!=t){if(!(l=e.d))return e;for(i=1,s=l[0];10<=s;s/=10)i++;if((a=t-i)<0)a+=D,o=t,u=(c=l[f=0])/d(10,i-o-1)%10|0;else if((f=Math.ceil((a+1)/D))>=(s=l.length)){if(!n)break e;for(;s++<=f;)l.push(0);c=u=0,o=(a%=D)-D+(i=1)}else{for(c=s=l[f],i=1;10<=s;s/=10)i++;u=(o=(a%=D)-D+i)<0?0:c/d(10,i-o-1)%10|0}if(n=n||t<0||void 0!==l[f+1]||(o<0?c:c%d(10,i-o-1)),u=r<4?(u||n)&&(0==r||r==(e.s<0?3:2)):5<u||5==u&&(4==r||n||6==r&&(0<a?0<o?c/d(10,i-o):0:l[f-1])%10&1||r==(e.s<0?8:7)),t<1||!l[0])return l.length=0,u?(t-=e.e+1,l[0]=d(10,(D-t%D)%D),e.e=-t||0):l[0]=e.e=0,e;if(0==a?(l.length=f,s=1,f--):(l.length=f+1,s=d(10,D-a),l[f]=0<o?(c/d(10,i-o)%d(10,o)|0)*s:0),u)for(;;){if(0==f){for(a=1,o=l[0];10<=o;o/=10)a++;for(o=l[0]+=s,s=1;10<=o;o/=10)s++;a!=s&&(e.e++,l[0]==Dt&&(l[0]=1));break}if(l[f]+=s,l[f]!=Dt)break;l[f--]=0,s=1}for(a=l.length;0===l[--a];)l.pop()}return b&&(e.e>p.maxE?(e.d=null,e.e=NaN):e.e<p.minE&&(e.e=0,e.d=[0])),e}function Rt(e,t,r){if(!e.isFinite())return Yt(e);var n,i=e.e,a=w(e.d),o=a.length;return t?(r&&0<(n=r-o)?a=a.charAt(0)+"."+a.slice(1)+$t(n):1<o&&(a=a.charAt(0)+"."+a.slice(1)),a=a+(e.e<0?"e":"e+")+e.e):i<0?(a="0."+$t(-i-1)+a,r&&0<(n=r-o)&&(a+=$t(n))):o<=i?(a+=$t(i+1-o),r&&0<(n=r-i-1)&&(a=a+"."+$t(n))):((n=i+1)<o&&(a=a.slice(0,n)+"."+a.slice(n)),r&&0<(n=r-o)&&(i+1===o&&(a+="."),a+=$t(n))),a}function Pt(e,t){var r=e[0];for(t*=D;10<=r;r/=10)t++;return t}function jt(e,t,r){if(Ft<t)throw b=!0,r&&(e.precision=r),Error(wt);return F(new e(gt),t,1,!0)}function Ut(e,t,r){if(Bt<t)throw Error(wt);return F(new e(yt),t,r,!0)}function Lt(e){var t=e.length-1,r=t*D+1;if(t=e[t]){for(;t%10==0;t/=10)r--;for(t=e[0];10<=t;t/=10)r++}return r}function $t(e){for(var t="";e--;)t+="0";return t}function Ht(e,t,r,n){var i,a=new e(1),o=Math.ceil(n/D+4);for(b=!1;;){if(r%2&&tr((a=a.times(t)).d,o)&&(i=!0),0===(r=At(r/2))){r=a.d.length-1,i&&0===a.d[r]&&++a.d[r];break}tr((t=t.times(t)).d,o)}return b=!0,a}function Gt(e){return 1&e.d[e.d.length-1]}function Zt(e,t,r){for(var n,i=new e(t[0]),a=0;++a<t.length;){if(!(n=new e(t[a])).s){i=n;break}i[r](n)&&(i=n)}return i}function Vt(e,t){var r,n,i,a,o,s,u,c=0,l=0,f=0,p=e.constructor,m=p.rounding,h=p.precision;if(!e.d||!e.d[0]||17<e.e)return new p(e.d?e.d[0]?e.s<0?0:1/0:1:e.s?e.s<0?0:e:NaN);for(u=null==t?(b=!1,h):t,s=new p(.03125);-2<e.e;)e=e.times(s),f+=5;for(u+=n=Math.log(d(2,f))/Math.LN10*2+5|0,r=a=o=new p(1),p.precision=u;;){if(a=F(a.times(e),u,1),r=r.times(++l),w((s=o.plus(N(a,r,u,1))).d).slice(0,u)===w(o.d).slice(0,u)){for(i=f;i--;)o=F(o.times(o),u,1);if(null!=t)return p.precision=h,o;if(!(c<3&&_t(o.d,u-n,m,c)))return F(o,p.precision=h,m,b=!0);p.precision=u+=10,r=a=s=new p(1),l=0,c++}o=s}}function Wt(e,t){var r,n,i,a,o,s,u,c,l,f,p,m=1,h=e,d=h.d,g=h.constructor,y=g.rounding,x=g.precision;if(h.s<0||!d||!d[0]||!h.e&&1==d[0]&&1==d.length)return new g(d&&!d[0]?-1/0:1!=h.s?NaN:d?0:h);if(l=null==t?(b=!1,x):t,g.precision=l+=10,n=(r=w(d)).charAt(0),!(Math.abs(a=h.e)<15e14))return c=jt(g,l+2,x).times(a+""),h=Wt(new g(n+"."+r.slice(1)),l-10).plus(c),g.precision=x,null==t?F(h,x,y,b=!0):h;for(;n<7&&1!=n||1==n&&3<r.charAt(1);)n=(r=w((h=h.times(e)).d)).charAt(0),m++;for(a=h.e,1<n?(h=new g("0."+r),a++):h=new g(n+"."+r.slice(1)),u=o=h=N((f=h).minus(1),h.plus(1),l,1),p=F(h.times(h),l,1),i=3;;){if(o=F(o.times(p),l,1),w((c=u.plus(N(o,new g(i),l,1))).d).slice(0,l)===w(u.d).slice(0,l)){if(u=u.times(2),0!==a&&(u=u.plus(jt(g,l+2,x).times(a+""))),u=N(u,new g(m),l,1),null!=t)return g.precision=x,u;if(!_t(u.d,l-10,y,s))return F(u,g.precision=x,y,b=!0);g.precision=l+=10,c=o=h=N(f.minus(1),f.plus(1),l,1),p=F(h.times(h),l,1),i=s=1}u=c,i+=2}}function Yt(e){return String(e.s*e.s/0)}function Jt(e,t){var r,n,i;for(0<(n=(t=-1<(r=t.indexOf("."))?t.replace(".",""):t).search(/e/i))?(r<0&&(r=n),r+=+t.slice(n+1),t=t.substring(0,n)):r<0&&(r=t.length),n=0;48===t.charCodeAt(n);n++);for(i=t.length;48===t.charCodeAt(i-1);--i);if(t=t.slice(n,i)){if(i-=n,e.e=r=r-n-1,e.d=[],n=(r+1)%D,r<0&&(n+=D),n<i){for(n&&e.d.push(+t.slice(0,n)),i-=D;n<i;)e.d.push(+t.slice(n,n+=D));t=t.slice(n),n=D-t.length}else n-=i;for(;n--;)t+="0";e.d.push(+t),b&&(e.e>e.constructor.maxE?(e.d=null,e.e=NaN):e.e<e.constructor.minE&&(e.e=0,e.d=[0]))}else e.e=0,e.d=[0];return e}function Xt(e,t,r,n,i){var a,o,s,u,c=e.precision,l=Math.ceil(c/D);for(b=!1,u=r.times(r),s=new e(n);;){if(o=N(s.times(u),new e(t++*t++),c,1),s=i?n.plus(o):n.minus(o),n=N(o.times(u),new e(t++*t++),c,1),void 0!==(o=s.plus(n)).d[l]){for(a=l;o.d[a]===s.d[a]&&a--;);if(-1==a)break}a=s,s=n,n=o,o=a}return b=!0,o.d.length=l+1,o}function Qt(e,t){for(var r=e;--t;)r*=e;return r}function Kt(e,t){var r,n=t.s<0,e=Ut(e,e.precision,1),i=e.times(.5);if((t=t.abs()).lte(i))return pt=n?4:1,t;if((r=t.divToInt(e)).isZero())pt=n?3:2;else{if((t=t.minus(r.times(e))).lte(i))return pt=Gt(r)?n?2:3:n?4:1,t;pt=Gt(r)?n?1:4:n?3:2}return t.minus(e).abs()}function er(e,t,r,n){var i,a,o,s,u,c,l,f,p=e.constructor,m=void 0!==r;if(m?(Ot(r,1,ht),void 0===n?n=p.rounding:Ot(n,0,8)):(r=p.precision,n=p.rounding),e.isFinite()){for(m?(i=2,16==t?r=4*r-3:8==t&&(r=3*r-2)):i=t,0<=(o=(c=Rt(e)).indexOf("."))&&(c=c.replace(".",""),(f=new p(1)).e=c.length-o,f.d=zt(Rt(f),10,i),f.e=f.d.length),a=s=(l=zt(c,10,i)).length;0==l[--s];)l.pop();if(l[0]){if(o<0?a--:((e=new p(e)).d=l,e.e=a,l=(e=N(e,f,r,n,0,i)).d,a=e.e,u=ft),o=l[r],p=i/2,u=u||void 0!==l[r+1],u=n<4?(void 0!==o||u)&&(0===n||n===(e.s<0?3:2)):p<o||o===p&&(4===n||u||6===n&&1&l[r-1]||n===(e.s<0?8:7)),l.length=r,u)for(;++l[--r]>i-1;)l[r]=0,r||(++a,l.unshift(1));for(s=l.length;!l[s-1];--s);for(o=0,c="";o<s;o++)c+=dt.charAt(l[o]);if(m){if(1<s)if(16==t||8==t){for(o=16==t?4:3,--s;s%o;s++)c+="0";for(s=(l=zt(c,i,t)).length;!l[s-1];--s);for(o=1,c="1.";o<s;o++)c+=dt.charAt(l[o])}else c=c.charAt(0)+"."+c.slice(1);c=c+(a<0?"p":"p+")+a}else if(a<0){for(;++a;)c="0"+c;c="0."+c}else if(++a>s)for(a-=s;a--;)c+="0";else a<s&&(c=c.slice(0,a)+"."+c.slice(a))}else c=m?"0p+0":"0";c=(16==t?"0x":2==t?"0b":8==t?"0o":"")+c}else c=Yt(e);return e.s<0?"-"+c:c}function tr(e,t){return e.length>t&&(e.length=t,1)}function rr(e){return new this(e).abs()}function nr(e){return new this(e).acos()}function ir(e){return new this(e).acosh()}function ar(e,t){return new this(e).plus(t)}function or(e){return new this(e).asin()}function sr(e){return new this(e).asinh()}function ur(e){return new this(e).atan()}function cr(e){return new this(e).atanh()}function lr(e,t){e=new this(e),t=new this(t);var r,n=this.precision,i=this.rounding,a=n+4;return e.s&&t.s?e.d||t.d?!t.d||e.isZero()?(r=t.s<0?Ut(this,n,i):new this(0)).s=e.s:!e.d||t.isZero()?(r=Ut(this,a,1).times(.5)).s=e.s:r=t.s<0?(this.precision=a,this.rounding=1,r=this.atan(N(e,t,a,1)),t=Ut(this,a,1),this.precision=n,this.rounding=i,e.s<0?r.minus(t):r.plus(t)):this.atan(N(e,t,a,1)):(r=Ut(this,a,1).times(0<t.s?.25:.75)).s=e.s:r=new this(NaN),r}function fr(e){return new this(e).cbrt()}function pr(e){return F(e=new this(e),e.e+1,2)}function mr(e,t,r){return new this(e).clamp(t,r)}function hr(e){if(!e||"object"!=typeof e)throw Error(bt+"Object expected");for(var t,r,n=!0===e.defaults,i=["precision",1,ht,"rounding",0,8,"toExpNeg",-mt,0,"toExpPos",0,mt,"maxE",0,mt,"minE",-mt,0,"modulo",0,9],a=0;a<i.length;a+=3)if(t=i[a],n&&(this[t]=xt[t]),void 0!==(r=e[t])){if(!(At(r)===r&&i[a+1]<=r&&r<=i[a+2]))throw Error(vt+t+": "+r);this[t]=r}if(t="crypto",n&&(this[t]=xt[t]),void 0!==(r=e[t])){if(!0!==r&&!1!==r&&0!==r&&1!==r)throw Error(vt+t+": "+r);if(r){if("undefined"==typeof crypto||!crypto||!crypto.getRandomValues&&!crypto.randomBytes)throw Error(Nt);this[t]=!0}else this[t]=!1}return this}function dr(e){return new this(e).cos()}function gr(e){return new this(e).cosh()}function yr(e,t){return new this(e).div(t)}function xr(e){return new this(e).exp()}function br(e){return F(e=new this(e),e.e+1,3)}function vr(){var e,t,r=new this(0);for(b=!1,e=0;e<arguments.length;)if((t=new this(arguments[e++])).d)r.d&&(r=r.plus(t.times(t)));else{if(t.s)return b=!0,new this(1/0);r=t}return b=!0,r.sqrt()}function wr(e){return e instanceof Lr||e&&e.toStringTag===Et||!1}function Nr(e){return new this(e).ln()}function Er(e,t){return new this(e).log(t)}function Ar(e){return new this(e).log(2)}function Sr(e){return new this(e).log(10)}function Mr(){return Zt(this,arguments,"lt")}function Cr(){return Zt(this,arguments,"gt")}function Tr(e,t){return new this(e).mod(t)}function Dr(e,t){return new this(e).mul(t)}function Fr(e,t){return new this(e).pow(t)}function Br(e){var t,r,n,i,a=0,o=new this(1),s=[];if(void 0===e?e=this.precision:Ot(e,1,ht),n=Math.ceil(e/D),this.crypto)if(crypto.getRandomValues)for(t=crypto.getRandomValues(new Uint32Array(n));a<n;)429e7<=(i=t[a])?t[a]=crypto.getRandomValues(new Uint32Array(1))[0]:s[a++]=i%1e7;else{if(!crypto.randomBytes)throw Error(Nt);for(t=crypto.randomBytes(n*=4);a<n;)214e7<=(i=t[a]+(t[a+1]<<8)+(t[a+2]<<16)+((127&t[a+3])<<24))?crypto.randomBytes(4).copy(t,a):(s.push(i%1e7),a+=4);a=n/4}else for(;a<n;)s[a++]=1e7*Math.random()|0;for(n=s[--a],e%=D,n&&e&&(i=d(10,D-e),s[a]=(n/i|0)*i);0===s[a];a--)s.pop();if(a<0)s=[r=0];else{for(r=-1;0===s[0];r-=D)s.shift();for(n=1,i=s[0];10<=i;i/=10)n++;n<D&&(r-=D-n)}return o.e=r,o.d=s,o}function Or(e){return F(e=new this(e),e.e+1,this.rounding)}function _r(e){return(e=new this(e)).d?e.d[0]?e.s:0*e.s:e.s||NaN}function zr(e){return new this(e).sin()}function Ir(e){return new this(e).sinh()}function kr(e){return new this(e).sqrt()}function qr(e,t){return new this(e).sub(t)}function Rr(){var e=0,t=arguments,r=new this(t[e]);for(b=!1;r.s&&++e<t.length;)r=r.plus(t[e]);return b=!0,F(r,this.precision,this.rounding)}function Pr(e){return new this(e).tan()}function jr(e){return new this(e).tanh()}function Ur(e){return F(e=new this(e),e.e+1,1)}o[Symbol.for("nodejs.util.inspect.custom")]=o.toString,o[Symbol.toStringTag]="Decimal";var Lr=o.constructor=function e(t){var r,n,i;function a(e){var t,r,n,i=this;if(!(i instanceof a))return new a(e);if(i.constructor=a,wr(e))return i.s=e.s,void(b?!e.d||e.e>a.maxE?(i.e=NaN,i.d=null):e.e<a.minE?(i.e=0,i.d=[0]):(i.e=e.e,i.d=e.d.slice()):(i.e=e.e,i.d=e.d&&e.d.slice()));if("number"==(n=typeof e)){if(0===e)return i.s=1/e<0?-1:1,i.e=0,void(i.d=[0]);if(e<0?(e=-e,i.s=-1):i.s=1,e===~~e&&e<1e7){for(t=0,r=e;10<=r;r/=10)t++;return void(b?a.maxE<t?(i.e=NaN,i.d=null):t<a.minE?(i.e=0,i.d=[0]):(i.e=t,i.d=[e]):(i.e=t,i.d=[e]))}return 0*e!=0?(e||(i.s=NaN),i.e=NaN,void(i.d=null)):Jt(i,e.toString())}if("string"!=n)throw Error(vt+e);return 45===(r=e.charCodeAt(0))?(e=e.slice(1),i.s=-1):(43===r&&(e=e.slice(1)),i.s=1),(Tt.test(e)?Jt:function(e,t){var r,n,i,a,o,s,u,c;if(-1<t.indexOf("_")){if(t=t.replace(/(\d)_(?=\d)/g,"$1"),Tt.test(t))return Jt(e,t)}else if("Infinity"===t||"NaN"===t)return+t||(e.s=NaN),e.e=NaN,e.d=null,e;if(Mt.test(t))r=16,t=t.toLowerCase();else if(St.test(t))r=2;else{if(!Ct.test(t))throw Error(vt+t);r=8}for(o=0<=(a=(t=0<(a=t.search(/p/i))?(u=+t.slice(a+1),t.substring(2,a)):t.slice(2)).indexOf(".")),n=e.constructor,o&&(a=(s=(t=t.replace(".","")).length)-a,i=Ht(n,new n(r),a,2*a)),a=t=(c=zt(t,r,Dt)).length-1;0===c[a];--a)c.pop();return a<0?new n(0*e.s):(e.e=Pt(c,t),e.d=c,b=!1,o&&(e=N(e,i,4*s)),u&&(e=e.times(Math.abs(u)<54?d(2,u):Lr.pow(2,u))),b=!0,e)})(i,e)}if(a.prototype=o,a.ROUND_UP=0,a.ROUND_DOWN=1,a.ROUND_CEIL=2,a.ROUND_FLOOR=3,a.ROUND_HALF_UP=4,a.ROUND_HALF_DOWN=5,a.ROUND_HALF_EVEN=6,a.ROUND_HALF_CEIL=7,a.ROUND_HALF_FLOOR=8,a.EUCLID=9,a.config=a.set=hr,a.clone=e,a.isDecimal=wr,a.abs=rr,a.acos=nr,a.acosh=ir,a.add=ar,a.asin=or,a.asinh=sr,a.atan=ur,a.atanh=cr,a.atan2=lr,a.cbrt=fr,a.ceil=pr,a.clamp=mr,a.cos=dr,a.cosh=gr,a.div=yr,a.exp=xr,a.floor=br,a.hypot=vr,a.ln=Nr,a.log=Er,a.log10=Sr,a.log2=Ar,a.max=Mr,a.min=Cr,a.mod=Tr,a.mul=Dr,a.pow=Fr,a.random=Br,a.round=Or,a.sign=_r,a.sin=zr,a.sinh=Ir,a.sqrt=kr,a.sub=qr,a.sum=Rr,a.tan=Pr,a.tanh=jr,a.trunc=Ur,(t=void 0===t?{}:t)&&!0!==t.defaults)for(i=["precision","rounding","toExpNeg","toExpPos","maxE","minE","modulo","crypto"],r=0;r<i.length;)t.hasOwnProperty(n=i[r++])||(t[n]=this[n]);return a.config(t),a}(xt),gt=new Lr(gt),yt=new Lr(yt);const $r=Lr,Hr=s("BigNumber",["?on","config"],e=>{let{on:t,config:r}=e;const n=$r.clone({precision:r.precision,modulo:$r.EUCLID});return n.prototype=Object.create(n.prototype),n.prototype.type="BigNumber",n.prototype.isBigNumber=!0,n.prototype.toJSON=function(){return{mathjs:"BigNumber",value:this.toString()}},n.fromJSON=function(e){return new n(e.value)},t&&t("config",function(e,t){e.precision!==t.precision&&n.config({precision:e.precision})}),n},{isClass:!0});var Gr=kh(5716);const Zr=s("Complex",[],()=>(Object.defineProperty(Gr,"name",{value:"Complex"}),(Gr.prototype.constructor=Gr).prototype.type="Complex",Gr.prototype.isComplex=!0,Gr.prototype.toJSON=function(){return{mathjs:"Complex",re:this.re,im:this.im}},Gr.prototype.toPolar=function(){return{r:this.abs(),phi:this.arg()}},Gr.prototype.format=function(e){let t=this.im,r=this.re;const n=Se(this.re,e),i=Se(this.im,e),a=E(e)?e:e?e.precision:null;if(null!==a){const e=Math.pow(10,-a);Math.abs(r/t)<e&&(r=0),Math.abs(t/r)<e&&(t=0)}return 0===t?n:0===r?1===t?"i":-1===t?"-i":i+"i":t<0?-1===t?n+" - i":n+" - "+i.substring(1)+"i":1===t?n+" + i":n+" + "+i+"i"},Gr.fromPolar=function(t){switch(arguments.length){case 1:{const t=arguments[0];if("object"==typeof t)return Gr(t);throw new TypeError("Input has to be an object with r and phi keys.")}case 2:{const t=arguments[0];let e=arguments[1];if(E(t)){if(E(e=L(e)&&e.hasBase("ANGLE")?e.toNumber("rad"):e))return new Gr({r:t,phi:e});throw new TypeError("Phi is not a number nor an angle unit.")}throw new TypeError("Radius r is not a number.")}default:throw new SyntaxError("Wrong number of arguments in function fromPolar")}},Gr.prototype.valueOf=Gr.prototype.toString,Gr.fromJSON=function(e){return new Gr(e)},Gr.compare=function(e,t){return e.re>t.re?1:e.re<t.re?-1:e.im>t.im?1:e.im<t.im?-1:0},Gr),{isClass:!0});var y={s:1,n:0,d:1};function Vr(e,t){if(isNaN(e=parseInt(e,10)))throw Kr();return e*t}function u(e,t){if(0===t)throw Qr();var r=Object.create(Xr.prototype),n=(r.s=e<0?-1:1,Jr(e=e<0?-e:e,t));return r.n=e/n,r.d=t/n,r}function Wr(e){for(var t={},r=e,n=2,i=4;i<=r;){for(;r%n==0;)r/=n,t[n]=(t[n]||0)+1;i+=1+2*n++}return r!==e?1<r&&(t[r]=(t[r]||0)+1):t[e]=(t[e]||0)+1,t}function Yr(e,t){var r,n=0,i=1,a=1,o=0,s=0,u=0,c=1,l=1,f=0,p=1,m=1,h=1;if(null!=e)if(void 0!==t){if(a=(n=e)*(i=t),n%1!=0||i%1!=0)throw en()}else switch(typeof e){case"object":if("d"in e&&"n"in e)n=e.n,i=e.d,"s"in e&&(n*=e.s);else{if(!(0 in e))throw Kr();n=e[0],1 in e&&(i=e[1])}a=n*i;break;case"number":if((e=e<0?-(a=e):e)%1==0)n=e;else if(0<e){for(1<=e&&(e/=l=Math.pow(10,Math.floor(1+Math.log(e)/Math.LN10)));p<=1e7&&h<=1e7;){if(e===(r=(f+m)/(p+h))){i=p+h<=1e7?(n=f+m,p+h):p<h?(n=m,h):(n=f,p);break}r<e?(f+=m,p+=h):(m+=f,h+=p),i=1e7<p?(n=m,h):(n=f,p)}n*=l}else(isNaN(e)||isNaN(t))&&(i=n=NaN);break;case"string":if(null===(p=e.match(/\d+|./g)))throw Kr();if("-"===p[f]?(a=-1,f++):"+"===p[f]&&f++,p.length===f+1?s=Vr(p[f++],a):"."===p[f+1]||"."===p[f]?("."!==p[f]&&(o=Vr(p[f++],a)),(++f+1===p.length||"("===p[f+1]&&")"===p[f+3]||"'"===p[f+1]&&"'"===p[f+3])&&(s=Vr(p[f],a),c=Math.pow(10,p[f].length),f++),("("===p[f]&&")"===p[f+2]||"'"===p[f]&&"'"===p[f+2])&&(u=Vr(p[f+1],a),l=Math.pow(10,p[f+1].length)-1,f+=3)):"/"===p[f+1]||":"===p[f+1]?(s=Vr(p[f],a),c=Vr(p[f+2],1),f+=3):"/"===p[f+3]&&" "===p[f+1]&&(o=Vr(p[f],a),s=Vr(p[f+2],a),c=Vr(p[f+4],1),f+=5),p.length<=f){a=n=u+(i=c*l)*o+l*s;break}default:throw Kr()}if(0===i)throw Qr();y.s=a<0?-1:1,y.n=Math.abs(n),y.d=Math.abs(i)}function Jr(e,t){if(!e)return t;if(!t)return e;for(;;){if(!(e%=t))return t;if(!(t%=e))return e}}function Xr(e,t){if(Yr(e,t),!(this instanceof Xr))return u(y.s*y.n,y.d);e=Jr(y.d,y.n),this.s=y.s,this.n=y.n/e,this.d=y.d/e}var Qr=function(){return new Error("Division by Zero")},Kr=function(){return new Error("Invalid argument")},en=function(){return new Error("Parameters must be integer")};Xr.prototype={s:1,n:0,d:1,abs:function(){return u(this.n,this.d)},neg:function(){return u(-this.s*this.n,this.d)},add:function(e,t){return Yr(e,t),u(this.s*this.n*y.d+y.s*this.d*y.n,this.d*y.d)},sub:function(e,t){return Yr(e,t),u(this.s*this.n*y.d-y.s*this.d*y.n,this.d*y.d)},mul:function(e,t){return Yr(e,t),u(this.s*y.s*this.n*y.n,this.d*y.d)},div:function(e,t){return Yr(e,t),u(this.s*y.s*this.n*y.d,this.d*y.n)},clone:function(){return u(this.s*this.n,this.d)},mod:function(e,t){if(isNaN(this.n)||isNaN(this.d))return new Xr(NaN);if(void 0===e)return u(this.s*this.n%this.d,1);if(Yr(e,t),0===y.n&&0===this.d)throw Qr();return u(this.s*(y.d*this.n)%(y.n*this.d),y.d*this.d)},gcd:function(e,t){return Yr(e,t),u(Jr(y.n,this.n)*Jr(y.d,this.d),y.d*this.d)},lcm:function(e,t){return Yr(e,t),0===y.n&&0===this.n?u(0,1):u(y.n*this.n,Jr(y.n,this.n)*Jr(y.d,this.d))},ceil:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Xr(NaN):u(Math.ceil(e*this.s*this.n/this.d),e)},floor:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Xr(NaN):u(Math.floor(e*this.s*this.n/this.d),e)},round:function(e){return e=Math.pow(10,e||0),isNaN(this.n)||isNaN(this.d)?new Xr(NaN):u(Math.round(e*this.s*this.n/this.d),e)},roundTo:function(e,t){return Yr(e,t),u(this.s*Math.round(this.n*y.d/(this.d*y.n))*y.n,y.d)},inverse:function(){return u(this.s*this.d,this.n)},pow:function(e,t){if(Yr(e,t),1===y.d)return y.s<0?u(Math.pow(this.s*this.d,y.n),Math.pow(this.n,y.n)):u(Math.pow(this.s*this.n,y.n),Math.pow(this.d,y.n));if(this.s<0)return null;var r,n=Wr(this.n),i=Wr(this.d),a=1,o=1;for(r in n)if("1"!==r){if("0"===r){a=0;break}if(n[r]*=y.n,n[r]%y.d!=0)return null;n[r]/=y.d,a*=Math.pow(r,n[r])}for(r in i)if("1"!==r){if(i[r]*=y.n,i[r]%y.d!=0)return null;i[r]/=y.d,o*=Math.pow(r,i[r])}return y.s<0?u(o,a):u(a,o)},equals:function(e,t){return Yr(e,t),this.s*this.n*y.d==y.s*y.n*this.d},compare:function(e,t){Yr(e,t);e=this.s*this.n*y.d-y.s*y.n*this.d;return(0<e)-(e<0)},simplify:function(e){if(isNaN(this.n)||isNaN(this.d))return this;e=e||.001;for(var t=this.abs(),r=t.toContinued(),n=1;n<r.length;n++){for(var i=u(r[n-1],1),a=n-2;0<=a;a--)i=i.inverse().add(r[a]);if(Math.abs(i.sub(t).valueOf())<e)return i.mul(this.s)}return this},divisible:function(e,t){return Yr(e,t),!(!(y.n*this.d)||this.n*y.d%(y.n*this.d))},valueOf:function(){return this.s*this.n/this.d},toFraction:function(e){var t="",r=this.n,n=this.d;return this.s<0&&(t+="-"),1===n?t+=r:(e&&0<(e=Math.floor(r/n))&&(t=t+e+" ",r%=n),t=(t+=r)+"/"+n),t},toLatex:function(e){var t="",r=this.n,n=this.d;return this.s<0&&(t+="-"),1===n?t+=r:(e&&0<(e=Math.floor(r/n))&&(t+=e,r%=n),t=(t=(t+="\\frac{")+r+"}{")+n+"}"),t},toContinued:function(){var e,t=this.n,r=this.d,n=[];if(isNaN(t)||isNaN(r))return n;for(;n.push(Math.floor(t/r)),e=t%r,t=r,r=e,1!==t;);return n},toString:function(e){var t=this.n,r=this.d;if(isNaN(t)||isNaN(r))return"NaN";e=e||15;var i=function(e){for(;e%2==0;e/=2);for(;e%5==0;e/=5);if(1===e)return 0;for(var t=10%e,r=1;1!==t;r++)if(t=10*t%e,2e3<r)return 0;return r}(r),n=function(e){for(var t=1,r=function(e,t,r){for(var n=1;0<t;e=e*e%r,t>>=1)1&t&&(n=n*e%r);return n}(10,i,e),n=0;n<300;n++){if(t===r)return n;t=10*t%e,r=10*r%e}return 0}(r),a=this.s<0?"-":"";if(a+=t/r|0,(t=t%r*10)&&(a+="."),i){for(var o=n;o--;)a+=t/r|0,t=t%r*10;for(a+="(",o=i;o--;)a+=t/r|0,t=t%r*10;a+=")"}else for(o=e;t&&o--;)a+=t/r|0,t=t%r*10;return a}};const tn=s("Fraction",[],()=>(Object.defineProperty(Xr,"name",{value:"Fraction"}),(Xr.prototype.constructor=Xr).prototype.type="Fraction",Xr.prototype.isFraction=!0,Xr.prototype.toJSON=function(){return{mathjs:"Fraction",n:this.s*this.n,d:this.d}},Xr.fromJSON=function(e){return new Xr(e)},Xr),{isClass:!0}),rn=(kh(3362),s("Range",[],()=>{function o(e,t,r){if(!(this instanceof o))throw new SyntaxError("Constructor must be called with the new operator");var n=null!=e,i=null!=t,a=null!=r;if(n)if(Q(e))e=e.toNumber();else if("number"!=typeof e)throw new TypeError("Parameter start must be a number");if(i)if(Q(t))t=t.toNumber();else if("number"!=typeof t)throw new TypeError("Parameter end must be a number");if(a)if(Q(r))r=r.toNumber();else if("number"!=typeof r)throw new TypeError("Parameter step must be a number");this.start=n?parseFloat(e):0,this.end=i?parseFloat(t):0,this.step=a?parseFloat(r):1}return o.prototype.type="Range",o.prototype.isRange=!0,o.parse=function(e){if("string"!=typeof e)return null;const t=e.split(":").map(function(e){return parseFloat(e)});if(t.some(function(e){return isNaN(e)}))return null;switch(t.length){case 2:return new o(t[0],t[1]);case 3:return new o(t[0],t[2],t[1]);default:return null}},o.prototype.clone=function(){return new o(this.start,this.end,this.step)},o.prototype.size=function(){let e=0;var t=this.start,r=this.step,t=this.end-t;return n(r)===n(t)?e=Math.ceil(t/r):0==t&&(e=0),[e=isNaN(e)?0:e]},o.prototype.min=function(){var e=this.size()[0];return 0<e?0<this.step?this.start:this.start+(e-1)*this.step:void 0},o.prototype.max=function(){var e=this.size()[0];return 0<e?0<this.step?this.start+(e-1)*this.step:this.start:void 0},o.prototype.forEach=function(e){let t=this.start;var r=this.step,n=this.end;let i=0;if(0<r)for(;t<n;)e(t,[i],this),t+=r,i++;else if(r<0)for(;t>n;)e(t,[i],this),t+=r,i++},o.prototype.map=function(n){const i=[];return this.forEach(function(e,t,r){i[t[0]]=n(e,t,r)}),i},o.prototype.toArray=function(){const r=[];return this.forEach(function(e,t){r[t[0]]=e}),r},o.prototype.valueOf=function(){return this.toArray()},o.prototype.format=function(e){let t=Se(this.start,e);return 1!==this.step&&(t+=":"+Se(this.step,e)),t+=":"+Se(this.end,e)},o.prototype.toString=function(){return this.format()},o.prototype.toJSON=function(){return{mathjs:"Range",start:this.start,end:this.end,step:this.step}},o.fromJSON=function(e){return new o(e.start,e.end,e.step)},o},{isClass:!0})),nn=s("Matrix",[],()=>{function e(){if(!(this instanceof e))throw new SyntaxError("Constructor must be called with the new operator")}return e.prototype.type="Matrix",e.prototype.isMatrix=!0,e.prototype.storage=function(){throw new Error("Cannot invoke storage on a Matrix interface")},e.prototype.datatype=function(){throw new Error("Cannot invoke datatype on a Matrix interface")},e.prototype.create=function(e,t){throw new Error("Cannot invoke create on a Matrix interface")},e.prototype.subset=function(e,t,r){throw new Error("Cannot invoke subset on a Matrix interface")},e.prototype.get=function(e){throw new Error("Cannot invoke get on a Matrix interface")},e.prototype.set=function(e,t,r){throw new Error("Cannot invoke set on a Matrix interface")},e.prototype.resize=function(e,t){throw new Error("Cannot invoke resize on a Matrix interface")},e.prototype.reshape=function(e,t){throw new Error("Cannot invoke reshape on a Matrix interface")},e.prototype.clone=function(){throw new Error("Cannot invoke clone on a Matrix interface")},e.prototype.size=function(){throw new Error("Cannot invoke size on a Matrix interface")},e.prototype.map=function(e,t){throw new Error("Cannot invoke map on a Matrix interface")},e.prototype.forEach=function(e){throw new Error("Cannot invoke forEach on a Matrix interface")},e.prototype[Symbol.iterator]=function(){throw new Error("Cannot iterate a Matrix interface")},e.prototype.toArray=function(){throw new Error("Cannot invoke toArray on a Matrix interface")},e.prototype.valueOf=function(){throw new Error("Cannot invoke valueOf on a Matrix interface")},e.prototype.format=function(e){throw new Error("Cannot invoke format on a Matrix interface")},e.prototype.toString=function(){throw new Error("Cannot invoke toString on a Matrix interface")},e},{isClass:!0});function an(){return(an=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r,n=arguments[t];for(r in n)!{}.hasOwnProperty.call(n,r)||(e[r]=n[r])}return e}).apply(null,arguments)}function on(e,t,r){const n=new e.constructor(2);let i="";if(r){if(r<1)throw new Error("size must be in greater than 0");if(!v(r))throw new Error("size must be an integer");if(e.greaterThan(n.pow(r-1).sub(1))||e.lessThan(n.pow(r-1).mul(-1)))throw new Error(`Value must be in range [-2^${r-1}, 2^${r-1}-1]`);if(!e.isInteger())throw new Error("Value must be an integer");e.lessThan(0)&&(e=e.add(n.pow(r))),i="i"+r}switch(t){case 2:return""+e.toBinary()+i;case 8:return""+e.toOctal()+i;case 16:return""+e.toHexadecimal()+i;default:throw new Error(`Base ${t} not supported `)}}function sn(e,t){return void 0!==t?e.toExponential(t-1):e.toExponential()}function un(e,t){return E(e)?e:Q(e)?e.toNumber():t}function S(e,t){const r=function(t,r){{if("number"==typeof t)return Se(t,r);if(!Q(t))return t&&"object"==typeof t&&"number"==typeof t.s&&"number"==typeof t.n&&"number"==typeof t.d?r&&"decimal"===r.fraction?t.toString():t.s*t.n+"/"+t.d:Array.isArray(t)?function r(n,i){if(Array.isArray(n)){let t="[";const a=n.length;for(let e=0;e<a;e++)0!==e&&(t+=", "),t+=r(n[e],i);return t+="]"}return S(n,i)}(t,r):k(t)?cn(t):"function"==typeof t?t.syntax?String(t.syntax):"function":t&&"object"==typeof t?"function"==typeof t.format?t.format(r):t&&t.toString(r)!=={}.toString()?t.toString(r):"{"+Object.keys(t).map(e=>cn(e)+": "+S(t[e],r)).join(", ")+"}":String(t);{var n=t,i=r;if("function"==typeof i)return i(n);if(!n.isFinite())return n.isNaN()?"NaN":n.gt(0)?"Infinity":"-Infinity";const{notation:s,precision:u,wordSize:c}=Me(i);switch(s){case"fixed":return n.toFixed(u);case"exponential":return sn(n,u);case"engineering":{var a=n;var o=u;const l=a.e,f=l%3==0?l:l<0?l-3-l%3:l-l%3;let e=a.mul(Math.pow(10,-f)).toPrecision(o);return(e=e.includes("e")?new a.constructor(e).toFixed():e)+"e"+(0<=l?"+":"")+f.toString();return}case"bin":return on(n,2,c);case"oct":return on(n,8,c);case"hex":return on(n,16,c);case"auto":{const s=un(null==i?void 0:i.lowerExp,-3),c=un(null==i?void 0:i.upperExp,5);if(n.isZero())return"0";let e;const p=n.toSignificantDigits(u),m=p.e;return(e=m>=s&&m<c?p.toFixed():sn(n,u)).replace(/((\.\d*?)(0+))($|e)/,function(){var e=arguments[2],t=arguments[4];return"."!==e?e+t:t})}default:throw new Error('Unknown notation "'+s+'". Choose "auto", "exponential", "fixed", "bin", "oct", or "hex.')}}}}(e,t);return t&&"object"==typeof t&&"truncate"in t&&r.length>t.truncate?r.substring(0,t.truncate-3)+"...":r}function cn(e){const t=String(e);let r="",n=0;for(;n<t.length;){const e=t.charAt(n);r+=e in ln?ln[e]:e,n++}return'"'+r+'"'}kh(2712);const ln={'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t"};function fn(e){let t=String(e);return t=t.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&#39;").replace(/</g,"&lt;").replace(/>/g,"&gt;")}function pn(e,t){if(!k(e))throw new TypeError("Unexpected type of argument in function compareText (expected: string or Array or Matrix, actual: "+K(e)+", index: 0)");if(k(t))return e===t?0:t<e?1:-1;throw new TypeError("Unexpected type of argument in function compareText (expected: string or Array or Matrix, actual: "+K(t)+", index: 1)")}function z(e,t,r){if(!(this instanceof z))throw new SyntaxError("Constructor must be called with the new operator");this.actual=e,this.expected=t,this.relation=r,this.message="Dimension mismatch ("+(Array.isArray(e)?"["+e.join(", ")+"]":e)+" "+(this.relation||"!=")+" "+(Array.isArray(t)?"["+t.join(", ")+"]":t)+")",this.stack=(new Error).stack}function mn(e,t,r){if(!(this instanceof mn))throw new SyntaxError("Constructor must be called with the new operator");this.index=e,arguments.length<3?(this.min=0,this.max=t):(this.min=t,this.max=r),void 0!==this.min&&this.index<this.min?this.message="Index out of range ("+this.index+" < "+this.min+")":void 0!==this.max&&this.index>=this.max?this.message="Index out of range ("+this.index+" > "+(this.max-1)+")":this.message="Index out of range ("+this.index+")",this.stack=(new Error).stack}function T(e){const t=[];for(;Array.isArray(e);)t.push(e.length),e=e[0];return t}function hn(e,t){if(0===t.length){if(Array.isArray(e))throw new z(e.length,0)}else!function e(t,r,n){let i;var a=t.length;if(a!==r[n])throw new z(a,r[n]);if(n<r.length-1){var o=n+1;for(i=0;i<a;i++){const n=t[i];if(!Array.isArray(n))throw new z(r.length-1,r.length,"<");e(t[i],r,o)}}else for(i=0;i<a;i++)if(Array.isArray(t[i]))throw new z(r.length+1,r.length,">")}(e,t,0)}function dn(e,t){const r=e.isMatrix?e._size:T(e);t._sourceSize.forEach((e,t)=>{if(null!==e&&e!==r[t])throw new z(e,r[t])})}function M(e,t){if(void 0!==e){if(!E(e)||!v(e))throw new TypeError("Index must be an integer (value: "+e+")");if(e<0||"number"==typeof t&&t<=e)throw new mn(e,t)}}function gn(t){for(let e=0;e<t._dimensions.length;++e){var r=t._dimensions[e];if(r._data&&g(r._data)){if(0===r._size[0])return 1}else if(r.isRange){if(r.start===r.end)return 1}else if(k(r)&&0===r.length)return 1}}function yn(e,t,r){if(!Array.isArray(t))throw new TypeError("Array expected");if(0===t.length)throw new Error("Resizing to scalar is not supported");return t.forEach(function(e){if(!E(e)||!v(e)||e<0)throw new TypeError("Invalid size, must contain positive integers (size: "+S(t)+")")}),function e(t,r,n,i){let a,o;const s=t.length,u=r[n],c=Math.min(s,u);if(t.length=u,n<r.length-1){const s=n+1;for(a=0;a<c;a++)o=t[a],Array.isArray(o)||(o=[o],t[a]=o),e(o,r,s,i);for(a=c;a<u;a++)o=[],t[a]=o,e(o,r,s,i)}else{for(a=0;a<c;a++)for(;Array.isArray(t[a]);)t[a]=t[a][0];for(a=c;a<u;a++)t[a]=i}}(e=E(e)||Q(e)?[e]:e,t,0,void 0!==r?r:0),e}function xn(e,n){var i=A(e),t=i.length;if(!Array.isArray(e)||!Array.isArray(n))throw new TypeError("Array expected");if(0===n.length)throw new z(0,t,"!=");var r=vn(n=bn(n,t));if(t!==r)throw new z(r,t,"!=");try{{var a=n;let t,r=i;for(let e=a.length-1;0<e;e--){var o=a[e],s=(t=[],r.length/o);for(let e=0;e<s;e++)t.push(r.slice(e*o,(e+1)*o));r=t}return r;return}}catch(e){if(e instanceof z)throw new z(r,t,"!=");throw e}}function bn(e,t){const r=vn(e),n=e.slice(),i=e.indexOf(-1);if(0<=e.indexOf(-1,i+1))throw new Error("More than one wildcard in sizes");if(0<=i){if(t%r!=0)throw new Error("Could not replace wildcard, since "+t+" is no multiple of "+-r);n[i]=-t/r}return n}function vn(e){return e.reduce((e,t)=>e*t,1)}function wn(e,t){const r=t||T(e);for(;Array.isArray(e)&&1===e.length;)e=e[0],r.shift();let n=r.length;for(;1===r[n-1];)n--;return n<r.length&&(e=function e(t,r,n){let i,a;if(n<r){const o=n+1;for(i=0,a=t.length;i<a;i++)t[i]=e(t[i],r,o)}else for(;Array.isArray(t);)t=t[0];return t}(e,n,0),r.length=n),e}function Nn(t,e,r,n){const i=n||T(t);if(r)for(let e=0;e<r;e++)t=[t],i.unshift(1);for(t=function e(t,r,n){let i,a;if(Array.isArray(t)){const o=n+1;for(i=0,a=t.length;i<a;i++)t[i]=e(t[i],r,o)}else for(let e=n;e<r;e++)t=[t];return t}(t,e,0);i.length<e;)i.push(1);return t}function A(e){if(!Array.isArray(e))return e;const r=[];return e.forEach(function e(t){Array.isArray(t)?t.forEach(e):r.push(t)}),r}function En(e,t){return Array.prototype.map.call(e,t)}function An(e,t){Array.prototype.forEach.call(e,t)}function Sn(e,t){if(1!==T(e).length)throw new Error("Only one dimensional matrices supported");return Array.prototype.filter.call(e,t)}function Mn(e,t){if(1!==T(e).length)throw new Error("Only one dimensional matrices supported");return Array.prototype.filter.call(e,e=>t.test(e))}function Cn(e,t){return Array.prototype.join.call(e,t)}function Tn(t){if(!Array.isArray(t))throw new TypeError("Array input expected");if(0===t.length)return t;const r=[];let n=0;r[0]={value:t[0],identifier:0};for(let e=1;e<t.length;e++)t[e]===t[e-1]?n++:n=0,r.push({value:t[e],identifier:n});return r}function Dn(t){if(!Array.isArray(t))throw new TypeError("Array input expected");if(0===t.length)return t;const r=[];for(let e=0;e<t.length;e++)r.push(t[e].value);return r}function Fn(t,r){let n,i=0;for(let e=0;e<t.length;e++){var a=t[e],o=Array.isArray(a);if(0===e&&o&&(i=a.length),o&&a.length!==i)return;o=o?Fn(a,r):r(a);if(void 0===n)n=o;else if(n!==o)return"mixed"}return n}function Bn(){const e=Array.prototype.slice.call(arguments,0,-1),r=Array.prototype.slice.call(arguments,-1);if(1===e.length)return e[0];if(1<e.length)return e.slice(1).reduce(function(e,t){return function t(r,n,i,a){if(a<i){if(r.length!==n.length)throw new z(r.length,n.length);const o=[];for(let e=0;e<r.length;e++)o[e]=t(r[e],n[e],i,a+1);return o}return r.concat(n)}(e,t,r,0)},e[0]);throw new Error("Wrong number of arguments in function concat")}function On(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];const n=t.map(e=>e.length),i=Math.max(...n),a=new Array(i).fill(null);for(let e=0;e<t.length;e++){const r=t[e],o=n[e];for(let e=0;e<o;e++){const t=i-o+e;r[e]>a[t]&&(a[t]=r[e])}}for(let e=0;e<t.length;e++)_n(t[e],a);return a}function _n(t,r){var n=r.length,i=t.length;for(let e=0;e<i;e++){var a=n-i+e;if(t[e]<r[a]&&1<t[e]||t[e]>r[a])throw new Error(`shape missmatch: missmatch is found in arg with shape (${t}) not possible to broadcast dimension ${i} with size ${t[e]} to size `+r[a])}}function zn(e,t){let r=T(e);if(Ue(r,t))return e;_n(r,t);var n,i,a,o=On(r,t),s=o.length,t=[...Array(s-r.length).fill(1),...r];let u=an([],e);r.length<s&&(u=xn(u,t),r=T(u));for(let e=0;e<s;e++)r[e]<o[e]&&(n=u,i=o[e],a=e,u=Bn(...Array(i).fill(n),a),r=T(u));return u}function In(n){let i=0,a=1,o=Object.create(null),s=Object.create(null),u=0;function c(e){var t=s[e];if(t&&(delete o[t],delete s[e],--i,a===t)){if(!i)return u=0,void(a=1);for(;!Object.prototype.hasOwnProperty.call(o,++a););}}return n=Math.abs(n),{hit:function(e){var t=s[e],r=++u;if(o[r]=e,s[e]=r,!t)return++i<=n?void 0:(e=o[a],c(e),e);if(delete o[t],a===t)for(;!Object.prototype.hasOwnProperty.call(o,++a););},delete:c,clear:function(){i=u=0,a=1,o=Object.create(null),s=Object.create(null)}}}function kn(i,e){let{hasher:a,limit:o}=1<arguments.length&&void 0!==e?e:{};return o=null==o?Number.POSITIVE_INFINITY:o,a=null==a?JSON.stringify:a,function e(){"object"!=typeof e.cache&&(e.cache={values:new Map,lru:In(o||Number.POSITIVE_INFINITY)});const t=[];for(let e=0;e<arguments.length;e++)t[e]=arguments[e];var r=a(t);if(e.cache.values.has(r))return e.cache.lru.hit(r),e.cache.values.get(r);var n=i.apply(i,t);return e.cache.values.set(r,n),e.cache.values.delete(e.cache.lru.hit(r)),n}}function qn(e){return Object.keys(e.signatures||{}).reduce(function(e,t){t=(t.match(/,/g)||[]).length+1;return Math.max(e,t)},-1)}(z.prototype=new RangeError).constructor=RangeError,z.prototype.name="DimensionError",z.prototype.isDimensionError=!0,(mn.prototype=new RangeError).constructor=RangeError,mn.prototype.name="IndexError",mn.prototype.isIndexError=!0,kh(3110);const Rn=s("DenseMatrix",["Matrix"],e=>{let t=e["Matrix"];function p(e,t){if(!(this instanceof p))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!k(t))throw new Error("Invalid datatype: "+t);if(_(e))"DenseMatrix"===e.type?(this._data=ee(e._data),this._size=ee(e._size)):(this._data=e.toArray(),this._size=e.size()),this._datatype=t||e._datatype;else if(e&&g(e.data)&&g(e.size))this._data=e.data,this._size=e.size,hn(this._data,this._size),this._datatype=t||e.datatype;else if(g(e))this._data=r(e),this._size=T(this._data),hn(this._data,this._size),this._datatype=t;else{if(e)throw new TypeError("Unsupported type of data ("+K(e)+")");this._data=[],this._size=[0],this._datatype=t}}function a(t,e,r){if(0!==e.length)return t._size=e.slice(0),t._data=yn(t._data,t._size,r),t;{let e=t._data;for(;g(e);)e=e[0];return e}}function m(e,r,t){const n=e._size.slice(0);let i=!1;for(;n.length<r.length;)n.push(0),i=!0;for(let e=0,t=r.length;e<t;e++)r[e]>n[e]&&(n[e]=r[e],i=!0);i&&a(e,n,t)}function r(e){return _(e)?r(e.valueOf()):g(e)?e.map(r):e}return(p.prototype=new t).createDenseMatrix=function(e,t){return new p(e,t)},Object.defineProperty(p,"name",{value:"DenseMatrix"}),(p.prototype.constructor=p).prototype.type="DenseMatrix",p.prototype.isDenseMatrix=!0,p.prototype.getDataType=function(){return Fn(this._data,K)},p.prototype.storage=function(){return"dense"},p.prototype.datatype=function(){return this._datatype},p.prototype.create=function(e,t){return new p(e,t)},p.prototype.subset=function(e,t,n){switch(arguments.length){case 1:var r=this,i=e;if(!j(i))throw new TypeError("Invalid index");if(i.isScalar())return r.get(i.min());var a=i.size();if(a.length!==r._size.length)throw new z(a.length,r._size.length);var o=i.min(),s=i.max();for(let e=0,t=r._size.length;e<t;e++)M(o[e],r._size[e]),M(s[e],r._size[e]);return new p(function t(r,n,i,a){const e=a===i-1,o=n.dimension(a);return(e?o.map(function(e){return M(e,r.length),r[e]}):o.map(function(e){return M(e,r.length),t(r[e],n,i,a+1)})).valueOf()}(r._data,i,a.length,0),r._datatype);case 2:case 3:{var u=this;i=e;a=t;var c=n;if(!i||!0!==i.isIndex)throw new TypeError("Invalid index");const l=i.size(),f=i.isScalar();let r;if(_(a)?(r=a.size(),a=a.valueOf()):r=T(a),f){if(0!==r.length)throw new TypeError("Scalar expected");u.set(i.min(),a,c)}else{if(!Ue(r,l))try{r=T(a=0===r.length?zn([a],l):zn(a,l))}catch(u){}if(l.length<u._size.length)throw new z(l.length,u._size.length,"<");if(r.length<l.length){let e=0,t=0;for(;1===l[e]&&1===r[e];)e++;for(;1===l[e];)t++,e++;a=Nn(a,l.length,t,r)}if(!Ue(l,r))throw new z(l,r,">");m(u,i.max().map(function(e){return e+1}),c);const f=l.length;!function r(n,i,a,o,s){const e=s===o-1,t=i.dimension(s);e?t.forEach(function(e,t){M(e),n[e]=a[t[0]]}):t.forEach(function(e,t){M(e),r(n[e],i,a[t[0]],o,s+1)})}(u._data,i,a,f,0)}return u;return}default:throw new SyntaxError("Wrong number of arguments")}},p.prototype.get=function(r){if(!g(r))throw new TypeError("Array expected");if(r.length!==this._size.length)throw new z(r.length,this._size.length);for(let e=0;e<r.length;e++)M(r[e],this._size[e]);let n=this._data;for(let e=0,t=r.length;e<t;e++){var i=r[e];M(i,n.length),n=n[i]}return n},p.prototype.set=function(e,t,r){if(!g(e))throw new TypeError("Array expected");if(e.length<this._size.length)throw new z(e.length,this._size.length,"<");let n,i,a;m(this,e.map(function(e){return e+1}),r);let o=this._data;for(n=0,i=e.length-1;n<i;n++)M(a=e[n],o.length),o=o[a];return M(a=e[e.length-1],o.length),o[a]=t,this},p.prototype.resize=function(e,t,r){if(!q(e))throw new TypeError("Array or Matrix expected");e=e.valueOf().map(e=>Array.isArray(e)&&1===e.length?e[0]:e);return a(r?this.clone():this,e,t)},p.prototype.reshape=function(e,t){const r=t?this.clone():this;r._data=xn(r._data,e);t=r._size.reduce((e,t)=>e*t);return r._size=bn(e,t),r},p.prototype.clone=function(){return new p({data:ee(this._data),size:ee(this._size),datatype:this._datatype})},p.prototype.size=function(){return this._size.slice(0)},p.prototype.map=function(t){function n(e,r){return g(e)?e.map(function(e,t){return n(e,r.concat(t))}):1===a?t(e):2===a?t(e,r):t(e,r,i)}const i=this,a=qn(t),e=n(this._data,[]);return new p(e,void 0!==this._datatype?Fn(e,K):void 0)},p.prototype.forEach=function(t){function n(e,r){g(e)?e.forEach(function(e,t){n(e,r.concat(t))}):t(e,r,i)}const i=this;n(this._data,[])},p.prototype[Symbol.iterator]=function*(){function*n(t,r){if(g(t))for(let e=0;e<t.length;e++)yield*n(t[e],r.concat(e));else yield{value:t,index:r}}yield*n(this._data,[])},p.prototype.rows=function(){const e=[];if(2!==this.size().length)throw new TypeError("Rows can only be returned for a 2D matrix.");for(const t of this._data)e.push(new p([t],this._datatype));return e},p.prototype.columns=function(){const e=[],r=this.size();if(2!==r.length)throw new TypeError("Rows can only be returned for a 2D matrix.");const n=this._data;for(let t=0;t<r[1];t++){const r=n.map(e=>[e[t]]);e.push(new p(r,this._datatype))}return e},p.prototype.toArray=function(){return ee(this._data)},p.prototype.valueOf=function(){return this._data},p.prototype.format=function(e){return S(this._data,e)},p.prototype.toString=function(){return S(this._data)},p.prototype.toJSON=function(){return{mathjs:"DenseMatrix",data:this._data,size:this._size,datatype:this._datatype}},p.prototype.diagonal=function(e){if(e){if(!E(e=Q(e)?e.toNumber():e)||!v(e))throw new TypeError("The parameter k must be an integer number")}else e=0;const t=0<e?e:0,r=e<0?-e:0,n=this._size[0],i=this._size[1],a=Math.min(n-r,i-t),o=[];for(let e=0;e<a;e++)o[e]=this._data[e+r][e+t];return new p({data:o,size:[a],datatype:this._datatype})},p.diagonal=function(e,t,r,n){if(!g(e))throw new TypeError("Array expected, size parameter");if(2!==e.length)throw new Error("Only two dimensions matrix are supported");if(e=e.map(function(e){if(!E(e=Q(e)?e.toNumber():e)||!v(e)||e<1)throw new Error("Size values must be positive integers");return e}),r){if(!E(r=Q(r)?r.toNumber():r)||!v(r))throw new TypeError("The parameter k must be an integer number")}else r=0;var i=0<r?r:0,a=r<0?-r:0,r=e[0],o=e[1],s=Math.min(r-a,o-i);let u;if(g(t)){if(t.length!==s)throw new Error("Invalid value array length");u=function(e){return t[e]}}else if(_(t)){const e=t.size();if(1!==e.length||e[0]!==s)throw new Error("Invalid matrix length");u=function(e){return t.get([e])}}else u=function(){return t};n=n||(Q(u(0))?u(0).mul(0):0);let c=[];if(0<e.length){c=yn(c,e,n);for(let e=0;e<s;e++)c[e+a][e+i]=u(e)}return new p({data:c,size:[r,o]})},p.fromJSON=function(e){return new p(e)},p.prototype.swapRows=function(e,t){if(!(E(e)&&v(e)&&E(t)&&v(t)))throw new Error("Row index must be positive integers");if(2!==this._size.length)throw new Error("Only two dimensional matrix is supported");return M(e,this._size[0]),M(t,this._size[0]),p._swapRows(e,t,this._data),this},p._swapRows=function(e,t,r){var n=r[e];r[e]=r[t],r[t]=n},p},{isClass:!0}),Pn=s("clone",["typed"],e=>{let t=e["typed"];return t("clone",{any:ee})});function jn(e){const t=e.length,r=e[0].length;let n,i;const a=[];for(i=0;i<r;i++){const r=[];for(n=0;n<t;n++)r.push(e[n][i]);a.push(r)}return a}function Un(t){for(let e=0;e<t.length;e++)if(q(t[e]))return 1}function Ln(r,n){for(let e=0,t=(r=_(r)?r.valueOf():r).length;e<t;e++){var i=r[e];Array.isArray(i)?Ln(i,n):n(i)}}function ce(e,t,r){return e&&"function"==typeof e.map?e.map(function(e){return ce(e,t,r)}):t(e)}function $n(e,t,r){var n=Array.isArray(e)?T(e):e.size();if(t<0||t>=n.length)throw new mn(t,n.length);return _(e)?e.create(Hn(e.valueOf(),t,r)):Hn(e,t,r)}function Hn(e,t,r){let n,i,a,o;if(t<=0){if(Array.isArray(e[0])){for(o=jn(e),i=[],n=0;n<o.length;n++)i[n]=Hn(o[n],t-1,r);return i}for(a=e[0],n=1;n<e.length;n++)a=r(a,e[n]);return a}for(i=[],n=0;n<e.length;n++)i[n]=Hn(e[n],t-1,r);return i}function Gn(e,t,r,n,i,a,o,s,u,c,l){var f=e._values,p=e._index,e=e._ptr;let m,h,d,g;if(n)for(h=e[t],d=e[t+1],m=h;m<d;m++)r[g=p[m]]!==a?(r[g]=a,o.push(g),c?(n[g]=u?s(f[m],l):s(l,f[m]),i[g]=a):n[g]=f[m]):(n[g]=u?s(f[m],n[g]):s(n[g],f[m]),i[g]=a);else for(h=e[t],d=e[t+1],m=h;m<d;m++)r[g=p[m]]!==a?(r[g]=a,o.push(g)):i[g]=a}const Zn="isInteger",Vn=s(Zn,["typed"],e=>{let t=e["typed"];return t(Zn,{number:v,BigNumber:function(e){return e.isInt()},bigint:function(e){return!0},Fraction:function(e){return 1===e.d&&isFinite(e.n)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),Wn="number";function Yn(e){return Number.isNaN(e)}function Jn(e,t,r,n){r=2<arguments.length&&void 0!==r?r:1e-9,n=3<arguments.length&&void 0!==n?n:0;if(r<=0)throw new Error("Relative tolerance must be greater than 0");if(n<0)throw new Error("Absolute tolerance must be at least 0");return!e.isNaN()&&!t.isNaN()&&(e.isFinite()&&t.isFinite()?!!e.eq(t)||e.minus(t).abs().lte(e.constructor.max(e.constructor.max(e.abs(),t.abs()).mul(r),n)):e.eq(t))}Yn.signature=Wn;const Xn="isNegative",Qn=s(Xn,["typed","config"],e=>{let{typed:r,config:t}=e;return r(Xn,{number:e=>!p(e,0,t.relTol,t.absTol)&&e<0,BigNumber:e=>!Jn(e,new e.constructor(0),t.relTol,t.absTol)&&e.isNeg()&&!e.isZero()&&!e.isNaN(),bigint:e=>e<0n,Fraction:e=>e.s<0,Unit:r.referToSelf(t=>e=>r.find(t,e.valueType())(e.value)),"Array | Matrix":r.referToSelf(t=>e=>ce(e,t))})}),Kn="isNumeric",ei=s(Kn,["typed"],e=>{let t=e["typed"];return t(Kn,{"number | BigNumber | bigint | Fraction | boolean":()=>!0,"Complex | Unit | string | null | undefined | Node":()=>!1,"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),ti="hasNumericValue",ri=s(ti,["typed","isNumeric"],e=>{let{typed:t,isNumeric:r}=e;return t(ti,{boolean:()=>!0,string:function(e){return 0<e.trim().length&&!isNaN(Number(e))},any:function(e){return r(e)}})}),ni="isPositive",ii=s(ni,["typed","config"],e=>{let{typed:r,config:t}=e;return r(ni,{number:e=>!p(e,0,t.relTol,t.absTol)&&0<e,BigNumber:e=>!(Jn(e,new e.constructor(0),t.relTol,t.absTol)||e.isNeg()||e.isZero()||e.isNaN()),bigint:e=>0n<e,Fraction:e=>0<e.s&&0<e.n,Unit:r.referToSelf(t=>e=>r.find(t,e.valueType())(e.value)),"Array | Matrix":r.referToSelf(t=>e=>ce(e,t))})}),ai=s("isZero",["typed","equalScalar"],e=>{let{typed:r,equalScalar:t}=e;return r("isZero",{"number | BigNumber | Complex | Fraction":e=>t(e,0),bigint:e=>0n===e,Unit:r.referToSelf(t=>e=>r.find(t,e.valueType())(e.value)),"Array | Matrix":r.referToSelf(t=>e=>ce(e,t))})}),oi=s("isNaN",["typed"],e=>{let t=e["typed"];return t("isNaN",{number:Yn,BigNumber:function(e){return e.isNaN()},bigint:function(e){return!1},Fraction:function(e){return!1},Complex:function(e){return e.isNaN()},Unit:function(e){return Number.isNaN(e.value)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),si=s("typeOf",["typed"],e=>{let t=e["typed"];return t("typeOf",{any:K})}),ui=s("compareUnits",["typed"],e=>{let n=e["typed"];return{"Unit, Unit":n.referToSelf(r=>(e,t)=>{if(e.equalBase(t))return n.find(r,[e.valueType(),t.valueType()])(e.value,t.value);throw new Error("Cannot compare units with different base")})}}),ci="equalScalar",li=s(ci,["typed","config"],e=>{let{typed:t,config:i}=e;e=ui({typed:t});return t(ci,{"boolean, boolean":function(e,t){return e===t},"number, number":function(e,t){return p(e,t,i.relTol,i.absTol)},"BigNumber, BigNumber":function(e,t){return e.eq(t)||Jn(e,t,i.relTol,i.absTol)},"bigint, bigint":function(e,t){return e===t},"Fraction, Fraction":function(e,t){return e.equals(t)},"Complex, Complex":function(e,t){return e=e,t=t,r=i.relTol,n=i.absTol,p(e.re,t.re,r,n)&&p(e.im,t.im,r,n);var r,n}},e)}),fi=(s(ci,["typed","config"],e=>{let{typed:t,config:r}=e;return t(ci,{"number, number":function(e,t){return p(e,t,r.relTol,r.absTol)}})}),s("SparseMatrix",["typed","equalScalar","Matrix"],e=>{let{typed:y,equalScalar:x,Matrix:t}=e;function A(e,t){if(!(this instanceof A))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!k(t))throw new Error("Invalid datatype: "+t);if(_(e))r=this,i=t,"SparseMatrix"===(n=e).type?(r._values=n._values?ee(n._values):void 0,r._index=ee(n._index),r._ptr=ee(n._ptr),r._size=ee(n._size),r._datatype=i||n._datatype):a(r,n.valueOf(),i||n._datatype);else if(e&&g(e.index)&&g(e.ptr)&&g(e.size))this._values=e.values,this._index=e.index,this._ptr=e.ptr,this._size=e.size,this._datatype=t||e.datatype;else if(g(e))a(this,e,t);else{if(e)throw new TypeError("Unsupported type of data ("+K(e)+")");this._values=[],this._index=[],this._ptr=[0],this._size=[0,0],this._datatype=t}var r,n,i}function a(r,n,i){r._values=[],r._index=[],r._ptr=[],r._datatype=i;var a=n.length;let o=0,s=x,u=0;if(k(i)&&(s=y.find(x,[i,i])||x,u=y.convert(0,i)),0<a){let t=0;do{r._ptr.push(r._index.length);for(let e=0;e<a;e++){const i=n[e];if(g(i)){if(0===t&&o<i.length&&(o=i.length),t<i.length){const n=i[t];s(n,u)||(r._values.push(n),r._index.push(e))}}else 0===t&&o<1&&(o=1),s(i,u)||(r._values.push(i),r._index.push(e))}}while(++t<o)}r._ptr.push(r._index.length),r._size=[a,o]}function m(t,r,n,i){if(n-r==0)return n;for(let e=r;e<n;e++)if(i[e]===t)return e;return r}function h(e,t,r,n,i,a,o){i.splice(e,0,n),a.splice(e,0,t);for(let e=r+1;e<o.length;e++)o[e]++}function d(r,n,t,e){let i=e||0,a=x,o=0;k(r._datatype)&&(a=y.find(x,[r._datatype,r._datatype])||x,o=y.convert(0,r._datatype),i=y.convert(i,r._datatype));var s=!a(i,o),u=r._size[0];let c,l,f,p=r._size[1];if(t>p){for(l=p;l<t;l++)if(r._ptr[l]=r._values.length,s)for(c=0;c<u;c++)r._values.push(i),r._index.push(c);r._ptr[t]=r._values.length}else t<p&&(r._ptr.splice(t+1,p-t),r._values.splice(r._ptr[t],r._values.length),r._index.splice(r._ptr[t],r._index.length));if(p=t,u<n){if(s){let t=0;for(l=0;l<p;l++){r._ptr[l]=r._ptr[l]+t,f=r._ptr[l+1]+t;let e=0;for(c=u;c<n;c++,e++)r._values.splice(f+e,0,i),r._index.splice(f+e,0,c),t++}r._ptr[p]=r._values.length}}else if(n<u){let e=0;for(l=0;l<p;l++){r._ptr[l]=r._ptr[l]-e;const x=r._ptr[l],t=r._ptr[l+1]-e;for(f=x;f<t;f++)(c=r._index[f])>n-1&&(r._values.splice(f,1),r._index.splice(f,1),e++)}r._ptr[l]=r._values.length}return r._size[0]=n,r._size[1]=t,r}function r(t,r,e,n,i){const a=n[0],o=n[1],s=[];let u,c;for(u=0;u<a;u++)for(s[u]=[],c=0;c<o;c++)s[u][c]=0;for(c=0;c<o;c++){const n=e[c],a=e[c+1];for(let e=n;e<a;e++)u=r[e],s[u][c]=t?i?ee(t[e]):t[e]:1}return s}return(A.prototype=new t).createSparseMatrix=function(e,t){return new A(e,t)},Object.defineProperty(A,"name",{value:"SparseMatrix"}),(A.prototype.constructor=A).prototype.type="SparseMatrix",A.prototype.isSparseMatrix=!0,A.prototype.getDataType=function(){return Fn(this._values,K)},A.prototype.storage=function(){return"sparse"},A.prototype.datatype=function(){return this._datatype},A.prototype.create=function(e,t){return new A(e,t)},A.prototype.density=function(){var e=this._size[0],t=this._size[1];return 0!==e&&0!==t?this._index.length/(e*t):0},A.prototype.subset=function(i,e,t){if(!this._values)throw new Error("Cannot invoke subset on a Pattern only matrix");switch(arguments.length){case 1:{var a=this;var o=i;if(!j(o))throw new TypeError("Invalid index");if(o.isScalar())return a.get(o.min());var s=o.size();if(s.length!==a._size.length)throw new z(s.length,a._size.length);let t,e,r,n;var u=o.min(),c=o.max();for(t=0,e=a._size.length;t<e;t++)M(u[t],a._size[t]),M(c[t],a._size[t]);const m=a._values,h=a._index,d=a._ptr,g=o.dimension(0),y=o.dimension(1),x=[],b=[],v=(g.forEach(function(e,t){b[e]=t[0],x[e]=!0}),m?[]:void 0),w=[],N=[];return y.forEach(function(e){for(N.push(w.length),r=d[e],n=d[e+1];r<n;r++)t=h[r],!0===x[t]&&(w.push(b[t]),v&&v.push(m[r]))}),N.push(w.length),new A({values:v,index:w,ptr:N,size:s,datatype:a._datatype});return}case 2:case 3:{var l=this;o=i;var f=e;var p=t;if(!o||!0!==o.isIndex)throw new TypeError("Invalid index");const n=o.size(),E=o.isScalar();let r;if(_(f)?(r=f.size(),f=f.toArray()):r=T(f),E){if(0!==r.length)throw new TypeError("Scalar expected");l.set(o.min(),f,p)}else{if(1!==n.length&&2!==n.length)throw new z(n.length,l._size.length,"<");if(r.length<n.length){let e=0,t=0;for(;1===n[e]&&1===r[e];)e++;for(;1===n[e];)t++,e++;f=Nn(f,n.length,t,r)}if(!Ue(n,r))throw new z(n,r,">");if(1===n.length)o.dimension(0).forEach(function(e,t){M(e),l.set([e,0],f[t[0]],p)});else{const n=o.dimension(0),E=o.dimension(1);n.forEach(function(r,n){M(r),E.forEach(function(e,t){M(e),l.set([r,e],f[n[0]][t[0]],p)})})}}return l;return}default:throw new SyntaxError("Wrong number of arguments")}},A.prototype.get=function(e){if(!g(e))throw new TypeError("Array expected");if(e.length!==this._size.length)throw new z(e.length,this._size.length);if(!this._values)throw new Error("Cannot invoke get on a Pattern only matrix");var t=e[0],e=e[1],r=(M(t,this._size[0]),M(e,this._size[1]),m(t,this._ptr[e],this._ptr[e+1],this._index));return r<this._ptr[e+1]&&this._index[r]===t?this._values[r]:0},A.prototype.set=function(e,t,r){if(!g(e))throw new TypeError("Array expected");if(e.length!==this._size.length)throw new z(e.length,this._size.length);if(!this._values)throw new Error("Cannot invoke set on a Pattern only matrix");var n=e[0],e=e[1];let i=this._size[0],a=this._size[1],o=x,s=0;k(this._datatype)&&(o=y.find(x,[this._datatype,this._datatype])||x,s=y.convert(0,this._datatype)),(n>i-1||e>a-1)&&(d(this,Math.max(n+1,i),Math.max(e+1,a),r),i=this._size[0],a=this._size[1]),M(n,i),M(e,a);r=m(n,this._ptr[e],this._ptr[e+1],this._index);if(r<this._ptr[e+1]&&this._index[r]===n)if(o(t,s)){var u=r,c=e,l=this._values,f=this._index,p=this._ptr;l.splice(u,1),f.splice(u,1);for(let e=c+1;e<p.length;e++)p[e]--}else this._values[r]=t;else o(t,s)||h(r,n,e,t,this._values,this._index,this._ptr);return this},A.prototype.resize=function(e,t,r){if(!q(e))throw new TypeError("Array or Matrix expected");const n=e.valueOf().map(e=>Array.isArray(e)&&1===e.length?e[0]:e);if(2!==n.length)throw new Error("Only two dimensions matrix are supported");return n.forEach(function(e){if(!E(e)||!v(e)||e<0)throw new TypeError("Invalid size, must contain positive integers (size: "+S(n)+")")}),d(r?this.clone():this,n[0],n[1],t)},A.prototype.reshape=function(t,r){if(!g(t))throw new TypeError("Array expected");if(2!==t.length)throw new Error("Sparse matrices can only be reshaped in two dimensions");t.forEach(function(e){if(!E(e)||!v(e)||e<=-2||0===e)throw new TypeError("Invalid size, must contain positive integers or -1 (size: "+S(t)+")")});const n=this._size[0]*this._size[1];if(n!==(t=bn(t,n))[0]*t[1])throw new Error("Reshaping sparse matrix will result in the wrong number of elements");const i=r?this.clone():this;if(this._size[0]===t[0]&&this._size[1]===t[1])return i;const a=[];for(let t=0;t<i._ptr.length;t++)for(let e=0;e<i._ptr[t+1]-i._ptr[t];e++)a.push(t);const o=i._values.slice(),s=i._index.slice();for(let e=0;e<i._index.length;e++){const r=s[e],n=a[e],o=r*i._size[1]+n;a[e]=o%t[1],s[e]=Math.floor(o/t[1])}i._values.length=0,i._index.length=0,i._ptr.length=t[1]+1,i._size=t.slice();for(let e=0;e<i._ptr.length;e++)i._ptr[e]=0;for(let e=0;e<o.length;e++){const E=s[e],r=a[e],n=o[e];h(m(E,i._ptr[r],i._ptr[r+1],i._index),E,r,n,i._values,i._index,i._ptr)}return i},A.prototype.clone=function(){return new A({values:this._values?ee(this._values):void 0,index:ee(this._index),ptr:ee(this._ptr),size:ee(this._size),datatype:this._datatype})},A.prototype.size=function(){return this._size.slice(0)},A.prototype.map=function(s,e){if(!this._values)throw new Error("Cannot invoke map on a Pattern only matrix");const u=this,t=this._size[0],r=this._size[1],c=qn(s);{var n=this,i=t-1,l=r-1,f=e;const m=[],h=[],d=[];let a=x,o=0;function p(e,t,r){var n,i;n=e,i=t,r=r,e=1===c?s(n):2===c?s(n,[i,r]):s(n,[i,r],u),a(e,o)||(m.push(e),h.push(t))}k(n._datatype)&&(a=y.find(x,[n._datatype,n._datatype])||x,o=y.convert(0,n._datatype));for(let t=0;t<=l;t++){d.push(m.length);const y=n._ptr[t],x=n._ptr[t+1];if(f)for(let e=y;e<x;e++){const y=n._index[e];0<=y&&y<=i&&p(n._values[e],+y,+t)}else{const g={};for(let e=y;e<x;e++)g[n._index[e]]=n._values[e];for(let e=0;e<=i;e++)p(e in g?g[e]:0,+e,+t)}}return d.push(m.length),new A({values:m,index:h,ptr:d,size:[1+i,1+l]})}},A.prototype.forEach=function(r,n){if(!this._values)throw new Error("Cannot invoke forEach on a Pattern only matrix");const i=this._size[0],a=this._size[1];for(let t=0;t<a;t++){const a=this._ptr[t],o=this._ptr[t+1];if(n)for(let e=a;e<o;e++){const i=this._index[e];r(this._values[e],[i,t],this)}else{const n={};for(let e=a;e<o;e++)n[this._index[e]]=this._values[e];for(let e=0;e<i;e++)r(e in n?n[e]:0,[e,t],this)}}},A.prototype[Symbol.iterator]=function*(){if(!this._values)throw new Error("Cannot iterate a Pattern only matrix");const r=this._size[1];for(let t=0;t<r;t++){const r=this._ptr[t],n=this._ptr[t+1];for(let e=r;e<n;e++){const r=this._index[e];yield{value:this._values[e],index:[r,t]}}}},A.prototype.toArray=function(){return r(this._values,this._index,this._ptr,this._size,!0)},A.prototype.valueOf=function(){return r(this._values,this._index,this._ptr,this._size,!1)},A.prototype.format=function(r){const e=this._size[0],n=this._size[1],i=this.density();let a="Sparse Matrix ["+S(e,r)+" x "+S(n,r)+"] density: "+S(i,r)+"\n";for(let t=0;t<n;t++){const n=this._ptr[t],i=this._ptr[t+1];for(let e=n;e<i;e++)a+="\n    ("+S(this._index[e],r)+", "+S(t,r)+") ==> "+(this._values?S(this._values[e],r):"X")}return a},A.prototype.toString=function(){return S(this.toArray())},A.prototype.toJSON=function(){return{mathjs:"SparseMatrix",values:this._values,index:this._index,ptr:this._ptr,size:this._size,datatype:this._datatype}},A.prototype.diagonal=function(e){if(e){if(!E(e=Q(e)?e.toNumber():e)||!v(e))throw new TypeError("The parameter k must be an integer number")}else e=0;const r=0<e?e:0,n=e<0?-e:0,t=this._size[0],i=this._size[1],a=Math.min(t-n,i-r),o=[],s=[],u=[];u[0]=0;for(let t=r;t<i&&o.length<a;t++){const E=this._ptr[t],Q=this._ptr[t+1];for(let e=E;e<Q;e++){const E=this._index[e];if(E===t-r+n){o.push(this._values[e]),s[o.length-1]=E-n;break}}}return u.push(o.length),new A({values:o,index:s,ptr:u,size:[a,1]})},A.fromJSON=function(e){return new A(e)},A.diagonal=function(t,r,e,n,i){if(!g(t))throw new TypeError("Array expected, size parameter");if(2!==t.length)throw new Error("Only two dimensions matrix are supported");if(t=t.map(function(e){if(!E(e=Q(e)?e.toNumber():e)||!v(e)||e<1)throw new Error("Size values must be positive integers");return e}),e){if(!E(e=Q(e)?e.toNumber():e)||!v(e))throw new TypeError("The parameter k must be an integer number")}else e=0;let a=x,o=0;k(i)&&(a=y.find(x,[i,i])||x,o=y.convert(0,i));var s=0<e?e:0,u=e<0?-e:0,i=t[0],c=t[1],l=Math.min(i-u,c-s);let f;if(g(r)){if(r.length!==l)throw new Error("Invalid value array length");f=function(e){return r[e]}}else if(_(r)){const t=r.size();if(1!==t.length||t[0]!==l)throw new Error("Invalid matrix length");f=function(e){return r.get([e])}}else f=function(){return r};const p=[],m=[],h=[];for(let e=0;e<c;e++){h.push(p.length);const E=e-s;if(0<=E&&E<l){const t=f(E);a(t,o)||(m.push(E+u),p.push(t))}}return h.push(p.length),new A({values:p,index:m,ptr:h,size:[i,c]})},A.prototype.swapRows=function(e,t){if(!(E(e)&&v(e)&&E(t)&&v(t)))throw new Error("Row index must be positive integers");if(2!==this._size.length)throw new Error("Only two dimensional matrix is supported");return M(e,this._size[0]),M(t,this._size[0]),A._swapRows(e,t,this._size[1],this._values,this._index,this._ptr),this},A._forEachRow=function(e,t,r,n,i){var a=n[e],o=n[e+1];for(let e=a;e<o;e++)i(r[e],t[e])},A._swapRows=function(t,r,n,i,a,o){for(let e=0;e<n;e++){const n=o[e],s=o[e+1],u=m(t,n,s,a),c=m(r,n,s,a);if(u<s&&c<s&&a[u]===t&&a[c]===r){if(i){const t=i[u];i[u]=i[c],i[c]=t}}else if(u<s&&a[u]===t&&(s<=c||a[c]!==r)){const t=i?i[u]:void 0;a.splice(c,0,r),i&&i.splice(c,0,t),a.splice(c<=u?u+1:u,1),i&&i.splice(c<=u?u+1:u,1)}else if(c<s&&a[c]===r&&(s<=u||a[u]!==t)){const r=i?i[c]:void 0;a.splice(u,0,t),i&&i.splice(u,0,r),a.splice(u<=c?c+1:c,1),i&&i.splice(u<=c?c+1:c,1)}}},A},{isClass:!0})),pi=s("number",["typed"],e=>{let t=e["typed"];const r=t("number",{"":function(){return 0},number:function(e){return e},string:function(r){if("NaN"===r)return NaN;var n=(e=(n=r).match(/(0[box])([0-9a-fA-F]*)\.([0-9a-fA-F]*)/))?{input:n,radix:{"0b":2,"0o":8,"0x":16}[e[1]],integerPart:e[2],fractionalPart:e[3]}:null;if(n){var i=n,e=parseInt(i.integerPart,i.radix);let t=0;for(let e=0;e<i.fractionalPart.length;e++)t+=parseInt(i.fractionalPart[e],i.radix)/Math.pow(i.radix,e+1);if(e+=t,isNaN(e))throw new SyntaxError('String "'+i.input+'" is not a valid number');return e}{let e=0;n=r.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/);n&&(e=Number(n[2]),r=n[1]);let t=Number(r);if(isNaN(t))throw new SyntaxError('String "'+r+'" is not a valid number');if(n){if(t>2**e-1)throw new SyntaxError(`String "${r}" is out of range`);t>=2**(e-1)&&(t-=2**e)}return t}},BigNumber:function(e){return e.toNumber()},bigint:function(e){return Number(e)},Fraction:function(e){return e.valueOf()},Unit:t.referToSelf(r=>e=>{const t=e.clone();return t.value=r(e.value),t}),null:function(e){return 0},"Unit, string | Unit":function(e,t){return e.toNumber(t)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))});return r.fromJSON=function(e){return parseFloat(e.value)},r}),mi=s("bigint",["typed"],e=>{let t=e["typed"];const r=t("bigint",{"":function(){return 0n},bigint:function(e){return e},number:function(e){return BigInt(e.toFixed())},BigNumber:function(e){return BigInt(e.round().toString())},Fraction:function(e){return BigInt(e.valueOf().toFixed())},"string | boolean":function(e){return BigInt(e)},null:function(e){return 0n},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))});return r.fromJSON=function(e){return BigInt(e.value)},r}),hi=s("string",["typed"],e=>{let t=e["typed"];return t("string",{"":function(){return""},number:Se,null:function(e){return"null"},boolean:function(e){return e+""},string:function(e){return e},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t)),any:function(e){return String(e)}})}),di="boolean",gi=s(di,["typed"],e=>{let t=e["typed"];return t(di,{"":function(){return!1},boolean:function(e){return e},number:function(e){return!!e},null:function(e){return!1},BigNumber:function(e){return!e.isZero()},string:function(e){var t=e.toLowerCase();if("true"===t)return!0;if("false"===t)return!1;t=Number(e);if(""===e||isNaN(t))throw new Error('Cannot convert "'+e+'" to a boolean');return!!t},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),yi=s("bignumber",["typed","BigNumber"],e=>{let{typed:t,BigNumber:a}=e;return t("bignumber",{"":function(){return new a(0)},number:function(e){return new a(e+"")},string:function(e){var t=e.match(/(0[box][0-9a-fA-F]*)i([0-9]*)/);if(t){const r=t[2],n=a(t[1]),i=new a(2).pow(Number(r));if(n.gt(i.sub(1)))throw new SyntaxError(`String "${e}" is out of range`);t=new a(2).pow(Number(r)-1);return n.gte(t)?n.sub(i):n}return new a(e)},BigNumber:function(e){return e},bigint:function(e){return new a(e.toString())},Unit:t.referToSelf(r=>e=>{const t=e.clone();return t.value=r(e.value),t}),Fraction:function(e){return new a(e.n).div(e.d).times(e.s)},null:function(e){return new a(0)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),xi=s("complex",["typed","Complex"],e=>{let{typed:t,Complex:r}=e;return t("complex",{"":function(){return r.ZERO},number:function(e){return new r(e,0)},"number, number":function(e,t){return new r(e,t)},"BigNumber, BigNumber":function(e,t){return new r(e.toNumber(),t.toNumber())},Fraction:function(e){return new r(e.valueOf(),0)},Complex:function(e){return e.clone()},string:function(e){return r(e)},null:function(e){return r(0)},Object:function(e){if("re"in e&&"im"in e)return new r(e.re,e.im);if("r"in e&&"phi"in e||"abs"in e&&"arg"in e)return new r(e);throw new Error("Expected object with properties (re and im) or (r and phi) or (abs and arg)")},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),bi=s("fraction",["typed","Fraction"],e=>{let{typed:t,Fraction:r}=e;return t("fraction",{number:function(e){if(!isFinite(e)||isNaN(e))throw new Error(e+" cannot be represented as a fraction");return new r(e)},string:function(e){return new r(e)},"number, number":function(e,t){return new r(e,t)},null:function(e){return new r(0)},BigNumber:function(e){return new r(e.toString())},bigint:function(e){return new r(e.toString())},Fraction:function(e){return e},Unit:t.referToSelf(r=>e=>{const t=e.clone();return t.value=r(e.value),t}),Object:function(e){return new r(e)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),vi=s("matrix",["typed","Matrix","DenseMatrix","SparseMatrix"],e=>{let{typed:t,DenseMatrix:n,SparseMatrix:i}=e;return t("matrix",{"":function(){return r([])},string:function(e){return r([],e)},"string, string":function(e,t){return r([],e,t)},Array:function(e){return r(e)},Matrix:function(e){return r(e,e.storage())},"Array | Matrix, string":r,"Array | Matrix, string, string":r});function r(e,t,r){if("dense"===t||"default"===t||void 0===t)return new n(e,r);if("sparse"===t)return new i(e,r);throw new TypeError("Unknown matrix type "+JSON.stringify(t)+".")}}),wi="matrixFromFunction",Ni=s(wi,["typed","matrix","isZero"],e=>{let{typed:t,matrix:a,isZero:o}=e;return t(wi,{"Array | Matrix, function, string, string":i,"Array | Matrix, function, string":function(e,t,r){return i(e,t,r)},"Matrix, function":function(e,t){return i(e,t,"dense")},"Array, function":function(e,t){return i(e,t,"dense").toArray()},"Array | Matrix, string, function":function(e,t,r){return i(e,r,t)},"Array | Matrix, string, string, function":function(e,t,r,n){return i(e,n,t,r)}});function i(e,n,t,r){let i;return(i=void 0!==r?a(t,r):a(t)).resize(e),i.forEach(function(e,t){var r=n(t);o(r)||i.set(t,r)}),i}}),Ei="matrixFromRows",Ai=s(Ei,["typed","matrix","flatten","size"],e=>{let{typed:t,matrix:r,flatten:i,size:n}=e;return t(Ei,{"...Array":a,"...Matrix":function(e){return r(a(e.map(e=>e.toArray())))}});function a(e){if(0===e.length)throw new TypeError("At least one row is needed to construct a matrix.");const t=o(e[0]),r=[];for(const n of e){const e=o(n);if(e!==t)throw new TypeError("The vectors had different length: "+(0|t)+" ≠ "+(0|e));r.push(i(n))}return r}function o(e){e=n(e);if(1===e.length)return e[0];if(2!==e.length)throw new TypeError("Only one- or two-dimensional vectors are supported.");if(1===e[0])return e[1];if(1===e[1])return e[0];throw new TypeError("At least one of the arguments is not a vector.")}}),Si="matrixFromColumns",Mi=s(Si,["typed","matrix","flatten","size"],e=>{let{typed:t,matrix:r,flatten:a,size:n}=e;return t(Si,{"...Array":i,"...Matrix":function(e){return r(i(e.map(e=>e.toArray())))}});function i(e){if(0===e.length)throw new TypeError("At least one column is needed to construct a matrix.");const t=o(e[0]),r=[];for(let e=0;e<t;e++)r[e]=[];for(const i of e){const e=o(i);if(e!==t)throw new TypeError("The vectors had different length: "+(0|t)+" ≠ "+(0|e));var n=a(i);for(let e=0;e<t;e++)r[e].push(n[e])}return r}function o(e){e=n(e);if(1===e.length)return e[0];if(2!==e.length)throw new TypeError("Only one- or two-dimensional vectors are supported.");if(1===e[0])return e[1];if(1===e[1])return e[0];throw new TypeError("At least one of the arguments is not a vector.")}}),Ci="splitUnit",Ti=s(Ci,["typed"],e=>{let t=e["typed"];return t(Ci,{"Unit, Array":function(e,t){return e.splitUnit(t)}})}),Di="number",Fi="number, number";function Bi(e){return Math.abs(e)}function Oi(e,t){return e+t}function _i(e,t){return e-t}function zi(e,t){return e*t}function Ii(e){return-e}function ki(e){return e}function qi(e){return a(e)}function Ri(e){return e*e*e}function Pi(e){return Math.exp(e)}function ji(e){return Ee(e)}function Ui(e,t){if(!v(e)||!v(t))throw new Error("Parameters in function lcm must be integer numbers");if(0===e||0===t)return 0;for(var r,n=e*t;0!==t;)t=e%(r=t),e=r;return Math.abs(n/e)}function Li(e){return i(e)}function $i(e){return r(e)}function Hi(e){let t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:2;var r=t<0;if(0===(t=r?-t:t))throw new Error("Root must be non-zero");if(e<0&&Math.abs(t)%2!=1)throw new Error("Root must be odd when a is negative.");if(0===e)return r?1/0:0;if(!isFinite(e))return r?0:e;let n=Math.pow(Math.abs(e),1/t);return n=e<0?-n:n,r?1/n:n}function Gi(e){return n(e)}function Zi(e){return e*e}function Vi(e,t){let r,n,i,a=0,o=1,s=1,u=0;if(!v(e)||!v(t))throw new Error("Parameters in function xgcd must be integer numbers");for(;t;)i=e-(n=Math.floor(e/t))*t,r=a,a=o-n*a,o=r,r=s,s=u-n*s,u=r,e=t,t=i;return e<0?[-e,-o,-u]:[e,e?o:0,u]}function Wi(e,t){return e*e<1&&t===1/0||1<e*e&&t===-1/0?0:Math.pow(e,t)}function Yi(e,t){t=1<arguments.length&&void 0!==t?t:0;if(!v(t)||t<0||15<t)throw new Error("Number of decimals in function round must be an integer from 0 to 15 inclusive");return parseFloat(Te(e,t))}Bi.signature=Di,zi.signature=_i.signature=Oi.signature=Fi,ji.signature=Pi.signature=Ri.signature=qi.signature=ki.signature=Ii.signature=Di,Ui.signature=Fi,Zi.signature=Gi.signature=$i.signature=Li.signature=Di,Wi.signature=Vi.signature=Fi;const Ji="unaryMinus",Xi=s(Ji,["typed"],e=>{let n=e["typed"];return n(Ji,{number:Ii,"Complex | BigNumber | Fraction":e=>e.neg(),bigint:e=>-e,Unit:n.referToSelf(r=>e=>{const t=e.clone();return t.value=n.find(r,t.valueType())(e.value),t}),"Array | Matrix":n.referToSelf(t=>e=>ce(e,t,!0))})}),Qi="unaryPlus",Ki=s(Qi,["typed","config","numeric"],e=>{let{typed:t,config:r,numeric:n}=e;return t(Qi,{number:ki,Complex:function(e){return e},BigNumber:function(e){return e},bigint:function(e){return e},Fraction:function(e){return e},Unit:function(e){return e.clone()},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0)),boolean:function(e){return n(e?1:0,r.number)},string:function(e){return n(e,we(e,r))}})}),ea=s("abs",["typed"],e=>{let t=e["typed"];return t("abs",{number:Bi,"Complex | BigNumber | Fraction | Unit":e=>e.abs(),bigint:e=>e<0n?-e:e,"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0))})}),ta=s("apply",["typed","isInteger"],e=>{let{typed:t,isInteger:i}=e;return t("apply",{"Array | Matrix, number | BigNumber, function":function(e,t,r){if(!i(t))throw new TypeError("Integer number expected for dimension");var n=Array.isArray(e)?T(e):e.size();if(t<0||t>=n.length)throw new mn(t,n.length);return _(e)?e.create(ra(e.valueOf(),t,r)):ra(e,t,r)}})});function ra(e,t,r){let n,i,a;if(t<=0){if(Array.isArray(e[0])){for(a=function(e){const t=e.length,r=e[0].length;let n,i;const a=[];for(i=0;i<r;i++){const r=[];for(n=0;n<t;n++)r.push(e[n][i]);a.push(r)}return a}(e),i=[],n=0;n<a.length;n++)i[n]=ra(a[n],t-1,r);return i}return r(e)}for(i=[],n=0;n<e.length;n++)i[n]=ra(e[n],t-1,r);return i}const na="addScalar",ia=s(na,["typed"],e=>{let i=e["typed"];return i(na,{"number, number":Oi,"Complex, Complex":function(e,t){return e.add(t)},"BigNumber, BigNumber":function(e,t){return e.plus(t)},"bigint, bigint":function(e,t){return e+t},"Fraction, Fraction":function(e,t){return e.add(t)},"Unit, Unit":i.referToSelf(n=>(e,t)=>{if(null===e.value||void 0===e.value)throw new Error("Parameter x contains a unit with undefined value");if(null===t.value||void 0===t.value)throw new Error("Parameter y contains a unit with undefined value");if(!e.equalBase(t))throw new Error("Units do not match");const r=e.clone();return r.value=i.find(n,[r.valueType(),t.valueType()])(r.value,t.value),r.fixPrefix=!1,r})})}),aa="subtractScalar",oa=s(aa,["typed"],e=>{let i=e["typed"];return i(aa,{"number, number":_i,"Complex, Complex":function(e,t){return e.sub(t)},"BigNumber, BigNumber":function(e,t){return e.minus(t)},"bigint, bigint":function(e,t){return e-t},"Fraction, Fraction":function(e,t){return e.sub(t)},"Unit, Unit":i.referToSelf(n=>(e,t)=>{if(null===e.value||void 0===e.value)throw new Error("Parameter x contains a unit with undefined value");if(null===t.value||void 0===t.value)throw new Error("Parameter y contains a unit with undefined value");if(!e.equalBase(t))throw new Error("Units do not match");const r=e.clone();return r.value=i.find(n,[r.valueType(),t.valueType()])(r.value,t.value),r.fixPrefix=!1,r})})}),sa=s("cbrt",["config","typed","isNegative","unaryMinus","matrix","Complex","BigNumber","Fraction"],e=>{let{config:a,typed:t,isNegative:n,unaryMinus:i,matrix:o,Complex:s,BigNumber:u,Fraction:c}=e;return t("cbrt",{number:qi,Complex:l,"Complex, boolean":l,BigNumber:function(e){return e.cbrt()},Unit:function(t){if(t.value&&te(t.value)){let e=t.clone();return e.value=1,(e=e.pow(1/3)).value=l(t.value),e}{var e,r=n(t.value);r&&(t.value=i(t.value)),e=Q(t.value)?new u(1).div(3):I(t.value)?new c(1,3):1/3;const te=t.pow(e);return r&&(te.value=i(te.value)),te}}});function l(e,t){var r=e.arg()/3,n=e.abs(),i=new s(qi(n),0).mul(new s(0,r).exp());if(t){const e=[i,new s(qi(n),0).mul(new s(0,r+2*Math.PI/3).exp()),new s(qi(n),0).mul(new s(0,r-2*Math.PI/3).exp())];return"Array"===a.matrix?e:o(e)}return i}}),x=s("matAlgo11xS0s",["typed","equalScalar"],e=>{let{typed:x,equalScalar:b}=e;return function(i,a,e,o){var s=i._values,u=i._index,c=i._ptr,t=i._size,r=i._datatype;if(!s)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");var n=t[0],l=t[1];let f,p=b,m=0,h=e;"string"==typeof r&&(f=r,p=x.find(b,[f,f]),m=x.convert(0,f),a=x.convert(a,f),h=x.find(e,[f,f]));const d=[],g=[],y=[];for(let n=0;n<l;n++){y[n]=g.length;for(let e=c[n],t=c[n+1],r=e;r<t;r++){const i=u[r],x=o?h(a,s[r]):h(s[r],a);p(x,m)||(g.push(i),d.push(x))}}return y[l]=g.length,i.createSparseMatrix({values:d,index:g,ptr:y,size:[n,l],datatype:f})}}),C=s("matAlgo12xSfs",["typed","DenseMatrix"],e=>{let{typed:d,DenseMatrix:g}=e;return function(i,t,e,r){var a=i._values,o=i._index,s=i._ptr,n=i._size,i=i._datatype;if(!a)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");var u=n[0],c=n[1];let l,f=e;"string"==typeof i&&(l=i,t=d.convert(t,l),f=d.find(e,[l,l]));const p=[],m=[],h=[];for(let n=0;n<c;n++){const d=n+1;for(let e=s[n],t=s[n+1],r=e;r<t;r++){const i=o[r];m[i]=a[r],h[i]=d}for(let e=0;e<u;e++)0===n&&(p[e]=[]),h[e]===d?p[e][n]=r?f(t,m[e]):f(m[e],t):p[e][n]=r?f(t,0):f(0,t)}return new g({data:p,size:[u,c],datatype:l})}}),ua=s("matAlgo14xDs",["typed"],e=>{let c=e["typed"];return function(e,t,r,n){var i=e._data,a=e._size,o=e._datatype;let s,u=r;"string"==typeof o&&(s=o,t=c.convert(t,s),u=c.find(r,[s,s]));o=0<a.length?function t(r,n,i,a,o,s,u){const c=[];if(n===i.length-1)for(let e=0;e<a;e++)c[e]=u?r(s,o[e]):r(o[e],s);else for(let e=0;e<a;e++)c[e]=t(r,n+1,i,i[n+1],o[e],s,u);return c}(u,0,a,a[0],i,t,n):[];return e.createDenseMatrix({data:o,size:ee(a),datatype:s})}}),ca="ceil",la=s(ca,["typed","config","round"],e=>{let{typed:t,config:n,round:i}=e;return t(ca,{number:function(e){return p(e,i(e),n.relTol,n.absTol)?i(e):Math.ceil(e)},"number, number":function(e,t){if(p(e,i(e,t),n.relTol,n.absTol))return i(e,t);var[e,r]=(e+"e").split("e");return[e,r]=(Math.ceil(Number(e+"e"+(Number(r)+t)))+"e").split("e"),Number(e+"e"+(Number(r)-t))}})}),fa=s(ca,["typed","config","round","matrix","equalScalar","zeros","DenseMatrix"],e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:a,zeros:o,DenseMatrix:s}=e;const u=x({typed:t,equalScalar:a}),c=C({typed:t,DenseMatrix:s}),l=ua({typed:t}),f=la({typed:t,config:r,round:n});return t("ceil",{number:f.signatures.number,"number,number":f.signatures["number,number"],Complex:function(e){return e.ceil()},"Complex, number":function(e,t){return e.ceil(t)},"Complex, BigNumber":function(e,t){return e.ceil(t.toNumber())},BigNumber:function(e){return Jn(e,n(e),r.relTol,r.absTol)?n(e):e.ceil()},"BigNumber, BigNumber":function(e,t){return Jn(e,n(e,t),r.relTol,r.absTol)?n(e,t):e.toDecimalPlaces(t.toNumber(),$r.ROUND_CEIL)},Fraction:function(e){return e.ceil()},"Fraction, number":function(e,t){return e.ceil(t)},"Fraction, BigNumber":function(e,t){return e.ceil(t.toNumber())},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0)),"Array, number | BigNumber":t.referToSelf(r=>(e,t)=>ce(e,e=>r(e,t),!0)),"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>u(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>l(e,t,r,!1)),"number | Complex | Fraction | BigNumber, Array":t.referToSelf(r=>(e,t)=>l(i(t),e,r,!0).valueOf()),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf(r=>(e,t)=>a(e,0)?o(t.size(),t.storage()):("dense"===t.storage()?l:c)(t,e,r,!0))})}),pa=s("cube",["typed"],e=>{let t=e["typed"];return t("cube",{number:Ri,Complex:function(e){return e.mul(e).mul(e)},BigNumber:function(e){return e.times(e).times(e)},bigint:function(e){return e*e*e},Fraction:function(e){return e.pow(3)},Unit:function(e){return e.pow(3)}})}),ma=s("exp",["typed"],e=>{let t=e["typed"];return t("exp",{number:Pi,Complex:function(e){return e.exp()},BigNumber:function(e){return e.exp()}})}),ha=s("expm1",["typed","Complex"],e=>{let{typed:t,Complex:r}=e;return t("expm1",{number:ji,Complex:function(e){var t=Math.exp(e.re);return new r(t*Math.cos(e.im)-1,t*Math.sin(e.im))},BigNumber:function(e){return e.exp().minus(1)}})}),da=s("fix",["typed","ceil","floor"],e=>{let{typed:t,ceil:r,floor:n}=e;return t("fix",{number:function(e){return(0<e?n:r)(e)},"number, number":function(e,t){return(0<e?n:r)(e,t)}})}),ga=s("fix",["typed","Complex","matrix","ceil","floor","equalScalar","zeros","DenseMatrix"],e=>{let{typed:t,Complex:r,matrix:n,ceil:i,floor:a,equalScalar:o,zeros:s,DenseMatrix:u}=e;const c=C({typed:t,DenseMatrix:u}),l=ua({typed:t}),f=da({typed:t,ceil:i,floor:a});return t("fix",{number:f.signatures.number,"number, number | BigNumber":f.signatures["number,number"],Complex:function(e){return new r(0<e.re?Math.floor(e.re):Math.ceil(e.re),0<e.im?Math.floor(e.im):Math.ceil(e.im))},"Complex, number":function(e,t){return new r((0<e.re?a:i)(e.re,t),(0<e.im?a:i)(e.im,t))},"Complex, BigNumber":function(e,t){t=t.toNumber();return new r((0<e.re?a:i)(e.re,t),(0<e.im?a:i)(e.im,t))},BigNumber:function(e){return(e.isNegative()?i:a)(e)},"BigNumber, number | BigNumber":function(e,t){return(e.isNegative()?i:a)(e,t)},Fraction:function(e){return e.s<0?e.ceil():e.floor()},"Fraction, number | BigNumber":function(e,t){return(e.s<0?i:a)(e,t)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0)),"Array | Matrix, number | BigNumber":t.referToSelf(r=>(e,t)=>ce(e,e=>r(e,t),!0)),"number | Complex | Fraction | BigNumber, Array":t.referToSelf(r=>(e,t)=>l(n(t),e,r,!0).valueOf()),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf(r=>(e,t)=>o(e,0)?s(t.size(),t.storage()):("dense"===t.storage()?l:c)(t,e,r,!0))})}),ya="floor",xa=s(ya,["typed","config","round"],e=>{let{typed:t,config:n,round:i}=e;return t(ya,{number:function(e){return p(e,i(e),n.relTol,n.absTol)?i(e):Math.floor(e)},"number, number":function(e,t){if(p(e,i(e,t),n.relTol,n.absTol))return i(e,t);var[e,r]=(e+"e").split("e");return[e,r]=(Math.floor(Number(e+"e"+(Number(r)+t)))+"e").split("e"),Number(e+"e"+(Number(r)-t))}})}),ba=s(ya,["typed","config","round","matrix","equalScalar","zeros","DenseMatrix"],e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:a,zeros:o,DenseMatrix:s}=e;const u=x({typed:t,equalScalar:a}),c=C({typed:t,DenseMatrix:s}),l=ua({typed:t}),f=xa({typed:t,config:r,round:n});return t("floor",{number:f.signatures.number,"number,number":f.signatures["number,number"],Complex:function(e){return e.floor()},"Complex, number":function(e,t){return e.floor(t)},"Complex, BigNumber":function(e,t){return e.floor(t.toNumber())},BigNumber:function(e){return Jn(e,n(e),r.relTol,r.absTol)?n(e):e.floor()},"BigNumber, BigNumber":function(e,t){return Jn(e,n(e,t),r.relTol,r.absTol)?n(e,t):e.toDecimalPlaces(t.toNumber(),$r.ROUND_FLOOR)},Fraction:function(e){return e.floor()},"Fraction, number":function(e,t){return e.floor(t)},"Fraction, BigNumber":function(e,t){return e.floor(t.toNumber())},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0)),"Array, number | BigNumber":t.referToSelf(r=>(e,t)=>ce(e,e=>r(e,t),!0)),"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>u(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>l(e,t,r,!1)),"number | Complex | Fraction | BigNumber, Array":t.referToSelf(r=>(e,t)=>l(i(t),e,r,!0).valueOf()),"number | Complex | Fraction | BigNumber, Matrix":t.referToSelf(r=>(e,t)=>a(e,0)?o(t.size(),t.storage()):("dense"===t.storage()?l:c)(t,e,r,!0))})}),va=s("matAlgo02xDS0",["typed","equalScalar"],e=>{let{typed:v,equalScalar:w}=e;return function(e,t,r,i){var a=e._data,n=e._size,o=e._datatype||e.getDataType(),s=t._values,u=t._index,c=t._ptr,l=t._size,f=t._datatype||void 0===t._data?t._datatype:t.getDataType();if(n.length!==l.length)throw new z(n.length,l.length);if(n[0]!==l[0]||n[1]!==l[1])throw new RangeError("Dimension mismatch. Matrix A ("+n+") must match Matrix B ("+l+")");if(!s)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");var l=n[0],p=n[1];let m,h=w,d=0,g=r;"string"==typeof o&&o===f&&"mixed"!==o&&(m=o,h=v.find(w,[m,m]),d=v.convert(0,m),g=v.find(r,[m,m]));const y=[],x=[],b=[];for(let n=0;n<p;n++){b[n]=x.length;for(let e=c[n],t=c[n+1],r=e;r<t;r++){const v=u[r],w=i?g(s[r],a[v][n]):g(a[v][n],s[r]);h(w,d)||(x.push(v),y.push(w))}}return b[p]=x.length,t.createSparseMatrix({values:y,index:x,ptr:b,size:[l,p],datatype:o===e._datatype&&f===t._datatype?m:void 0})}}),wa=s("matAlgo03xDSf",["typed"],e=>{let v=e["typed"];return function(e,i,t,a){var o=e._data,r=e._size,n=e._datatype||e.getDataType(),s=i._values,u=i._index,c=i._ptr,l=i._size,f=i._datatype||void 0===i._data?i._datatype:i.getDataType();if(r.length!==l.length)throw new z(r.length,l.length);if(r[0]!==l[0]||r[1]!==l[1])throw new RangeError("Dimension mismatch. Matrix A ("+r+") must match Matrix B ("+l+")");if(!s)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");var p=r[0],m=r[1];let h,d=0,g=t;"string"==typeof n&&n===f&&"mixed"!==n&&(h=n,d=v.convert(0,h),g=v.find(t,[h,h]));const y=[];for(let e=0;e<p;e++)y[e]=[];const x=[],b=[];for(let n=0;n<m;n++){const v=n+1;for(let e=c[n],t=c[n+1],r=e;r<t;r++){const i=u[r];x[i]=a?g(s[r],o[i][n]):g(o[i][n],s[r]),b[i]=v}for(let e=0;e<p;e++)b[e]===v?y[e][n]=x[e]:y[e][n]=a?g(d,o[e][n]):g(o[e][n],d)}return e.createDenseMatrix({data:y,size:[p,m],datatype:n===e._datatype&&f===i._datatype?h:void 0})}}),Na=s("matAlgo05xSfSf",["typed","equalScalar"],e=>{let{typed:D,equalScalar:F}=e;return function(e,t,r){var n=e._values,i=e._index,a=e._ptr,o=e._size,s=e._datatype||void 0===e._data?e._datatype:e.getDataType(),u=t._values,c=t._index,l=t._ptr,f=t._size,p=t._datatype||void 0===t._data?t._datatype:t.getDataType();if(o.length!==f.length)throw new z(o.length,f.length);if(o[0]!==f[0]||o[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+o+") must match Matrix B ("+f+")");var f=o[0],m=o[1];let h,d=F,g=0,y=r;"string"==typeof s&&s===p&&"mixed"!==s&&(h=s,d=D.find(F,[h,h]),g=D.convert(0,h),y=D.find(r,[h,h]));const x=n&&u?[]:void 0,b=[],v=[],w=x?[]:void 0,N=x?[]:void 0,E=[],A=[];let S,M,C,T;for(M=0;M<m;M++){v[M]=b.length;const e=M+1;for(C=a[M],T=a[M+1];C<T;C++)S=i[C],b.push(S),E[S]=e,w&&(w[S]=n[C]);for(C=l[M],T=l[M+1];C<T;C++)S=c[C],E[S]!==e&&b.push(S),A[S]=e,N&&(N[S]=u[C]);if(x)for(C=v[M];C<b.length;){S=b[C];const D=E[S],F=A[S];if(D===e||F===e){const t=y(D===e?w[S]:g,F===e?N[S]:g);d(t,g)?b.splice(C,1):(x.push(t),C++)}}}return v[m]=b.length,e.createSparseMatrix({values:x,index:b,ptr:v,size:[f,m],datatype:s===e._datatype&&p===t._datatype?h:void 0})}}),Ea=s("matAlgo13xDD",["typed"],e=>{let p=e["typed"];return function(e,t,r){const n=e._data,i=e._size,a=e._datatype,o=t._data,s=t._size,u=t._datatype,c=[];if(i.length!==s.length)throw new z(i.length,s.length);for(let e=0;e<i.length;e++){if(i[e]!==s[e])throw new RangeError("Dimension mismatch. Matrix A ("+i+") must match Matrix B ("+s+")");c[e]=i[e]}let l,f=r;"string"==typeof a&&a===u&&(l=a,f=p.find(r,[l,l]));t=0<c.length?function t(r,n,i,a,o,s){const u=[];if(n===i.length-1)for(let e=0;e<a;e++)u[e]=r(o[e],s[e]);else for(let e=0;e<a;e++)u[e]=t(r,n+1,i,i[n+1],o[e],s[e]);return u}(f,0,c,c[0],n,o):[];return e.createDenseMatrix({data:t,size:c,datatype:l})}});function l(e,t){if(Ue(e.size(),t.size()))return[e,t];const r=On(e.size(),t.size());return[e,t].map(e=>{var t=r;return Ue(e.size(),t)?e:e.create(zn(e.valueOf(),t),e.datatype())})}const B=s("matrixAlgorithmSuite",["typed","matrix"],e=>{let{typed:o,matrix:s}=e;const u=Ea({typed:o}),c=ua({typed:o});return function(n){const r=n.elop,i=n.SD||n.DS;let e;r?(e={"DenseMatrix, DenseMatrix":(e,t)=>u(...l(e,t),r),"Array, Array":(e,t)=>u(...l(s(e),s(t)),r).valueOf(),"Array, DenseMatrix":(e,t)=>u(...l(s(e),t),r),"DenseMatrix, Array":(e,t)=>u(...l(e,s(t)),r)},n.SS&&(e["SparseMatrix, SparseMatrix"]=(e,t)=>n.SS(...l(e,t),r,!1)),n.DS&&(e["DenseMatrix, SparseMatrix"]=(e,t)=>n.DS(...l(e,t),r,!1),e["Array, SparseMatrix"]=(e,t)=>n.DS(...l(s(e),t),r,!1)),i&&(e["SparseMatrix, DenseMatrix"]=(e,t)=>i(...l(t,e),r,!0),e["SparseMatrix, Array"]=(e,t)=>i(...l(s(t),e),r,!0))):(e={"DenseMatrix, DenseMatrix":o.referToSelf(r=>(e,t)=>u(...l(e,t),r)),"Array, Array":o.referToSelf(r=>(e,t)=>u(...l(s(e),s(t)),r).valueOf()),"Array, DenseMatrix":o.referToSelf(r=>(e,t)=>u(...l(s(e),t),r)),"DenseMatrix, Array":o.referToSelf(r=>(e,t)=>u(...l(e,s(t)),r))},n.SS&&(e["SparseMatrix, SparseMatrix"]=o.referToSelf(r=>(e,t)=>n.SS(...l(e,t),r,!1))),n.DS&&(e["DenseMatrix, SparseMatrix"]=o.referToSelf(r=>(e,t)=>n.DS(...l(e,t),r,!1)),e["Array, SparseMatrix"]=o.referToSelf(r=>(e,t)=>n.DS(...l(s(e),t),r,!1))),i&&(e["SparseMatrix, DenseMatrix"]=o.referToSelf(r=>(e,t)=>i(...l(t,e),r,!0)),e["SparseMatrix, Array"]=o.referToSelf(r=>(e,t)=>i(...l(s(t),e),r,!0))));var t=n.scalar||"any";(n.Ds||n.Ss)&&(r?(e["DenseMatrix,"+t]=(e,t)=>c(e,t,r,!1),e[t+", DenseMatrix"]=(e,t)=>c(t,e,r,!0),e["Array,"+t]=(e,t)=>c(s(e),t,r,!1).valueOf(),e[t+", Array"]=(e,t)=>c(s(t),e,r,!0).valueOf()):(e["DenseMatrix,"+t]=o.referToSelf(r=>(e,t)=>c(e,t,r,!1)),e[t+", DenseMatrix"]=o.referToSelf(r=>(e,t)=>c(t,e,r,!0)),e["Array,"+t]=o.referToSelf(r=>(e,t)=>c(s(e),t,r,!1).valueOf()),e[t+", Array"]=o.referToSelf(r=>(e,t)=>c(s(t),e,r,!0).valueOf())));const a=void 0!==n.sS?n.sS:n.Ss;return r?(n.Ss&&(e["SparseMatrix,"+t]=(e,t)=>n.Ss(e,t,r,!1)),a&&(e[t+", SparseMatrix"]=(e,t)=>a(t,e,r,!0))):(n.Ss&&(e["SparseMatrix,"+t]=o.referToSelf(r=>(e,t)=>n.Ss(e,t,r,!1))),a&&(e[t+", SparseMatrix"]=o.referToSelf(r=>(e,t)=>a(t,e,r,!0)))),r&&r.signatures&&je(e,r.signatures),e}}),Aa=s("mod",["typed","config","round","matrix","equalScalar","zeros","DenseMatrix","concat"],e=>{let{typed:t,config:r,round:n,matrix:i,equalScalar:a,zeros:o,DenseMatrix:s,concat:u}=e;const c=ba({typed:t,config:r,round:n,matrix:i,equalScalar:a,zeros:o,DenseMatrix:s}),l=va({typed:t,equalScalar:a}),f=wa({typed:t}),p=Na({typed:t,equalScalar:a}),m=x({typed:t,equalScalar:a}),h=C({typed:t,DenseMatrix:s});return t("mod",{"number, number":function(e,t){return 0===t?e:e-t*c(e/t)},"BigNumber, BigNumber":function(e,t){return t.isZero()?e:e.sub(t.mul(c(e.div(t))))},"bigint, bigint":function(e,t){return 0n===t?e:e<0?0n===(r=e%t)?r:r+t:e%t;var r},"Fraction, Fraction":function(e,t){return t.equals(0)?e:e.sub(t.mul(c(e.div(t))))}},B({typed:t,matrix:i,concat:u})({SS:p,DS:f,SD:l,Ss:m,sS:h}))}),Sa=s("matAlgo01xDSid",["typed"],e=>{let w=e["typed"];return function(n,e,t,i){var a=n._data,r=n._size,o=n._datatype||n.getDataType(),s=e._values,u=e._index,c=e._ptr,l=e._size,f=e._datatype||void 0===e._data?e._datatype:e.getDataType();if(r.length!==l.length)throw new z(r.length,l.length);if(r[0]!==l[0]||r[1]!==l[1])throw new RangeError("Dimension mismatch. Matrix A ("+r+") must match Matrix B ("+l+")");if(!s)throw new Error("Cannot perform operation on Dense Matrix and Pattern Sparse Matrix");const p=r[0],m=r[1],h="string"==typeof o&&"mixed"!==o&&o===f?o:void 0,d=h?w.find(t,[h,h]):t;let g,y;const x=[];for(g=0;g<p;g++)x[g]=[];const b=[],v=[];for(y=0;y<m;y++){const n=y+1;for(let e=c[y],t=c[y+1],r=e;r<t;r++)g=u[r],b[g]=i?d(s[r],a[g][y]):d(a[g][y],s[r]),v[g]=n;for(g=0;g<p;g++)v[g]===n?x[g][y]=b[g]:x[g][y]=a[g][y]}return n.createDenseMatrix({data:x,size:[p,m],datatype:o===n._datatype&&f===e._datatype?h:void 0})}}),Ma=s("matAlgo04xSidSid",["typed","equalScalar"],e=>{let{typed:F,equalScalar:B}=e;return function(e,t,r){var n=e._values,i=e._index,a=e._ptr,o=e._size,s=e._datatype||void 0===e._data?e._datatype:e.getDataType(),u=t._values,c=t._index,l=t._ptr,f=t._size,p=t._datatype||void 0===t._data?t._datatype:t.getDataType();if(o.length!==f.length)throw new z(o.length,f.length);if(o[0]!==f[0]||o[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+o+") must match Matrix B ("+f+")");var f=o[0],m=o[1];let h,d=B,g=0,y=r;"string"==typeof s&&s===p&&"mixed"!==s&&(h=s,d=F.find(B,[h,h]),g=F.convert(0,h),y=F.find(r,[h,h]));const x=n&&u?[]:void 0,b=[],v=[],w=n&&u?[]:void 0,N=n&&u?[]:void 0,E=[],A=[];let S,M,C,T,D;for(M=0;M<m;M++){v[M]=b.length;const e=M+1;for(T=a[M],D=a[M+1],C=T;C<D;C++)S=i[C],b.push(S),E[S]=e,w&&(w[S]=n[C]);for(T=l[M],D=l[M+1],C=T;C<D;C++)if(S=c[C],E[S]===e){if(w){const e=y(w[S],u[C]);d(e,g)?E[S]=null:w[S]=e}}else b.push(S),A[S]=e,N&&(N[S]=u[C]);if(w&&N)for(C=v[M];C<b.length;)S=b[C],E[S]===e?(x[C]=w[S],C++):A[S]===e?(x[C]=N[S],C++):b.splice(C,1)}return v[m]=b.length,e.createSparseMatrix({values:x,index:b,ptr:v,size:[f,m],datatype:s===e._datatype&&p===t._datatype?h:void 0})}}),Ca=s("matAlgo10xSids",["typed","DenseMatrix"],e=>{let{typed:d,DenseMatrix:g}=e;return function(i,t,e,r){var a=i._values,o=i._index,s=i._ptr,n=i._size,i=i._datatype;if(!a)throw new Error("Cannot perform operation on Pattern Sparse Matrix and Scalar value");var u=n[0],c=n[1];let l,f=e;"string"==typeof i&&(l=i,t=d.convert(t,l),f=d.find(e,[l,l]));const p=[],m=[],h=[];for(let n=0;n<c;n++){const d=n+1;for(let e=s[n],t=s[n+1],r=e;r<t;r++){const i=o[r];m[i]=a[r],h[i]=d}for(let e=0;e<u;e++)0===n&&(p[e]=[]),h[e]===d?p[e][n]=r?f(t,m[e]):f(m[e],t):p[e][n]=t}return new g({data:p,size:[u,c],datatype:l})}});function Ta(e,t,r,n){if(!(this instanceof Ta))throw new SyntaxError("Constructor must be called with the new operator");this.fn=e,this.count=t,this.min=r,this.max=n,this.message="Wrong number of arguments in function "+e+" ("+t+" provided, "+r+(null!=n?"-"+n:"")+" expected)",this.stack=(new Error).stack}(Ta.prototype=new Error).constructor=Error,Ta.prototype.name="ArgumentsError",Ta.prototype.isArgumentsError=!0;function Da(e){return!e.some(e=>Array.isArray(e))}const Fa=s("gcd",["typed","config","round","matrix","equalScalar","zeros","BigNumber","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,config:n,round:i,equalScalar:a,zeros:o,BigNumber:s,DenseMatrix:u,concat:c}=e;const l=Aa({typed:t,config:n,round:i,matrix:r,equalScalar:a,zeros:o,DenseMatrix:u,concat:c}),f=Sa({typed:t}),p=Ma({typed:t,equalScalar:a}),m=Ca({typed:t,DenseMatrix:u});return t("gcd",{"number, number":function(e,t){if(!v(e)||!v(t))throw new Error("Parameters in function gcd must be integer numbers");for(var r;0!==t;)r=l(e,t),e=t,t=r;return e<0?-e:e},"BigNumber, BigNumber":function(e,t){if(!e.isInt()||!t.isInt())throw new Error("Parameters in function gcd must be integer numbers");const r=new s(0);for(;!t.isZero();){const r=l(e,t);e=t,t=r}return e.lt(r)?e.neg():e},"Fraction, Fraction":(e,t)=>e.gcd(t)},B({typed:t,matrix:r,concat:c})({SS:p,DS:f,Ss:m}),{"number | BigNumber | Fraction | Matrix | Array, number | BigNumber | Fraction | Matrix | Array, ...number | BigNumber | Fraction | Matrix | Array":t.referToSelf(i=>(e,t,r)=>{let n=i(e,t);for(let e=0;e<r.length;e++)n=i(n,r[e]);return n}),Array:t.referToSelf(t=>e=>{if(1===e.length&&Array.isArray(e[0])&&Da(e[0]))return t(...e[0]);if(Da(e))return t(...e);throw new Ta("gcd() supports only 1d matrices!")}),Matrix:t.referToSelf(t=>e=>t(e.toArray()))})}),Ba=s("matAlgo06xS0S0",["typed","equalScalar"],e=>{let{typed:v,equalScalar:w}=e;return function(e,r,t){var n=e._values,i=e._size,a=e._datatype||void 0===e._data?e._datatype:e.getDataType(),o=r._values,s=r._size,u=r._datatype||void 0===r._data?r._datatype:r.getDataType();if(i.length!==s.length)throw new z(i.length,s.length);if(i[0]!==s[0]||i[1]!==s[1])throw new RangeError("Dimension mismatch. Matrix A ("+i+") must match Matrix B ("+s+")");var s=i[0],c=i[1];let l,f=w,p=0,m=t;"string"==typeof a&&a===u&&"mixed"!==a&&(l=a,f=v.find(w,[l,l]),p=v.convert(0,l),m=v.find(t,[l,l]));const h=n&&o?[]:void 0,d=[],g=[],y=h?[]:void 0,x=[],b=[];for(let t=0;t<c;t++){g[t]=d.length;const w=t+1;if(Gn(e,t,x,y,b,w,d,m),Gn(r,t,x,y,b,w,d,m),y){let e=g[t];for(;e<d.length;){const v=d[e];if(b[v]===w){const w=y[v];f(w,p)?d.splice(e,1):(h.push(w),e++)}else d.splice(e,1)}}else{let e=g[t];for(;e<d.length;)b[d[e]]!==w?d.splice(e,1):e++}}return g[c]=d.length,e.createSparseMatrix({values:h,index:d,ptr:g,size:[s,c],datatype:a===e._datatype&&u===r._datatype?l:void 0})}}),Oa=s("lcm",["typed","matrix","equalScalar","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,concat:i}=e;const a=va({typed:t,equalScalar:n}),o=Ba({typed:t,equalScalar:n}),s=x({typed:t,equalScalar:n}),u=B({typed:t,matrix:r,concat:i}),c="number | BigNumber | Fraction | Matrix | Array",l={};return l[c+`, ${c}, ...`+c]=t.referToSelf(i=>(e,t,r)=>{let n=i(e,t);for(let e=0;e<r.length;e++)n=i(n,r[e]);return n}),t("lcm",{"number, number":Ui,"BigNumber, BigNumber":function(e,t){if(!e.isInt()||!t.isInt())throw new Error("Parameters in function lcm must be integer numbers");if(e.isZero())return e;if(t.isZero())return t;const r=e.times(t);for(;!t.isZero();){const r=t;t=e.mod(r),e=r}return r.div(e).abs()},"Fraction, Fraction":(e,t)=>e.lcm(t)},u({SS:o,DS:a,Ss:s}),l)}),_a=s("log10",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("log10",{number:function(e){return 0<=e||r.predictable?Li(e):new n(e,0).log().div(Math.LN10)},Complex:function(e){return new n(e).log().div(Math.LN10)},BigNumber:function(e){return!e.isNegative()||r.predictable?e.log():new n(e.toNumber(),0).log().div(Math.LN10)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),za=s("log2",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("log2",{number:function(e){return 0<=e||r.predictable?$i(e):i(new n(e,0))},Complex:i,BigNumber:function(e){return!e.isNegative()||r.predictable?e.log(2):i(new n(e.toNumber(),0))},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))});function i(e){var t=Math.sqrt(e.re*e.re+e.im*e.im);return new n(Math.log2?Math.log2(t):Math.log(t)/Math.LN2,Math.atan2(e.im,e.re)/Math.LN2)}}),Ia=s("multiplyScalar",["typed"],e=>{let t=e["typed"];return t("multiplyScalar",{"number, number":zi,"Complex, Complex":function(e,t){return e.mul(t)},"BigNumber, BigNumber":function(e,t){return e.times(t)},"bigint, bigint":function(e,t){return e*t},"Fraction, Fraction":function(e,t){return e.mul(t)},"number | Fraction | BigNumber | Complex, Unit":(e,t)=>t.multiply(e),"Unit, number | Fraction | BigNumber | Complex | Unit":(e,t)=>e.multiply(t)})}),ka="multiply",qa=s(ka,["typed","matrix","addScalar","multiplyScalar","equalScalar","dot"],e=>{let{typed:F,matrix:i,addScalar:B,multiplyScalar:O,equalScalar:N,dot:a}=e;const r=x({typed:F,equalScalar:N}),n=ua({typed:F});function o(e,t){switch(e.length){case 1:switch(t.length){case 1:if(e[0]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Vectors must have the same length");break;case 2:if(e[0]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Vector length ("+e[0]+") must match Matrix rows ("+t[0]+")");break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix B has "+t.length+" dimensions)")}break;case 2:switch(t.length){case 1:if(e[1]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Matrix columns ("+e[1]+") must match Vector length ("+t[0]+")");break;case 2:if(e[1]!==t[0])throw new RangeError("Dimension mismatch in multiplication. Matrix A columns ("+e[1]+") must match Matrix B rows ("+t[0]+")");break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix B has "+t.length+" dimensions)")}break;default:throw new Error("Can only multiply a 1 or 2 dimensional matrix (Matrix A has "+e.length+" dimensions)")}}const s=F("_multiplyMatrixVector",{"DenseMatrix, any":function(e,t){var r=e._data,n=e._size,i=e._datatype||e.getDataType(),a=t._data,o=t._datatype||t.getDataType(),s=n[0],u=n[1];let c,l=B,f=O;i&&o&&i===o&&"string"==typeof i&&"mixed"!==i&&(c=i,l=F.find(B,[c,c]),f=F.find(O,[c,c]));const p=[];for(let e=0;e<s;e++){const F=r[e];let t=f(F[0],a[0]);for(let e=1;e<u;e++)t=l(t,f(F[e],a[e]));p[e]=t}return e.createDenseMatrix({data:p,size:[s],datatype:i===e._datatype&&o===t._datatype?c:void 0})},"SparseMatrix, any":function(i,e){var a=i._values,o=i._index,s=i._ptr,t=i._datatype||void 0===i._data?i._datatype:i.getDataType();if(!a)throw new Error("Cannot multiply Pattern only Matrix times Dense Matrix");const r=e._data,n=e._datatype||e.getDataType(),u=i._size[0],c=e._size[0],l=[],f=[],p=[];let m,h=B,d=O,g=N,y=0;t&&n&&t===n&&"string"==typeof t&&"mixed"!==t&&(m=t,h=F.find(B,[m,m]),d=F.find(O,[m,m]),g=F.find(N,[m,m]),y=F.convert(0,m));const x=[],b=[];for(let n=p[0]=0;n<c;n++){const F=r[n];if(!g(F,y))for(let e=s[n],t=s[n+1],r=e;r<t;r++){const i=o[r];b[i]?x[i]=h(x[i],d(F,a[r])):(b[i]=!0,f.push(i),x[i]=d(F,a[r]))}}for(let e=f.length,t=0;t<e;t++){const i=f[t];l[t]=x[i]}return p[1]=f.length,i.createSparseMatrix({values:l,index:f,ptr:p,size:[u,1],datatype:t===i._datatype&&n===e._datatype?m:void 0})}}),u=F("_multiplyMatrixMatrix",{"DenseMatrix, DenseMatrix":function(e,t){var r=e._data,n=e._size,i=e._datatype||e.getDataType(),a=t._data,o=t._size,s=t._datatype||t.getDataType(),u=n[0],c=n[1],l=o[1];let f,p=B,m=O;i&&s&&i===s&&"string"==typeof i&&"mixed"!==i&&"mixed"!==i&&(f=i,p=F.find(B,[f,f]),m=F.find(O,[f,f]));const h=[];for(let e=0;e<u;e++){const F=r[e];h[e]=[];for(let r=0;r<l;r++){let t=m(F[0],a[0][r]);for(let e=1;e<c;e++)t=p(t,m(F[e],a[e][r]));h[e][r]=t}}return e.createDenseMatrix({data:h,size:[u,l],datatype:i===e._datatype&&s===t._datatype?f:void 0})},"DenseMatrix, SparseMatrix":function(e,i){var a=e._data,t=e._size,r=e._datatype||e.getDataType(),o=i._values,s=i._index,n=i._ptr,u=i._size,c=i._datatype||void 0===i._data?i._datatype:i.getDataType();if(!o)throw new Error("Cannot multiply Dense Matrix times Pattern only Matrix");var l=t[0],f=u[1];let p,m=B,h=O,d=N,g=0;r&&c&&r===c&&"string"==typeof r&&"mixed"!==r&&(p=r,m=F.find(B,[p,p]),h=F.find(O,[p,p]),d=F.find(N,[p,p]),g=F.convert(0,p));const y=[],x=[],b=[],v=i.createSparseMatrix({values:y,index:x,ptr:b,size:[l,f],datatype:r===e._datatype&&c===i._datatype?p:void 0});for(let e=0;e<f;e++){b[e]=x.length;const F=n[e],i=n[e+1];if(i>F){let n=0;for(let r=0;r<l;r++){const O=r+1;let t;for(let e=F;e<i;e++){const F=s[e];n!==O?(t=h(a[r][F],o[e]),n=O):t=m(t,h(a[r][F],o[e]))}n!==O||d(t,g)||(x.push(r),y.push(t))}}}return b[f]=x.length,v},"SparseMatrix, DenseMatrix":function(a,e){var o=a._values,s=a._index,u=a._ptr,t=a._datatype||void 0===a._data?a._datatype:a.getDataType();if(!o)throw new Error("Cannot multiply Pattern only Matrix times Dense Matrix");var r=e._data,n=e._datatype||e.getDataType(),i=a._size[0],c=e._size[0],l=e._size[1];let f,p=B,m=O,h=N,d=0;t&&n&&t===n&&"string"==typeof t&&"mixed"!==t&&(f=t,p=F.find(B,[f,f]),m=F.find(O,[f,f]),h=F.find(N,[f,f]),d=F.convert(0,f));const g=[],y=[],x=[],b=a.createSparseMatrix({values:g,index:y,ptr:x,size:[i,l],datatype:t===a._datatype&&n===e._datatype?f:void 0}),v=[],w=[];for(let i=0;i<l;i++){x[i]=y.length;const F=i+1;for(let n=0;n<c;n++){const B=r[n][i];if(!h(B,d))for(let e=u[n],t=u[n+1],r=e;r<t;r++){const a=s[r];w[a]!==F?(w[a]=F,y.push(a),v[a]=m(B,o[r])):v[a]=p(v[a],m(B,o[r]))}}for(let e=x[i],t=y.length,r=e;r<t;r++){const a=y[r];g[r]=v[a]}}return x[l]=y.length,b},"SparseMatrix, SparseMatrix":function(i,e){var t=i._values,r=i._index,a=i._ptr,n=i._datatype||void 0===i._data?i._datatype:i.getDataType(),o=e._values,s=e._index,u=e._ptr,c=e._datatype||void 0===e._data?e._datatype:e.getDataType(),l=i._size[0],f=e._size[1],p=t&&o;let m,h=B,d=O;n&&c&&n===c&&"string"==typeof n&&"mixed"!==n&&(m=n,h=F.find(B,[m,m]),d=F.find(O,[m,m]));const g=p?[]:void 0,y=[],x=[],b=i.createSparseMatrix({values:g,index:y,ptr:x,size:[l,f],datatype:n===i._datatype&&c===e._datatype?m:void 0}),v=p?[]:void 0,w=[];let N,E,A,S,M,C,T,D;for(let n=0;n<f;n++){x[n]=y.length;const F=n+1;for(M=u[n],C=u[n+1],S=M;S<C;S++)if(D=s[S],p)for(E=a[D],A=a[D+1],N=E;N<A;N++)T=r[N],w[T]!==F?(w[T]=F,y.push(T),v[T]=d(o[S],t[N])):v[T]=h(v[T],d(o[S],t[N]));else for(E=a[D],A=a[D+1],N=E;N<A;N++)T=r[N],w[T]!==F&&(w[T]=F,y.push(T));if(p)for(let e=x[n],t=y.length,r=e;r<t;r++){const i=y[r];g[r]=v[i]}}return x[f]=y.length,b}});return F(ka,O,{"Array, Array":F.referTo("Matrix, Matrix",n=>(e,t)=>{o(T(e),T(t));const r=n(i(e),i(t));return _(r)?r.valueOf():r}),"Matrix, Matrix":function(e,t){var r=e.size(),n=t.size();return o(r,n),(1===r.length?1===n.length?function(e,t){if(0===r[0])throw new Error("Cannot multiply two empty vectors");return a(e,t)}:function(t,r){if("dense"!==r.storage())throw new Error("Support for SparseMatrix not implemented");{var a=t._data,o=t._size,s=t._datatype||t.getDataType(),u=r._data,c=r._size,l=r._datatype||r.getDataType(),f=o[0],p=c[1];let e,n=B,i=O;s&&l&&s===l&&"string"==typeof s&&"mixed"!==s&&(e=s,n=F.find(B,[e,e]),i=F.find(O,[e,e]));const m=[];for(let r=0;r<p;r++){let t=i(a[0],u[0][r]);for(let e=1;e<f;e++)t=n(t,i(a[e],u[e][r]));m[r]=t}return t.createDenseMatrix({data:m,size:[p],datatype:s===t._datatype&&l===r._datatype?e:void 0})}}:1===n.length?s:u)(e,t)},"Matrix, Array":F.referTo("Matrix,Matrix",r=>(e,t)=>r(e,i(t))),"Array, Matrix":F.referToSelf(r=>(e,t)=>r(i(e,t.storage()),t)),"SparseMatrix, any":function(e,t){return r(e,t,O,!1)},"DenseMatrix, any":function(e,t){return n(e,t,O,!1)},"any, SparseMatrix":function(e,t){return r(t,e,O,!0)},"any, DenseMatrix":function(e,t){return n(t,e,O,!0)},"Array, any":function(e,t){return n(i(e),t,O,!1).valueOf()},"any, Array":function(e,t){return n(i(t),e,O,!0).valueOf()},"any, any":O,"any, any, ...any":F.referToSelf(i=>(e,t,r)=>{let n=i(e,t);for(let e=0;e<r.length;e++)n=i(n,r[e]);return n})})}),Ra="nthRoot",Pa=s(Ra,["typed","matrix","equalScalar","BigNumber","concat"],e=>{let{typed:t,matrix:n,equalScalar:r,BigNumber:u,concat:i}=e;const a=Sa({typed:t}),o=va({typed:t,equalScalar:r}),s=Ba({typed:t,equalScalar:r}),c=x({typed:t,equalScalar:r}),l=B({typed:t,matrix:n,concat:i});function f(){throw new Error("Complex number not supported in function nthRoot. Use nthRoots instead.")}return t(Ra,{number:Hi,"number, number":Hi,BigNumber:e=>p(e,new u(2)),"BigNumber, BigNumber":p,Complex:f,"Complex, number":f,Array:t.referTo("DenseMatrix,number",t=>e=>t(n(e),2).valueOf()),DenseMatrix:t.referTo("DenseMatrix,number",t=>e=>t(e,2)),SparseMatrix:t.referTo("SparseMatrix,number",t=>e=>t(e,2)),"SparseMatrix, SparseMatrix":t.referToSelf(r=>(e,t)=>{if(1===t.density())return s(e,t,r);throw new Error("Root must be non-zero")}),"DenseMatrix, SparseMatrix":t.referToSelf(r=>(e,t)=>{if(1===t.density())return a(e,t,r,!1);throw new Error("Root must be non-zero")}),"Array, SparseMatrix":t.referTo("DenseMatrix,SparseMatrix",r=>(e,t)=>r(n(e),t)),"number | BigNumber, SparseMatrix":t.referToSelf(r=>(e,t)=>{if(1===t.density())return c(t,e,r,!0);throw new Error("Root must be non-zero")})},l({scalar:"number | BigNumber",SD:o,Ss:c,sS:!1}));function p(e,t){const r=u.precision,n=u.clone({precision:r+2}),i=new u(0),a=new n(1),o=t.isNegative();if((t=o?t.neg():t).isZero())throw new Error("Root must be non-zero");if(e.isNegative()&&!t.abs().mod(2).equals(1))throw new Error("Root must be odd when a is negative.");if(e.isZero())return o?new n(1/0):0;if(!e.isFinite())return o?i:e;let s=e.abs().pow(a.div(t));return s=e.isNeg()?s.neg():s,new u((o?a.div(s):s).toPrecision(r))}}),ja=s("sign",["typed","BigNumber","Fraction","complex"],e=>{let{typed:r,BigNumber:t,complex:n,Fraction:i}=e;return r("sign",{number:Gi,Complex:function(e){return 0===e.im?n(Gi(e.re)):e.sign()},BigNumber:function(e){return new t(e.cmp(0))},bigint:function(e){return 0n<e?1n:e<0n?-1n:0n},Fraction:function(e){return new i(e.s,1)},"Array | Matrix":r.referToSelf(t=>e=>ce(e,t,!0)),Unit:r.referToSelf(t=>e=>{if(e._isDerived()||0===e.units[0].unit.offset)return r.find(t,e.valueType())(e.value);throw new TypeError("sign is ambiguous for units with offset")})})}),Ua=s("sqrt",["config","typed","Complex"],e=>{let{config:t,typed:r,Complex:n}=e;return r("sqrt",{number:i,Complex:function(e){return e.sqrt()},BigNumber:function(e){return!e.isNegative()||t.predictable?e.sqrt():i(e.toNumber())},Unit:function(e){return e.pow(.5)}});function i(e){return isNaN(e)?NaN:0<=e||t.predictable?Math.sqrt(e):new n(e,0).sqrt()}}),La=s("square",["typed"],e=>{let t=e["typed"];return t("square",{number:Zi,Complex:function(e){return e.mul(e)},BigNumber:function(e){return e.times(e)},bigint:function(e){return e*e},Fraction:function(e){return e.mul(e)},Unit:function(e){return e.pow(2)}})}),$a="subtract",Ha=s($a,["typed","matrix","equalScalar","subtractScalar","unaryMinus","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,subtractScalar:i,DenseMatrix:a,concat:o}=e;const s=Sa({typed:t}),u=wa({typed:t}),c=Na({typed:t,equalScalar:n}),l=Ca({typed:t,DenseMatrix:a}),f=C({typed:t,DenseMatrix:a}),p=B({typed:t,matrix:r,concat:o});return t($a,{"any, any":i},p({elop:i,SS:c,DS:s,SD:u,Ss:f,sS:l}))}),Ga=s("xgcd",["typed","config","matrix","BigNumber"],e=>{let{typed:t,config:p,matrix:m,BigNumber:h}=e;return t("xgcd",{"number, number":function(e,t){e=Vi(e,t);return"Array"===p.matrix?e:m(e)},"BigNumber, BigNumber":function(e,t){let r,n,i;var a=new h(0),o=new h(1);let s,u=a,c=o,l=o,f=a;if(!e.isInt()||!t.isInt())throw new Error("Parameters in function xgcd must be integer numbers");for(;!t.isZero();)n=e.div(t).floor(),i=e.mod(t),r=u,u=c.minus(n.times(u)),c=r,r=l,l=f.minus(n.times(l)),f=r,e=t,t=i;return s=e.lt(a)?[e.neg(),c.neg(),f.neg()]:[e,e.isZero()?0:c,f],"Array"===p.matrix?s:m(s)}})}),Za=s("invmod",["typed","config","BigNumber","xgcd","equal","smaller","mod","add","isInteger"],e=>{let{typed:t,BigNumber:a,xgcd:o,equal:s,smaller:u,mod:c,add:l,isInteger:f}=e;return t("invmod",{"number, number":r,"BigNumber, BigNumber":r});function r(e,t){if(!f(e)||!f(t))throw new Error("Parameters in function invmod must be integer numbers");if(e=c(e,t),s(t,0))throw new Error("Divisor must be non zero");let r=o(e,t),[n,i]=r=r.valueOf();return s(n,a(1))?(i=c(i,t),i=u(i,a(0))?l(i,t):i):NaN}}),Va=s("matAlgo09xS0Sf",["typed","equalScalar"],e=>{let{typed:T,equalScalar:D}=e;return function(e,t,r){var n=e._values,i=e._index,a=e._ptr,o=e._size,s=e._datatype||void 0===e._data?e._datatype:e.getDataType(),u=t._values,c=t._index,l=t._ptr,f=t._size,p=t._datatype||void 0===t._data?t._datatype:t.getDataType();if(o.length!==f.length)throw new z(o.length,f.length);if(o[0]!==f[0]||o[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+o+") must match Matrix B ("+f+")");var f=o[0],m=o[1];let h,d=D,g=0,y=r;"string"==typeof s&&s===p&&"mixed"!==s&&(h=s,d=T.find(D,[h,h]),g=T.convert(0,h),y=T.find(r,[h,h]));const x=n&&u?[]:void 0,b=[],v=[],w=x?[]:void 0,N=[];let E,A,S,M,C;for(A=0;A<m;A++){v[A]=b.length;const e=A+1;if(w)for(M=l[A],C=l[A+1],S=M;S<C;S++)E=c[S],N[E]=e,w[E]=u[S];for(M=a[A],C=a[A+1],S=M;S<C;S++)if(E=i[S],w){const T=N[E]===e?w[E]:g,D=y(n[S],T);d(D,g)||(b.push(E),x.push(D))}else b.push(E)}return v[m]=b.length,e.createSparseMatrix({values:x,index:b,ptr:v,size:[f,m],datatype:s===e._datatype&&p===t._datatype?h:void 0})}}),Wa="dotMultiply",Ya=s(Wa,["typed","matrix","equalScalar","multiplyScalar","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,multiplyScalar:i,concat:a}=e;const o=va({typed:t,equalScalar:n}),s=Va({typed:t,equalScalar:n}),u=x({typed:t,equalScalar:n}),c=B({typed:t,matrix:r,concat:a});return t(Wa,c({elop:i,SS:s,DS:o,Ss:u}))});function Ja(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitAnd");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);if(e.isZero()||t.eq(-1)||e.eq(t))return e;if(t.isZero()||e.eq(-1))return t;if(!e.isFinite()||!t.isFinite()){if(!e.isFinite()&&!t.isFinite())return e.isNegative()===t.isNegative()?e:new r(0);if(!e.isFinite())return t.isNegative()?e:e.isNegative()?new r(0):t;if(!t.isFinite())return e.isNegative()?t:t.isNegative()?new r(0):e}return Ka(e,t,function(e,t){return e&t})}function Xa(e){if(e.isFinite()&&!e.isInteger())throw new Error("Integer expected in function bitNot");const t=e.constructor,r=t.precision,n=(t.config({precision:1e9}),e.plus(new t(1)));return n.s=-n.s||null,t.config({precision:r}),n}function Qa(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitOr");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);var n=new r(-1);return e.isZero()||t.eq(n)||e.eq(t)?t:t.isZero()||e.eq(n)?e:e.isFinite()&&t.isFinite()?Ka(e,t,function(e,t){return e|t}):!e.isFinite()&&!e.isNegative()&&t.isNegative()||e.isNegative()&&!t.isNegative()&&!t.isFinite()?n:e.isNegative()&&t.isNegative()?e.isFinite()?e:t:e.isFinite()?t:e}function Ka(e,t,r){const n=e.constructor;let i,a;var o=+(e.s<0),s=+(t.s<0);if(o){i=eo(Xa(e));for(let e=0;e<i.length;++e)i[e]^=1}else i=eo(e);if(s){a=eo(Xa(t));for(let e=0;e<a.length;++e)a[e]^=1}else a=eo(t);let u,c,l,f=(l=i.length<=a.length?(u=i,c=a,o):(u=a,c=i,s),u.length),p=c.length;var m=1^r(o,s);let h=new n(1^m),d=new n(1);var g=new n(2),e=n.precision;for(n.config({precision:1e9});0<f;)r(u[--f],c[--p])===m&&(h=h.plus(d)),d=d.times(g);for(;0<p;)r(l,c[--p])===m&&(h=h.plus(d)),d=d.times(g);return n.config({precision:e}),0==m&&(h.s=-h.s),h}function eo(e){var r=e.d;let n=r[0]+"";for(let e=1;e<r.length;++e){let t=r[e]+"";for(let e=7-t.length;e--;)t="0"+t;n+=t}let t=n.length;for(;"0"===n.charAt(t);)t--;let i=e.e,a=n.slice(0,t+1||1);e=a.length;if(0<i)if(++i>e)for(i-=e;i--;)a+="0";else i<e&&(a=a.slice(0,i)+"."+a.slice(i));const o=[0];for(let t=0;t<a.length;){let e=o.length;for(;e--;)o[e]*=10;o[0]+=parseInt(a.charAt(t++));for(let e=0;e<o.length;++e)1<o[e]&&(null!==o[e+1]&&void 0!==o[e+1]||(o[e+1]=0),o[e+1]+=o[e]>>1,o[e]&=1)}return o.reverse()}function to(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function bitXor");const r=e.constructor;if(e.isNaN()||t.isNaN())return new r(NaN);if(e.isZero())return t;if(t.isZero())return e;if(e.eq(t))return new r(0);var n=new r(-1);return e.eq(n)?Xa(t):t.eq(n)?Xa(e):e.isFinite()&&t.isFinite()?Ka(e,t,function(e,t){return e^t}):e.isFinite()||t.isFinite()?new r(e.isNegative()===t.isNegative()?1/0:-1/0):n}function ro(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function leftShift");const r=e.constructor;return e.isNaN()||t.isNaN()||t.isNegative()&&!t.isZero()?new r(NaN):e.isZero()||t.isZero()?e:e.isFinite()||t.isFinite()?t.lt(55)?e.times(Math.pow(2,t.toNumber())+""):e.times(new r(2).pow(t)):new r(NaN)}function no(e,t){if(e.isFinite()&&!e.isInteger()||t.isFinite()&&!t.isInteger())throw new Error("Integers expected in function rightArithShift");const r=e.constructor;return e.isNaN()||t.isNaN()||t.isNegative()&&!t.isZero()?new r(NaN):e.isZero()||t.isZero()?e:t.isFinite()?(t.lt(55)?e.div(Math.pow(2,t.toNumber())+""):e.div(new r(2).pow(t))).floor():e.isNegative()?new r(-1):e.isFinite()?new r(0):new r(NaN)}var io="number, number";function ao(e,t){if(v(e)&&v(t))return e&t;throw new Error("Integers expected in function bitAnd")}function oo(e){if(v(e))return~e;throw new Error("Integer expected in function bitNot")}function so(e,t){if(v(e)&&v(t))return e|t;throw new Error("Integers expected in function bitOr")}function uo(e,t){if(v(e)&&v(t))return e^t;throw new Error("Integers expected in function bitXor")}function co(e,t){if(v(e)&&v(t))return e<<t;throw new Error("Integers expected in function leftShift")}function lo(e,t){if(v(e)&&v(t))return e>>t;throw new Error("Integers expected in function rightArithShift")}function fo(e,t){if(v(e)&&v(t))return e>>>t;throw new Error("Integers expected in function rightLogShift")}ao.signature=io,oo.signature="number",fo.signature=lo.signature=co.signature=uo.signature=so.signature=io;const po=s("bitAnd",["typed","matrix","equalScalar","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,concat:i}=e;const a=va({typed:t,equalScalar:n}),o=Ba({typed:t,equalScalar:n}),s=x({typed:t,equalScalar:n}),u=B({typed:t,matrix:r,concat:i});return t("bitAnd",{"number, number":ao,"BigNumber, BigNumber":Ja,"bigint, bigint":(e,t)=>e&t},u({SS:o,DS:a,Ss:s}))}),mo=s("bitNot",["typed"],e=>{let t=e["typed"];return t("bitNot",{number:oo,BigNumber:Xa,bigint:e=>~e,"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),ho=s("bitOr",["typed","matrix","equalScalar","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:a}=e;const o=Sa({typed:t}),s=Ma({typed:t,equalScalar:n}),u=Ca({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:r,concat:a});return t("bitOr",{"number, number":so,"BigNumber, BigNumber":Qa,"bigint, bigint":(e,t)=>e|t},c({SS:s,DS:o,Ss:u}))}),go=s("matAlgo07xSSf",["typed","DenseMatrix"],e=>{let{typed:b,DenseMatrix:v}=e;return function(e,t,r){var n=e._size,i=e._datatype||void 0===e._data?e._datatype:e.getDataType(),a=t._size,o=t._datatype||void 0===t._data?t._datatype:t.getDataType();if(n.length!==a.length)throw new z(n.length,a.length);if(n[0]!==a[0]||n[1]!==a[1])throw new RangeError("Dimension mismatch. Matrix A ("+n+") must match Matrix B ("+a+")");var s=n[0],u=n[1];let c,l,f,p=0,m=r;"string"==typeof i&&i===o&&"mixed"!==i&&(c=i,p=b.convert(0,c),m=b.find(r,[c,c]));const h=[];for(l=0;l<s;l++)h[l]=[];var d=[],g=[],y=[],x=[];for(f=0;f<u;f++){const b=f+1;for(w(e,f,y,d,b),w(t,f,x,g,b),l=0;l<s;l++){const e=y[l]===b?d[l]:p,v=x[l]===b?g[l]:p;h[l][f]=m(e,v)}}return new v({data:h,size:[s,u],datatype:i===e._datatype&&o===t._datatype?c:void 0})};function w(r,n,i,a,o){var s=r._values,u=r._index,r=r._ptr;for(let e=r[n],t=r[n+1];e<t;e++){const n=u[e];i[n]=o,a[n]=s[e]}}}),yo=s("bitXor",["typed","matrix","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,DenseMatrix:n,concat:i}=e;const a=wa({typed:t}),o=go({typed:t,DenseMatrix:n}),s=C({typed:t,DenseMatrix:n}),u=B({typed:t,matrix:r,concat:i});return t("bitXor",{"number, number":uo,"BigNumber, BigNumber":to,"bigint, bigint":(e,t)=>e^t},u({SS:o,DS:a,Ss:s}))}),xo=s("arg",["typed"],e=>{let t=e["typed"];return t("arg",{number:function(e){return Math.atan2(0,e)},BigNumber:function(e){return e.constructor.atan2(0,e)},Complex:function(e){return e.arg()},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),bo=s("conj",["typed"],e=>{let t=e["typed"];return t("conj",{"number | BigNumber | Fraction":e=>e,Complex:e=>e.conjugate(),"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),vo=s("im",["typed"],e=>{let t=e["typed"];return t("im",{number:()=>0,"BigNumber | Fraction":e=>e.mul(0),Complex:e=>e.im,"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),wo=s("re",["typed"],e=>{let t=e["typed"];return t("re",{"number | BigNumber | Fraction":e=>e,Complex:e=>e.re,"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),No="number, number";function Eo(e){return!e}function Ao(e,t){return!(!e&&!t)}function So(e,t){return!!e!=!!t}function Mo(e,t){return!(!e||!t)}Eo.signature="number",Mo.signature=So.signature=Ao.signature=No;const Co=s("not",["typed"],e=>{let r=e["typed"];return r("not",{"null | undefined":()=>!0,number:Eo,Complex:function(e){return 0===e.re&&0===e.im},BigNumber:function(e){return e.isZero()||e.isNaN()},bigint:e=>!e,Unit:r.referToSelf(t=>e=>r.find(t,e.valueType())(e.value)),"Array | Matrix":r.referToSelf(t=>e=>ce(e,t))})}),To=s("or",["typed","matrix","equalScalar","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=Na({typed:t,equalScalar:n}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:r,concat:a});return t("or",{"number, number":Ao,"Complex, Complex":function(e,t){return 0!==e.re||0!==e.im||0!==t.re||0!==t.im},"BigNumber, BigNumber":function(e,t){return!e.isZero()&&!e.isNaN()||!t.isZero()&&!t.isNaN()},"bigint, bigint":Ao,"Unit, Unit":t.referToSelf(r=>(e,t)=>r(e.value||0,t.value||0))},c({SS:s,DS:o,Ss:u}))}),Do=s("xor",["typed","matrix","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,DenseMatrix:n,concat:i}=e;const a=wa({typed:t}),o=go({typed:t,DenseMatrix:n}),s=C({typed:t,DenseMatrix:n}),u=B({typed:t,matrix:r,concat:i});return t("xor",{"number, number":So,"Complex, Complex":function(e,t){return(0!==e.re||0!==e.im)!=(0!==t.re||0!==t.im)},"bigint, bigint":So,"BigNumber, BigNumber":function(e,t){return(!e.isZero()&&!e.isNaN())!=(!t.isZero()&&!t.isNaN())},"Unit, Unit":t.referToSelf(r=>(e,t)=>r(e.value||0,t.value||0))},u({SS:o,DS:a,Ss:s}))}),Fo=s("concat",["typed","matrix","isInteger"],e=>{let{typed:t,matrix:u,isInteger:c}=e;return t("concat",{"...Array | Matrix | number | BigNumber":function(e){let t;var r=e.length;let n,i=-1,a=!1;const o=[];for(t=0;t<r;t++){const u=e[t];if(_(u)&&(a=!0),E(u)||Q(u)){if(t!==r-1)throw new Error("Dimension must be specified as last argument");if(n=i,i=u.valueOf(),!c(i))throw new TypeError("Integer number expected for dimension");if(i<0||0<t&&i>n)throw new mn(i,n+1)}else{const e=ee(u).valueOf(),E=T(e);if(o[t]=e,n=i,i=E.length-1,0<t&&i!==n)throw new z(n+1,i+1)}}if(0===o.length)throw new SyntaxError("At least one matrix expected");let s=o.shift();for(;o.length;)s=Bn(s,o.shift(),i);return a?u(s):s},"...string":function(e){return e.join("")}})}),Bo=s("column",["typed","Index","matrix","range"],e=>{let{typed:t,Index:n,matrix:i,range:a}=e;return t("column",{"Matrix, number":r,"Array, number":function(e,t){return r(i(ee(e)),t).valueOf()}});function r(e,t){if(2!==e.size().length)throw new Error("Only two dimensional matrix is supported");M(t,e.size()[1]);var r=a(0,e.size()[0]),r=new n(r,t),t=e.subset(r);return _(t)?t:i([[t]])}}),Oo=s("count",["typed","size","prod"],e=>{let{typed:t,size:r,prod:n}=e;return t("count",{string:function(e){return e.length},"Matrix | Array":function(e){return n(r(e))}})}),_o=s("cross",["typed","matrix","subtract","multiply"],e=>{let{typed:t,matrix:r,subtract:a,multiply:o}=e;return t("cross",{"Matrix, Matrix":function(e,t){return r(n(e.toArray(),t.toArray()))},"Matrix, Array":function(e,t){return r(n(e.toArray(),t))},"Array, Matrix":function(e,t){return r(n(e,t.toArray()))},"Array, Array":n});function n(e,t){var r=Math.max(T(e).length,T(t).length);e=wn(e),t=wn(t);const n=T(e),i=T(t);if(1!==n.length||1!==i.length||3!==n[0]||3!==i[0])throw new RangeError("Vectors with length 3 expected (Size A = ["+n.join(", ")+"], B = ["+i.join(", ")+"])");e=[a(o(e[1],t[2]),o(e[2],t[1])),a(o(e[2],t[0]),o(e[0],t[2])),a(o(e[0],t[1]),o(e[1],t[0]))];return 1<r?[e]:e}}),zo=s("diag",["typed","matrix","DenseMatrix","SparseMatrix"],e=>{let{typed:t,matrix:y,DenseMatrix:x,SparseMatrix:b}=e;return t("diag",{Array:function(e){return n(e,0,T(e),null)},"Array, number":function(e,t){return n(e,t,T(e),null)},"Array, BigNumber":function(e,t){return n(e,t.toNumber(),T(e),null)},"Array, string":function(e,t){return n(e,0,T(e),t)},"Array, number, string":function(e,t,r){return n(e,t,T(e),r)},"Array, BigNumber, string":function(e,t,r){return n(e,t.toNumber(),T(e),r)},Matrix:function(e){return n(e,0,e.size(),e.storage())},"Matrix, number":function(e,t){return n(e,t,e.size(),e.storage())},"Matrix, BigNumber":function(e,t){return n(e,t.toNumber(),e.size(),e.storage())},"Matrix, string":function(e,t){return n(e,0,e.size(),t)},"Matrix, number, string":function(e,t,r){return n(e,t,e.size(),r)},"Matrix, BigNumber, string":function(e,t,r){return n(e,t.toNumber(),e.size(),r)}});function n(e,t,r,n){if(!v(t))throw new TypeError("Second parameter in function diag must be an integer");var i=0<t?t:0,a=t<0?-t:0;switch(r.length){case 1:{var o=e;var s=t;var u=n;var c=r[0];c=[c+a,c+i];if(u&&"sparse"!==u&&"dense"!==u)throw new TypeError(`Unknown matrix type ${u}"`);const h=("sparse"===u?b:x).diagonal(c,o,s);return null!==u?h:h.valueOf();return}case 2:{var l=e;c=n;var f=r;var p=a;var m=i;if(_(l)){const f=l.diagonal(t);return null!==c?c!==f.storage()?y(f,c):f:f.valueOf()}const d=Math.min(f[0]-p,f[1]-m),g=[];for(let e=0;e<d;e++)g[e]=l[e+p][e+m];return null!==c?y(g):g;return}}throw new RangeError("Matrix for function diag must be 2 dimensional")}});function Io(n,i,a,o,s){if(ve.isTypedFunction(n)){const s=[i,a,o],u=ve.resolve(n,s);if(u)return r(u.implementation,s);var e=[i,a],t=ve.resolve(n,e);if(t)return r(t.implementation,e);t=[i],e=ve.resolve(n,t);return e?r(e.implementation,t):r(n,s)}return n(i,a,o);function r(e,t){try{return e.apply(e,t)}catch(e){var r;if(e instanceof TypeError&&"wrongType"===(null==(r=e.data)?void 0:r.category)){const e=[];throw e.push("value: "+K(i)),2<=t.length&&e.push("index: "+K(a)),3<=t.length&&e.push("array: "+K(o)),new TypeError(`Function ${s} cannot apply callback arguments ${n.name}(${e.join(", ")}) at index `+JSON.stringify(a))}throw new TypeError(`Function ${s} cannot apply callback arguments to function ${n.name}: `+e.message)}}}const ko=s("filter",["typed"],e=>{let t=e["typed"];return t("filter",{"Array, function":qo,"Matrix, function":function(e,t){return e.create(qo(e.toArray(),t))},"Array, RegExp":Mn,"Matrix, RegExp":function(e,t){return e.create(Mn(e.toArray(),t))}})});function qo(e,n){return Sn(e,function(e,t,r){return Io(n,e,[t],r,"filter")})}const Ro="flatten",Po=s(Ro,["typed","matrix"],e=>{let{typed:t,matrix:r}=e;return t(Ro,{Array:A,Matrix:function(e){e=A(e.toArray());return r(e)}})}),jo="forEach",Uo=s(jo,["typed"],e=>{let t=e["typed"];return t(jo,{"Array, function":Lo,"Matrix, function":function(e,t){e.forEach(t)}})});function Lo(t,n){function i(e,r){if(!Array.isArray(e))return Io(n,e,r,t,"forEach");An(e,function(e,t){i(e,r.concat(t))})}i(t,[])}const $o="getMatrixDataType",Ho=s($o,["typed"],e=>{let t=e["typed"];return t($o,{Array:function(e){return Fn(e,K)},Matrix:function(e){return e.getDataType()}})}),Go="identity",Zo=s(Go,["typed","config","matrix","BigNumber","DenseMatrix","SparseMatrix"],e=>{let{typed:t,config:r,matrix:n,BigNumber:c,DenseMatrix:l,SparseMatrix:f}=e;return t(Go,{"":function(){return"Matrix"===r.matrix?n([]):[]},string:function(e){return n(e)},"number | BigNumber":function(e){return a(e,e,"Matrix"===r.matrix?"dense":void 0)},"number | BigNumber, string":function(e,t){return a(e,e,t)},"number | BigNumber, number | BigNumber":function(e,t){return a(e,t,"Matrix"===r.matrix?"dense":void 0)},"number | BigNumber, number | BigNumber, string":a,Array:function(e){return i(e)},"Array, string":i,Matrix:function(e){return i(e.valueOf(),e.storage())},"Matrix, string":function(e,t){return i(e.valueOf(),t)}});function i(e,t){switch(e.length){case 0:return t?n(t):[];case 1:return a(e[0],e[0],t);case 2:return a(e[0],e[1],t);default:throw new Error("Vector containing two values expected")}}function a(e,t,r){const n=Q(e)||Q(t)?c:null;if(Q(e)&&(e=e.toNumber()),Q(t)&&(t=t.toNumber()),!v(e)||e<1)throw new Error("Parameters in function identity must be positive integers");if(!v(t)||t<1)throw new Error("Parameters in function identity must be positive integers");var i=n?new c(1):1,a=n?new n(0):0,o=[e,t];if(r){if("sparse"===r)return f.diagonal(o,i,0,a);if("dense"===r)return l.diagonal(o,i,0,a);throw new TypeError(`Unknown matrix type "${r}"`)}const s=yn([],o,a),u=e<t?e:t;for(let e=0;e<u;e++)s[e][e]=i;return s}}),Vo=s("kron",["typed","matrix","multiplyScalar"],e=>{let{typed:t,matrix:r,multiplyScalar:a}=e;return t("kron",{"Matrix, Matrix":function(e,t){return r(n(e.toArray(),t.toArray()))},"Matrix, Array":function(e,t){return r(n(e.toArray(),t))},"Array, Matrix":function(e,t){return r(n(e,t.toArray()))},"Array, Array":n});function n(e,r){if(1===T(e).length&&(e=[e]),1===T(r).length&&(r=[r]),2<T(e).length||2<T(r).length)throw new RangeError("Vectors with dimensions greater then 2 are not supported expected (Size x = "+JSON.stringify(e.length)+", y = "+JSON.stringify(r.length)+")");const n=[];let i=[];return e.map(function(t){return r.map(function(e){return i=[],n.push(i),t.map(function(t){return e.map(function(e){return i.push(a(t,e))})})})})&&n}}),Wo=s("map",["typed"],e=>{let t=e["typed"];return t("map",{"Array, function":Yo,"Matrix, function":function(e,t){return e.map(t)}})});function Yo(t,n){function i(e,r){return Array.isArray(e)?e.map(function(e,t){return i(e,r.concat(t))}):Io(n,e,r,t,"map")}return i(t,[])}const Jo=s("diff",["typed","matrix","subtract","number"],e=>{let{typed:t,matrix:r,subtract:i,number:n}=e;return t("diff",{"Array | Matrix":function(e){return _(e)?r(o(e.toArray())):o(e)},"Array | Matrix, number":function(e,t){if(v(t))return _(e)?r(a(e.toArray(),t)):a(e,t);throw new RangeError("Dimension must be a whole number")},"Array, BigNumber":t.referTo("Array,number",r=>(e,t)=>r(e,n(t))),"Matrix, BigNumber":t.referTo("Matrix,number",r=>(e,t)=>r(e,n(t)))});function a(e,t){if(_(e)&&(e=e.toArray()),!Array.isArray(e))throw RangeError("Array/Matrix does not have that many dimensions");if(0<t){const r=[];return e.forEach(e=>{r.push(a(e,t-1))}),r}if(0===t)return o(e);throw RangeError("Cannot have negative dimension")}function o(t){const r=[],n=t.length;for(let e=1;e<n;e++)r.push(function a(e,t){_(e)&&(e=e.toArray()),_(t)&&(t=t.toArray());const r=Array.isArray(e),n=Array.isArray(t);if(r&&n)return function(t,r){if(t.length!==r.length)throw RangeError("Not all sub-arrays have the same length");const n=[],i=t.length;for(let e=0;e<i;e++)n.push(a(t[e],r[e]));return n}(e,t);if(!r&&!n)return i(t,e);throw TypeError("Cannot calculate difference between 1 array and 1 non-array")}(t[e-1],t[e]));return r}}),Xo=s("ones",["typed","config","matrix","BigNumber"],e=>{let{typed:t,config:r,matrix:i,BigNumber:a}=e;return t("ones",{"":function(){return"Array"===r.matrix?n([]):n([],"default")},"...number | BigNumber | string":function(e){var t;return"string"==typeof e[e.length-1]?(t=e.pop(),n(e,t)):"Array"===r.matrix?n(e):n(e,"default")},Array:n,Matrix:function(e){var t=e.storage();return n(e.valueOf(),t)},"Array | Matrix, string":function(e,t){return n(e.valueOf(),t)}});function n(e,t){const r=function(){let n=!1;return e.forEach(function(e,t,r){Q(e)&&(n=!0,r[t]=e.toNumber())}),n}(),n=r?new a(1):1;if(e.forEach(function(e){if("number"!=typeof e||!v(e)||e<0)throw new Error("Parameters in function ones must be positive integers")}),t){const r=i(t);return 0<e.length?r.resize(e,n):r}{const t=[];return 0<e.length?yn(t,e,n):t}}});function Qo(){throw new Error('No "bignumber" implementation available')}function Ko(){throw new Error('No "fraction" implementation available')}function es(){throw new Error('No "matrix" implementation available')}const ts=s("range",["typed","config","?matrix","?bignumber","smaller","smallerEq","larger","largerEq","add","isPositive"],e=>{let{typed:t,config:n,matrix:r,bignumber:i,smaller:s,smallerEq:u,larger:c,largerEq:l,add:f,isPositive:p}=e;return t("range",{string:o,"string, boolean":o,"number, number":function(e,t){return a(m(e,t,1,!1))},"number, number, number":function(e,t,r){return a(m(e,t,r,!1))},"number, number, boolean":function(e,t,r){return a(m(e,t,1,r))},"number, number, number, boolean":function(e,t,r,n){return a(m(e,t,r,n))},"BigNumber, BigNumber":function(e,t){return a(m(e,t,new e.constructor(1),!1))},"BigNumber, BigNumber, BigNumber":function(e,t,r){return a(m(e,t,r,!1))},"BigNumber, BigNumber, boolean":function(e,t,r){return a(m(e,t,new e.constructor(1),r))},"BigNumber, BigNumber, BigNumber, boolean":function(e,t,r,n){return a(m(e,t,r,n))},"Unit, Unit, Unit":function(e,t,r){return a(m(e,t,r,!1))},"Unit, Unit, Unit, boolean":function(e,t,r,n){return a(m(e,t,r,n))}});function a(e){return"Matrix"===n.matrix?r?r(e):es():e}function o(t,e){var r=function(){const e=t.split(":").map(function(e){return Number(e)});if(e.some(function(e){return isNaN(e)}))return null;switch(e.length){case 2:return{start:e[0],end:e[1],step:1};case 3:return{start:e[0],end:e[2],step:e[1]};default:return null}}();if(r)return"BigNumber"===n.number?(void 0===i&&Qo(),a(m(i(r.start),i(r.end),i(r.step)))):a(m(r.start,r.end,r.step,e));throw new SyntaxError('String "'+t+'" is no valid range')}function m(e,t,r,n){const i=[],a=p(r)?n?u:s:n?l:c;let o=e;for(;a(o,t);)i.push(o),o=f(o,r);return i}}),rs="reshape",ns=s(rs,["typed","isInteger","matrix"],e=>{let{typed:t,isInteger:r}=e;return t(rs,{"Matrix, Array":function(e,t){return e.reshape(t,!0)},"Array, Array":function(e,t){return t.forEach(function(e){if(!r(e))throw new TypeError("Invalid size for dimension: "+e)}),xn(e,t)}})}),is=s("resize",["config","matrix"],e=>{let{config:s,matrix:u}=e;return function(e,t,r){if(2!==arguments.length&&3!==arguments.length)throw new Ta("resize",arguments.length,2,3);if(Q((t=_(t)?t.valueOf():t)[0])&&(t=t.map(function(e){return Q(e)?e.toNumber():e})),_(e))return e.resize(t,r,!0);if("string"==typeof e){var n=e,i=t,a=r;if(void 0!==a){if("string"!=typeof a||1!==a.length)throw new TypeError("Single character expected as defaultValue")}else a=" ";if(1!==i.length)throw new z(i.length,1);var o=i[0];if("number"!=typeof o||!v(o))throw new TypeError("Invalid size, must contain positive integers (size: "+S(i)+")");if(n.length>o)return n.substring(0,o);if(n.length<o){let r=n;for(let e=0,t=o-n.length;e<t;e++)r+=a;return r}return n}i=!Array.isArray(e)&&"Array"!==s.matrix;if(0===t.length){for(;Array.isArray(e);)e=e[0];return ee(e)}{const s=yn(e=ee(e=Array.isArray(e)?e:[e]),t,r);return i?u(s):s}}}),as=s("rotate",["typed","multiply","rotationMatrix"],e=>{let{typed:t,multiply:n,rotationMatrix:i}=e;return t("rotate",{"Array , number | BigNumber | Complex | Unit":function(e,t){return a(e,2),n(i(t),e).toArray()},"Matrix , number | BigNumber | Complex | Unit":function(e,t){return a(e,2),n(i(t),e)},"Array, number | BigNumber | Complex | Unit, Array | Matrix":function(e,t,r){return a(e,3),n(i(t,r),e)},"Matrix, number | BigNumber | Complex | Unit, Array | Matrix":function(e,t,r){return a(e,3),n(i(t,r),e)}});function a(e,t){e=Array.isArray(e)?T(e):e.size();if(2<e.length)throw new RangeError("Vector must be of dimensions 1x"+t);if(2===e.length&&1!==e[1])throw new RangeError("Vector must be of dimensions 1x"+t);if(e[0]!==t)throw new RangeError("Vector must be of dimensions 1x"+t)}}),os="rotationMatrix",ss=s(os,["typed","config","multiplyScalar","addScalar","unaryMinus","norm","matrix","BigNumber","DenseMatrix","SparseMatrix","cos","sin"],e=>{let{typed:t,config:n,multiplyScalar:i,addScalar:m,unaryMinus:h,norm:d,BigNumber:g,matrix:a,DenseMatrix:r,SparseMatrix:o,cos:y,sin:x}=e;return t(os,{"":function(){return"Matrix"===n.matrix?a([]):[]},string:function(e){return a(e)},"number | BigNumber | Complex | Unit":function(e){return s(e,"Matrix"===n.matrix?"dense":void 0)},"number | BigNumber | Complex | Unit, string":s,"number | BigNumber | Complex | Unit, Array":function(e,t){t=a(t);return u(t),c(e,t,void 0)},"number | BigNumber | Complex | Unit, Matrix":function(e,t){u(t);var r=t.storage()||("Matrix"===n.matrix?"dense":void 0);return c(e,t,r)},"number | BigNumber | Complex | Unit, Array, string":function(e,t,r){t=a(t);return u(t),c(e,t,r)},"number | BigNumber | Complex | Unit, Matrix, string":function(e,t,r){return u(t),c(e,t,r)}});function s(e,t){var r=Q(e)?new g(-1):-1,n=y(e),e=x(e);return v([[n,i(r,e)],[e,n]],t)}function u(e){e=e.size();if(e.length<1||3!==e[0])throw new RangeError("Vector must be of dimensions 1x3")}function b(e){return e.reduce((e,t)=>i(e,t))}function v(e,t){if(t){if("sparse"===t)return new o(e);if("dense"===t)return new r(e);throw new TypeError(`Unknown matrix type "${t}"`)}return e}function c(e,t,r){var n=d(t);if(0===n)throw new RangeError("Rotation around zero vector");const i=Q(e)?g:null,a=i?new i(1):1,o=i?new i(-1):-1,s=i?new i(t.get([0])/n):t.get([0])/n,u=i?new i(t.get([1])/n):t.get([1])/n,c=i?new i(t.get([2])/n):t.get([2])/n,l=y(e),f=m(a,h(l)),p=x(e);return v([[m(l,b([s,s,f])),m(b([s,u,f]),b([o,c,p])),m(b([s,c,f]),b([u,p]))],[m(b([s,u,f]),b([c,p])),m(l,b([u,u,f])),m(b([u,c,f]),b([o,s,p]))],[m(b([s,c,f]),b([o,u,p])),m(b([u,c,f]),b([s,p])),m(l,b([c,c,f]))]],r)}}),us=s("row",["typed","Index","matrix","range"],e=>{let{typed:t,Index:n,matrix:i,range:a}=e;return t("row",{"Matrix, number":r,"Array, number":function(e,t){return r(i(ee(e)),t).valueOf()}});function r(e,t){if(2!==e.size().length)throw new Error("Only two dimensional matrix is supported");M(t,e.size()[0]);var r=a(0,e.size()[1]),t=new n(t,r),r=e.subset(t);return _(r)?r:i([[r]])}}),cs=s("size",["typed","config","?matrix"],e=>{let{typed:t,config:r,matrix:n}=e;return t("size",{Matrix:function(e){return e.create(e.size())},Array:T,string:function(e){return"Array"===r.matrix?[e.length]:n([e.length])},"number | Complex | BigNumber | Unit | boolean | null":function(e){return"Array"===r.matrix?[]:n?n([]):es()}})}),ls="squeeze",fs=s(ls,["typed","matrix"],e=>{let{typed:t,matrix:r}=e;return t(ls,{Array:function(e){return wn(ee(e))},Matrix:function(e){e=wn(e.toArray());return Array.isArray(e)?r(e):e},any:ee})}),ps=s("subset",["typed","matrix","zeros","add"],e=>{let{typed:t,matrix:o,zeros:i,add:a}=e;return t("subset",{"Matrix, Index":function(e,t){return gn(t)?o():(dn(e,t),e.subset(t))},"Array, Index":t.referTo("Matrix, Index",function(n){return function(e,t){const r=n(o(e),t);return t.isScalar()?r:r.valueOf()}}),"Object, Index":ds,"string, Index":ms,"Matrix, Index, any, any":function(e,t,r,n){return gn(t)?e:(dn(e,t),e.clone().subset(t,function(e,t){if("string"==typeof e)throw new Error("can't boradcast a string");if(t._isScalar)return e;const r=t.size();if(!r.every(e=>0<e))return e;try{return a(e,i(r))}catch(t){return e}}(r,t),n))},"Array, Index, any, any":t.referTo("Matrix, Index, any, any",function(a){return function(e,t,r,n){const i=a(o(e),t,r,n);return i.isMatrix?i.valueOf():i}}),"Array, Index, any":t.referTo("Matrix, Index, any, any",function(n){return function(e,t,r){return n(o(e),t,r,void 0).valueOf()}}),"Matrix, Index, any":t.referTo("Matrix, Index, any, any",function(n){return function(e,t,r){return n(e,t,r,void 0)}}),"string, Index, string":hs,"string, Index, string, string":hs,"Object, Index, any":gs})});function ms(t,e){if(!j(e))throw new TypeError("Index expected");if(gn(e))return"";if(dn(Array.from(t),e),1!==e.size().length)throw new z(e.size().length,1);var r=t.length;M(e.min()[0],r),M(e.max()[0],r);const n=e.dimension(0);let i="";return n.forEach(function(e){i+=t.charAt(e)}),i}function hs(t,e,r,n){if(!e||!0!==e.isIndex)throw new TypeError("Index expected");if(gn(e))return t;if(dn(Array.from(t),e),1!==e.size().length)throw new z(e.size().length,1);if(void 0!==n){if("string"!=typeof n||1!==n.length)throw new TypeError("Single character expected as defaultValue")}else n=" ";const i=e.dimension(0);if(i.size()[0]!==r.length)throw new z(i.size()[0],r.length);var a=t.length;M(e.min()[0]),M(e.max()[0]);const o=[];for(let e=0;e<a;e++)o[e]=t.charAt(e);if(i.forEach(function(e,t){o[e]=r.charAt(t[0])}),o.length>a)for(let e=a-1,t=o.length;e<t;e++)o[e]||(o[e]=n);return o.join("")}function ds(e,t){if(!gn(t)){if(1!==t.size().length)throw new z(t.size(),1);t=t.dimension(0);if("string"!=typeof t)throw new TypeError("String expected as index to retrieve an object property");return Ze(e,t)}}function gs(e,t,r){if(gn(t))return e;if(1!==t.size().length)throw new z(t.size(),1);t=t.dimension(0);if("string"!=typeof t)throw new TypeError("String expected as index to retrieve an object property");e=ee(e);return Ve(e,t,r),e}const ys="transpose",xs=s(ys,["typed","matrix"],e=>{let{typed:t,matrix:r}=e;return t(ys,{Array:e=>n(r(e)).valueOf(),Matrix:n,any:ee});function n(e){var t=e.size();let r;switch(t.length){case 1:r=e.clone();break;case 2:var n=t[0],i=t[1];if(0===i)throw new RangeError("Cannot transpose a 2D matrix with no columns (size: "+S(t)+")");switch(e.storage()){case"dense":r=function(e,r,n){const i=e._data,a=[];let o;for(let t=0;t<n;t++){o=a[t]=[];for(let e=0;e<r;e++)o[e]=ee(i[e][t])}return e.createDenseMatrix({data:a,size:[n,r],datatype:e._datatype})}(e,n,i);break;case"sparse":r=function(n,t,e){const i=n._values,a=n._index,o=n._ptr,s=i?[]:void 0,u=[],r=[],c=[];for(let e=0;e<t;e++)c[e]=0;let l,f,p;for(l=0,f=a.length;l<f;l++)c[a[l]]++;let m=0;for(let e=0;e<t;e++)r.push(m),m+=c[e],c[e]=r[e];for(r.push(m),p=0;p<e;p++)for(let e=o[p],t=o[p+1],r=e;r<t;r++){const n=c[a[r]]++;u[n]=p,i&&(s[n]=ee(i[r]))}return n.createSparseMatrix({values:s,index:u,ptr:r,size:[e,t],datatype:n._datatype})}(e,n,i)}break;default:throw new RangeError("Matrix must be a vector or two dimensional (size: "+S(t)+")")}return r}}),bs="ctranspose",vs=s(bs,["typed","transpose","conj"],e=>{let{typed:t,transpose:r,conj:n}=e;return t(bs,{any:function(e){return n(r(e))}})}),ws=s("zeros",["typed","config","matrix","BigNumber"],e=>{let{typed:t,config:r,matrix:i,BigNumber:a}=e;return t("zeros",{"":function(){return"Array"===r.matrix?n([]):n([],"default")},"...number | BigNumber | string":function(e){var t;return"string"==typeof e[e.length-1]?(t=e.pop(),n(e,t)):"Array"===r.matrix?n(e):n(e,"default")},Array:n,Matrix:function(e){var t=e.storage();return n(e.valueOf(),t)},"Array | Matrix, string":function(e,t){return n(e.valueOf(),t)}});function n(e,t){const r=function(){let n=!1;return e.forEach(function(e,t,r){Q(e)&&(n=!0,r[t]=e.toNumber())}),n}(),n=r?new a(0):0;if(e.forEach(function(e){if("number"!=typeof e||!v(e)||e<0)throw new Error("Parameters in function zeros must be positive integers")}),t){const r=i(t);return 0<e.length?r.resize(e,n):r}{const t=[];return 0<e.length?yn(t,e,n):t}}}),Ns=s("fft",["typed","matrix","addScalar","multiplyScalar","divideScalar","exp","tau","i","dotDivide","conj","pow","ceil","log2"],e=>{let{typed:t,addScalar:d,multiplyScalar:g,divideScalar:y,exp:x,tau:b,i:v,dotDivide:w,conj:N,pow:E,ceil:A,log2:S}=e;return t("fft",{Array:M,Matrix:function(e){return e.create(M(e.toArray()))}});function M(e){const t=T(e);return 1===t.length?C(e,t[0]):function r(n,i){const e=T(n);if(0!==i)return new Array(e[0]).fill(0).map((e,t)=>r(n[t],i-1));if(1===e.length)return C(n);function t(n){const t=T(n);return new Array(t[1]).fill(0).map((e,r)=>new Array(t[0]).fill(0).map((e,t)=>n[t][r]))}return t(r(t(n),1))}(e.map(e=>M(e,t.slice(1))),0)}function C(e){var t=e.length;if(1===t)return[e[0]];if(t%2!=0){var r=e;const n=r.length,i=x(y(g(-1,g(v,b)),n)),a=[];for(let e=1-n;e<n;e++)a.push(E(i,y(E(e,2),2)));const o=E(2,A(S(n+n-1))),s=[...new Array(n).fill(0).map((e,t)=>g(r[t],a[n-1+t])),...new Array(o-n).fill(0)],u=[...new Array(n+n-1).fill(0).map((e,t)=>y(1,a[t])),...new Array(o-(n+n-1)).fill(0)],c=C(s),l=C(u),f=new Array(o).fill(0).map((e,t)=>g(c[t],l[t])),p=w(N(M(N(f))),o),m=[];for(let e=n-1;e<n+n-1;e++)m.push(g(p[e],a[e]));return m}{const h=[...C(e.filter((e,t)=>t%2==0)),...C(e.filter((e,t)=>t%2==1))];for(let e=0;e<t/2;e++){const w=h[e],N=g(h[e+t/2],x(g(g(b,v),y(-e,t))));h[e]=d(w,N),h[e+t/2]=d(w,g(-1,N))}return h}}}),Es=s("ifft",["typed","fft","dotDivide","conj"],e=>{let{typed:t,fft:r,dotDivide:n,conj:i}=e;return t("ifft",{"Array | Matrix":function(e){const t=_(e)?e.size():T(e);return n(i(r(i(e))),t.reduce((e,t)=>e*t,1))}})}),As=s("solveODE",["typed","add","subtract","multiply","divide","max","map","abs","isPositive","isNegative","larger","smaller","matrix","bignumber","unaryMinus"],e=>{let{typed:t,add:T,subtract:D,multiply:F,divide:B,max:O,map:_,abs:z,isPositive:I,isNegative:k,larger:q,smaller:R,matrix:a,bignumber:P,unaryMinus:j}=e;function i(C){return function(t,r,e,n){if(2!==r.length||!r.every(U)&&!r.every(L))throw new Error('"tspan" must be an Array of two numeric values or two units [tStart, tEnd]');const i=r[0],a=r[1],o=q(a,i),s=n.firstStep;if(void 0!==s&&!I(s))throw new Error('"firstStep" must be positive');const u=n.maxStep;if(void 0!==u&&!I(u))throw new Error('"maxStep" must be positive');const c=n.minStep;if(c&&k(c))throw new Error('"minStep" must be positive or zero');const l=[i,a,s,c,u].filter(e=>void 0!==e);if(!l.every(U)&&!l.every(L))throw new Error('Inconsistent type of "t" dependant variables');var f=n.tol||1e-4,p=n.minDelta||.2,m=n.maxDelta||5,h=n.maxIter||1e4,d=[i,a,...e,u,c].some(Q),[g,y,x,r]=d?[P(C.a),P(C.c),P(C.b),P(C.bp)]:[C.a,C.c,C.b,C.bp];let b=s?o?s:j(s):B(D(a,i),1);const v=[i],w=[e],N=D(x,r);let E=0,A=0;const S=o?R:q,M=function(){const i=o?q:R;return function(e,t,r){var n=T(e,r);return i(n,t)?D(t,e):r}}();for(;S(v[E],a);){const C=[];b=M(v[E],a,b),C.push(t(v[E],w[E]));for(let e=1;e<y.length;++e)C.push(t(T(v[E],F(y[e],b)),T(w[E],F(b,g[e],C))));const r=O(z(_(F(N,C),e=>L(e)?e.value:e)));r<f&&.25<f/r&&(v.push(T(v[E],b)),w.push(T(w[E],F(b,x,C))),E++);let e=.84*(f/r)**.2;if(R(e,p)?e=p:q(e,m)&&(e=m),e=d?P(e):e,b=F(b,e),u&&q(z(b),u)?b=o?u:j(u):c&&R(z(b),c)&&(b=o?c:j(c)),++A>h)throw new Error("Maximum number of iterations reached, try changing options")}return{t:v,y:w}}}function s(e,t,r,n){return i({a:[[],[.5],[0,.75],[2/9,1/3,4/9]],c:[null,.5,.75,1],b:[2/9,1/3,4/9,0],bp:[7/24,.25,1/3,1/8]})(e,t,r,n)}function u(e,t,r,n){return i({a:[[],[.2],[.075,.225],[44/45,-56/15,32/9],[19372/6561,-25360/2187,64448/6561,-212/729],[9017/3168,-355/33,46732/5247,49/176,-5103/18656],[35/384,0,500/1113,125/192,-2187/6784,11/84]],c:[null,.2,.3,.8,8/9,1,1],b:[35/384,0,500/1113,125/192,-2187/6784,11/84,0],bp:[5179/57600,0,7571/16695,393/640,-92097/339200,187/2100,.025]})(e,t,r,n)}function o(e,t,r,n){const i=n.method||"RK45",a={RK23:s,RK45:u};if(i.toUpperCase()in a){const o={...n};return delete o.method,a[i.toUpperCase()](e,t,r,o)}{const e=Object.keys(a).map(e=>`"${e}"`),t=e.slice(0,-1).join(", ")+" and "+e.slice(-1);throw new Error(`Unavailable method "${i}". Available methods are `+t)}}function U(e){return Q(e)||E(e)}function n(e,t,r,n){e=o(e,t.toArray(),r.toArray(),n);return{t:a(e.t),y:a(e.y)}}return t("solveODE",{"function, Array, Array, Object":o,"function, Matrix, Matrix, Object":n,"function, Array, Array":(e,t,r)=>o(e,t,r,{}),"function, Matrix, Matrix":(e,t,r)=>n(e,t,r,{}),"function, Array, number | BigNumber | Unit":(e,t,r)=>{const n=o(e,t,[r],{});return{t:n.t,y:n.y.map(e=>e[0])}},"function, Matrix, number | BigNumber | Unit":(e,t,r)=>{const n=o(e,t.toArray(),[r],{});return{t:a(n.t),y:a(n.y.map(e=>e[0]))}},"function, Array, number | BigNumber | Unit, Object":(e,t,r,n)=>{const i=o(e,t,[r],n);return{t:i.t,y:i.y.map(e=>e[0])}},"function, Matrix, number | BigNumber | Unit, Object":(e,t,r,n)=>{const i=o(e,t.toArray(),[r],n);return{t:a(i.t),y:a(i.y.map(e=>e[0]))}}})}),Ss=s("erf",["typed"],e=>{let t=e["typed"];return t("name",{number:function(e){var t=Math.abs(e);return t>=Fs?n(e):t<=Ms?n(e)*function(e){var t=e*e;let r,n=Ts[0][4]*t,i=t;for(r=0;r<3;r+=1)n=(n+Ts[0][r])*t,i=(i+Ds[0][r])*t;return e*(n+Ts[0][3])/(i+Ds[0][3])}(t):t<=4?n(e)*(1-function(e){let t,r=Ts[1][8]*e,n=e;for(t=0;t<7;t+=1)r=(r+Ts[1][t])*e,n=(n+Ds[1][t])*e;var i=(r+Ts[1][7])/(n+Ds[1][7]),a=parseInt(16*e)/16,o=(e-a)*(e+a);return Math.exp(-a*a)*Math.exp(-o)*i}(t)):n(e)*(1-function(e){let t,r=1/(e*e),n=Ts[2][5]*r,i=r;for(t=0;t<4;t+=1)n=(n+Ts[2][t])*r,i=(i+Ds[2][t])*r;var a=r*(n+Ts[2][4])/(i+Ds[2][4]),a=(Cs-a)/e,e=(e-(r=parseInt(16*e)/16))*(e+r);return Math.exp(-r*r)*Math.exp(-e)*a}(t))},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),Ms=.46875,Cs=.5641895835477563,Ts=[[3.1611237438705655,113.86415415105016,377.485237685302,3209.3775891384694,.18577770618460315],[.5641884969886701,8.883149794388377,66.11919063714163,298.6351381974001,881.952221241769,1712.0476126340707,2051.0783778260716,1230.3393547979972,2.1531153547440383e-8],[.30532663496123236,.36034489994980445,.12578172611122926,.016083785148742275,.0006587491615298378,.016315387137302097]],Ds=[[23.601290952344122,244.02463793444417,1282.6165260773723,2844.236833439171],[15.744926110709835,117.6939508913125,537.1811018620099,1621.3895745666903,3290.7992357334597,4362.619090143247,3439.3676741437216,1230.3393548037495],[2.568520192289822,1.8729528499234604,.5279051029514285,.06051834131244132,.0023352049762686918]],Fs=Math.pow(2,53),Bs=s("zeta",["typed","config","multiply","pow","divide","factorial","equal","smallerEq","isNegative","gamma","sin","subtract","add","?Complex","?BigNumber","pi"],e=>{let{typed:t,config:r,multiply:u,pow:c,divide:l,factorial:i,equal:n,smallerEq:f,isNegative:a,gamma:p,sin:m,subtract:h,add:d,Complex:o,BigNumber:s,pi:g}=e;return t("zeta",{number:e=>y(e,e=>e,()=>20),BigNumber:e=>y(e,e=>new s(e),()=>Math.abs(Math.log10(r.relTol))),Complex:function(e){return 0===e.re&&0===e.im?new o(-.5):1===e.re?new o(NaN,NaN):e.re===1/0&&0===e.im?new o(1):e.im===1/0||e.re===-1/0?new o(NaN,NaN):x(e,e=>e,e=>Math.round(19.5+.9*Math.abs(e.im)),e=>e.re)}});function y(e,t,r){return n(e,0)?t(-.5):n(e,1)?t(NaN):isFinite(e)?x(e,t,r,e=>e):a(e)?t(NaN):t(1)}function x(e,r,t,n){var i=t(e);{if(n(e)>-(i-1)/2){var a=e,o=r(i),i=r,s=l(1,u(b(i(0),o),h(1,c(2,h(1,a)))));let t=i(0);for(let e=i(1);f(e,o);e=d(e,1))t=d(t,l(u((-1)**(e-1),b(e,o)),c(e,a)));return u(s,t)}return i=u(c(2,e),c(r(g),h(e,1))),i=u(i,m(u(l(r(g),2),e))),i=u(i,p(h(1,e))),u(i,x(h(1,e),r,t,n))}}function b(t,r){let n=t;for(let e=t;f(e,r);e=d(e,1)){const t=l(u(i(d(r,h(e,1))),c(4,e)),u(i(h(r,e)),i(u(2,e))));n=d(n,t)}return u(r,n)}}),Os=s("mode",["typed","isNaN","isNumeric"],e=>{let{typed:t,isNaN:o,isNumeric:s}=e;return t("mode",{"Array | Matrix":r,"...":r});function r(t){if(0===(t=A(t.valueOf())).length)throw new Error("Cannot calculate mode of an empty array");const r={};let n=[],i=0;for(let e=0;e<t.length;e++){var a=t[e];if(s(a)&&o(a))throw new Error("Cannot calculate mode of an array containing NaN values");a in r||(r[a]=0),r[a]++,r[a]===i?n.push(a):r[a]>i&&(i=r[a],n=[a])}return n}});function _s(e,t,r){let n;return String(e).includes("Unexpected type")?(n=2<arguments.length?" (type: "+K(r)+", value: "+JSON.stringify(r)+")":" (type: "+e.data.actual+")",new TypeError("Cannot calculate "+t+", unexpected type of argument"+n)):String(e).includes("complex numbers")?(n=2<arguments.length?" (type: "+K(r)+", value: "+JSON.stringify(r)+")":"",new TypeError("Cannot calculate "+t+", no ordering relation is defined for complex numbers"+n)):e}const zs=s("prod",["typed","config","multiplyScalar","numeric"],e=>{let{typed:t,config:n,multiplyScalar:i,numeric:a}=e;return t("prod",{"Array | Matrix":r,"Array | Matrix, number | BigNumber":function(e,t){throw new Error("prod(A, dim) is not yet supported")},"...":r});function r(e){let r;if(Ln(e,function(t){try{r=void 0===r?t:i(r,t)}catch(e){throw _s(e,"prod",t)}}),void 0===(r="string"==typeof r?a(r,we(r,n)):r))throw new Error("Cannot calculate prod of an empty array");return r}}),Is=s("format",["typed"],e=>{let t=e["typed"];return t("format",{any:S,"any, Object | function | number | BigNumber":S})}),ks=s("bin",["typed","format"],e=>{let{typed:t,format:r}=e;return t("bin",{"number | BigNumber":function(e){return r(e,{notation:"bin"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"bin",wordSize:t})}})}),qs=s("oct",["typed","format"],e=>{let{typed:t,format:r}=e;return t("oct",{"number | BigNumber":function(e){return r(e,{notation:"oct"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"oct",wordSize:t})}})}),Rs=s("hex",["typed","format"],e=>{let{typed:t,format:r}=e;return t("hex",{"number | BigNumber":function(e){return r(e,{notation:"hex"})},"number | BigNumber, number | BigNumber":function(e,t){return r(e,{notation:"hex",wordSize:t})}})}),Ps=/\$([\w.]+)/g,js=s("print",["typed"],e=>{let t=e["typed"];return t("print",{"string, Object | Array":Us,"string, Object | Array, number | Object":Us})});function Us(e,i,a){return e.replace(Ps,function(e,t){const r=t.split(".");let n=i[r.shift()];for(void 0!==n&&n.isMatrix&&(n=n.toArray());r.length&&void 0!==n;){const e=r.shift();n=e?n[e]:n+"."}return void 0!==n?k(n)?n:S(n,a):e})}const Ls=s("to",["typed","matrix","concat"],e=>{let{typed:t,matrix:r,concat:n}=e;return t("to",{"Unit, Unit | string":(e,t)=>e.to(t)},B({typed:t,matrix:r,concat:n})({Ds:!0}))}),$s="isPrime",Hs=s($s,["typed"],e=>{let t=e["typed"];return t($s,{number:function(t){if(t<=3)return 1<t;if(t%2==0||t%3==0)return!1;for(let e=5;e*e<=t;e+=6)if(t%e==0||t%(e+2)==0)return!1;return!0},bigint:function(t){if(t<=3n)return 1n<t;if(t%2n===0n||t%3n===0n)return!1;for(let e=5n;e*e<=t;e+=6n)if(t%e===0n||t%(e+2n)===0n)return!1;return!0},BigNumber:function(r){if(r.lte(3))return r.gt(1);if(r.mod(2).eq(0)||r.mod(3).eq(0))return!1;if(r.lt(Math.pow(2,32))){const t=r.toNumber();for(let e=5;e*e<=t;e+=6)if(t%e==0||t%(e+2)==0)return!1;return!0}function t(e,t,r){let n=1;for(;!t.eq(0);)t.mod(2).eq(0)?(t=t.div(2),e=e.mul(e).mod(r)):(t=t.sub(1),n=e.mul(n).mod(r));return n}const e=r.constructor.clone({precision:2*r.toFixed(0).length});let n=0,i=(r=new e(r)).sub(1);for(;i.mod(2).eq(0);)i=i.div(2),n+=1;let a=null;if(r.lt("3317044064679887385961981"))a=[2,3,5,7,11,13,17,19,23,29,31,37,41].filter(e=>e<r);else{const t=Math.min(r.toNumber()-2,Math.floor(2*Math.pow(r.toFixed(0).length*Math.log(10),2)));a=[];for(let e=2;e<=t;e+=1)a.push(t)}for(let e=0;e<a.length;e+=1){const o=a[e],s=t(r.sub(r).add(o),i,r);if(!s.eq(1))for(let e=0,t=s;!t.eq(r.sub(1));e+=1,t=t.mul(t).mod(r))if(e===n-1)return!1}return!0},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),Gs=s("numeric",["number","?bignumber","?fraction"],e=>{let{number:t,bignumber:r,fraction:n}=e;const i={string:!0,number:!0,BigNumber:!0,Fraction:!0},a={number:e=>t(e),BigNumber:r?e=>r(e):Qo,bigint:e=>BigInt(e),Fraction:n?e=>n(e):Ko};return function(e){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"number";if(void 0!==(2<arguments.length?arguments[2]:void 0))throw new SyntaxError("numeric() takes one or two arguments");var r=K(e);if(!(r in i))throw new TypeError("Cannot convert "+e+' of type "'+r+'"; valid input types are '+Object.keys(i).join(", "));if(t in a)return t===r?e:a[t](e);throw new TypeError("Cannot convert "+e+' to type "'+t+'"; valid output types are '+Object.keys(a).join(", "))}}),Zs="divideScalar",Vs=s(Zs,["typed","numeric"],e=>{let t=e["typed"];return t(Zs,{"number, number":function(e,t){return e/t},"Complex, Complex":function(e,t){return e.div(t)},"BigNumber, BigNumber":function(e,t){return e.div(t)},"bigint, bigint":function(e,t){return e/t},"Fraction, Fraction":function(e,t){return e.div(t)},"Unit, number | Complex | Fraction | BigNumber | Unit":(e,t)=>e.divide(t),"number | Fraction | Complex | BigNumber, Unit":(e,t)=>t.divideInto(e)})}),Ws=s("pow",["typed","config","identity","multiply","matrix","inv","fraction","number","Complex"],e=>{let{typed:t,config:n,identity:a,multiply:o,matrix:r,inv:s,number:i,fraction:u,Complex:c}=e;return t("pow",{"number, number":l,"Complex, Complex":function(e,t){return e.pow(t)},"BigNumber, BigNumber":function(e,t){return t.isInteger()||0<=e||n.predictable?e.pow(t):new c(e.toNumber(),0).pow(t.toNumber(),0)},"bigint, bigint":(e,t)=>e**t,"Fraction, Fraction":function(e,t){var r=e.pow(t);if(null!=r)return r;if(n.predictable)throw new Error("Result of pow is non-rational and cannot be expressed as a fraction");return l(e.valueOf(),t.valueOf())},"Array, number":f,"Array, BigNumber":function(e,t){return f(e,t.toNumber())},"Matrix, number":p,"Matrix, BigNumber":function(e,t){return p(e,t.toNumber())},"Unit, number | BigNumber":function(e,t){return e.pow(t)}});function l(e,t){if(n.predictable&&!v(t)&&e<0)try{const n=u(t),r=i(n);if((t===r||Math.abs((t-r)/t)<1e-14)&&n.d%2==1)return(n.n%2==0?1:-1)*Math.pow(-e,t)}catch(e){}return n.predictable&&(e<-1&&t===1/0||-1<e&&e<0&&t===-1/0)?NaN:v(t)||0<=e||n.predictable?Wi(e,t):e*e<1&&t===1/0||1<e*e&&t===-1/0?0:new c(e,0).pow(t,0)}function f(e,t){if(!v(t))throw new TypeError("For A^b, b must be an integer (value is "+t+")");var r=T(e);if(2!==r.length)throw new Error("For A^b, A must be 2 dimensional (A has "+r.length+" dimensions)");if(r[0]!==r[1])throw new Error("For A^b, A must be square (size is "+r[0]+"x"+r[1]+")");if(t<0)try{return f(s(e),-t)}catch(e){if("Cannot calculate inverse, determinant is zero"===e.message)throw new TypeError("For A^b, when A is not invertible, b must be a positive integer (value is "+t+")");throw e}let n=a(r[0]).valueOf(),i=e;for(;1<=t;)1&~t||(n=o(i,n)),t>>=1,i=o(i,i);return n}function p(e,t){return r(f(e.valueOf(),t))}}),Ys="Number of decimals in function round must be an integer",Js=s("round",["typed","config","matrix","equalScalar","zeros","BigNumber","DenseMatrix"],e=>{let{typed:t,config:i,matrix:n,equalScalar:a,zeros:o,BigNumber:r,DenseMatrix:s}=e;const u=x({typed:t,equalScalar:a}),c=C({typed:t,DenseMatrix:s}),l=ua({typed:t});function f(e){return Math.abs(Ce(e).exponent)}return t("round",{number:function(e){var t=Yi(e,f(i.relTol));return Yi(p(e,t,i.relTol,i.absTol)?t:e)},"number, number":function(e,t){var r=f(i.relTol);if(r<=t)return Yi(e,t);r=Yi(e,r);return Yi(p(e,r,i.relTol,i.absTol)?r:e,t)},"number, BigNumber":function(e,t){if(t.isInteger())return new r(e).toDecimalPlaces(t.toNumber());throw new TypeError(Ys)},Complex:function(e){return e.round()},"Complex, number":function(e,t){if(t%1)throw new TypeError(Ys);return e.round(t)},"Complex, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Ys);t=t.toNumber();return e.round(t)},BigNumber:function(e){const t=new r(e).toDecimalPlaces(f(i.relTol));return(Jn(e,t,i.relTol,i.absTol)?t:e).toDecimalPlaces(0)},"BigNumber, BigNumber":function(e,t){if(!t.isInteger())throw new TypeError(Ys);var r=f(i.relTol);if(r<=t)return e.toDecimalPlaces(t.toNumber());const n=e.toDecimalPlaces(r);return(Jn(e,n,i.relTol,i.absTol)?n:e).toDecimalPlaces(t.toNumber())},Fraction:function(e){return e.round()},"Fraction, number":function(e,t){if(t%1)throw new TypeError(Ys);return e.round(t)},"Fraction, BigNumber":function(e,t){if(t.isInteger())return e.round(t.toNumber());throw new TypeError(Ys)},"Unit, number, Unit":t.referToSelf(n=>function(e,t,r){e=e.toNumeric(r);return r.multiply(n(e,t))}),"Unit, BigNumber, Unit":t.referToSelf(n=>(e,t,r)=>n(e,t.toNumber(),r)),"Unit, Unit":t.referToSelf(r=>(e,t)=>r(e,0,t)),"Array | Matrix, number, Unit":t.referToSelf(n=>(e,t,r)=>ce(e,e=>n(e,t,r),!0)),"Array | Matrix, BigNumber, Unit":t.referToSelf(n=>(e,t,r)=>n(e,t.toNumber(),r)),"Array | Matrix, Unit":t.referToSelf(r=>(e,t)=>r(e,0,t)),"Array | Matrix":t.referToSelf(t=>e=>ce(e,t,!0)),"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>u(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>l(e,t,r,!1)),"Array, number | BigNumber":t.referToSelf(r=>(e,t)=>l(n(e),t,r,!1).valueOf()),"number | Complex | BigNumber | Fraction, SparseMatrix":t.referToSelf(r=>(e,t)=>a(e,0)?o(t.size(),t.storage()):c(t,e,r,!0)),"number | Complex | BigNumber | Fraction, DenseMatrix":t.referToSelf(r=>(e,t)=>a(e,0)?o(t.size(),t.storage()):l(t,e,r,!0)),"number | Complex | BigNumber | Fraction, Array":t.referToSelf(r=>(e,t)=>l(n(t),e,r,!0).valueOf())})}),Xs=s("log",["config","typed","divideScalar","Complex"],e=>{let{typed:t,config:r,divideScalar:n,Complex:i}=e;return t("log",{number:function(e){return 0<=e||r.predictable?Math.log(e):new i(e,0).log()},Complex:function(e){return e.log()},BigNumber:function(e){return!e.isNegative()||r.predictable?e.ln():new i(e.toNumber(),0).log()},"any, any":t.referToSelf(r=>(e,t)=>n(r(e),r(t)))})}),Qs=s("log1p",["typed","config","divideScalar","log","Complex"],e=>{let{typed:t,config:r,divideScalar:n,log:i,Complex:a}=e;return t("log1p",{number:function(e){return-1<=e||r.predictable?Ne(e):o(new a(e,0))},Complex:o,BigNumber:function(e){const t=e.plus(1);return!t.isNegative()||r.predictable?t.ln():o(new a(e.toNumber(),0))},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t)),"any, any":t.referToSelf(r=>(e,t)=>n(r(e),i(t)))});function o(e){var t=e.re+1;return new a(Math.log(Math.sqrt(t*t+e.im*e.im)),Math.atan2(e.im,t))}}),Ks="nthRoots",eu=s(Ks,["config","typed","divideScalar","Complex"],e=>{let{typed:t,Complex:u}=e;const c=[function(e){return new u(e,0)},function(e){return new u(0,e)},function(e){return new u(-e,0)},function(e){return new u(0,-e)}];function r(e,t){if(t<0)throw new Error("Root must be greater than zero");if(0===t)throw new Error("Root must be non-zero");if(t%1!=0)throw new Error("Root must be an integer");if(0===e||0===e.abs())return[new u(0,0)];const r="number"==typeof e;let n;!r&&0!==e.re&&0!==e.im||(n=r?2*(e<0):0===e.im?2*(e.re<0):2*(e.im<0)+1);const i=e.arg(),a=e.abs(),o=[],s=Math.pow(a,1/t);for(let e=0;e<t;e++){const r=(n+4*e)/t;r!==Math.round(r)?o.push(new u({r:s,phi:(i+2*Math.PI*e)/t})):o.push(c[r%4](s))}return o}return t(Ks,{Complex:function(e){return r(e,2)},"Complex, number":r})}),tu=s("dotPow",["typed","equalScalar","matrix","pow","DenseMatrix","concat"],e=>{let{typed:t,equalScalar:r,matrix:n,pow:i,DenseMatrix:a,concat:o}=e;const s=wa({typed:t}),u=go({typed:t,DenseMatrix:a}),c=x({typed:t,equalScalar:r}),l=C({typed:t,DenseMatrix:a}),f=B({typed:t,matrix:n,concat:o}),p={};for(const e in i.signatures)!Object.prototype.hasOwnProperty.call(i.signatures,e)||e.includes("Matrix")||e.includes("Array")||(p[e]=i.signatures[e]);e=t(p);return t("dotPow",f({elop:e,SS:u,DS:s,Ss:c,sS:l}))}),ru="dotDivide",nu=s(ru,["typed","matrix","equalScalar","divideScalar","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,divideScalar:i,DenseMatrix:a,concat:o}=e;const s=va({typed:t,equalScalar:n}),u=wa({typed:t}),c=go({typed:t,DenseMatrix:a}),l=x({typed:t,equalScalar:n}),f=C({typed:t,DenseMatrix:a}),p=B({typed:t,matrix:r,concat:o});return t(ru,p({elop:i,SS:c,DS:u,SD:s,Ss:l,sS:f}))});function iu(e){let s=e["DenseMatrix"];return function(r,t,n){const i=r.size();if(2!==i.length)throw new RangeError("Matrix must be two dimensional (size: "+S(i)+")");var a=i[0];if(a!==i[1])throw new RangeError("Matrix must be square (size: "+S(i)+")");let o=[];if(_(t)){const r=t.size(),i=t._data;if(1===r.length){if(r[0]!==a)throw new RangeError("Dimension mismatch. Matrix columns must match vector length.");for(let e=0;e<a;e++)o[e]=[i[e]];return new s({data:o,size:[a,1],datatype:t._datatype})}if(2===r.length){if(r[0]!==a||1!==r[1])throw new RangeError("Dimension mismatch. Matrix columns must match vector length.");if(R(t)){if(n){o=[];for(let e=0;e<a;e++)o[e]=[i[e][0]];return new s({data:o,size:[a,1],datatype:t._datatype})}return t}if(P(t)){for(let e=0;e<a;e++)o[e]=[0];const r=t._values,n=t._index,i=t._ptr;for(let e=i[1],t=i[0];t<e;t++)o[n[t]][0]=r[t];return new s({data:o,size:[a,1],datatype:t._datatype})}}throw new RangeError("Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.")}if(g(t)){const r=T(t);if(1===r.length){if(r[0]!==a)throw new RangeError("Dimension mismatch. Matrix columns must match vector length.");for(let e=0;e<a;e++)o[e]=[t[e]];return new s({data:o,size:[a,1]})}if(2!==r.length)throw new RangeError("Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.");if(r[0]!==a||1!==r[1])throw new RangeError("Dimension mismatch. Matrix columns must match vector length.");for(let e=0;e<a;e++)o[e]=[t[e][0]];return new s({data:o,size:[a,1]})}}}const au=s("lsolve",["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],e=>{let{typed:t,matrix:r,divideScalar:m,multiplyScalar:h,subtractScalar:d,equalScalar:g,DenseMatrix:y}=e;const x=iu({DenseMatrix:y});return t("lsolve",{"SparseMatrix, Array | Matrix":function(e,t){{var n=t;const a=(n=x(e,n,!0))._data,o=e._size[0],s=e._size[1],u=e._values,c=e._index,l=e._ptr,f=[];for(let r=0;r<s;r++){const n=a[r][0]||0;if(g(n,0))f[r]=[0];else{let t=0;const x=[],o=[],s=l[r],p=l[r+1];for(let e=s;e<p;e++){const a=c[e];a===r?t=u[e]:a>r&&(x.push(u[e]),o.push(a))}if(g(t,0))throw new Error("Linear system cannot be solved since matrix is singular");var i=m(n,t);for(let e=0,t=o.length;e<t;e++){const n=o[e];a[n]=[d(a[n][0]||0,h(i,x[e]))]}f[r]=[i]}}return new y({data:f,size:[o,1]})}},"DenseMatrix, Array | Matrix":n,"Array, Array | Matrix":function(e,t){return n(r(e),t).valueOf()}});function n(e,n){const i=(n=x(e,n,!0))._data,a=e._size[0],t=e._size[1],o=[],s=e._data;for(let r=0;r<t;r++){const n=i[r][0]||0;let t;if(g(n,0))t=0;else{const x=s[r][r];if(g(x,0))throw new Error("Linear system cannot be solved since matrix is singular");t=m(n,x);for(let e=r+1;e<a;e++)i[e]=[d(i[e][0]||0,h(t,s[e][r]))]}o[r]=[t]}return new y({data:o,size:[a,1]})}}),ou=s("usolve",["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],e=>{let{typed:t,matrix:r,divideScalar:p,multiplyScalar:m,subtractScalar:h,equalScalar:d,DenseMatrix:g}=e;const y=iu({DenseMatrix:g});return t("usolve",{"SparseMatrix, Array | Matrix":function(e,t){{var n=t;const a=(n=y(e,n,!0))._data,o=e._size[0],s=e._size[1],u=e._values,c=e._index,l=e._ptr,f=[];for(let r=s-1;0<=r;r--){const n=a[r][0]||0;if(d(n,0))f[r]=[0];else{let t=0;const y=[],o=[],s=l[r];for(let e=l[r+1]-1;e>=s;e--){const a=c[e];a===r?t=u[e]:a<r&&(y.push(u[e]),o.push(a))}if(d(t,0))throw new Error("Linear system cannot be solved since matrix is singular");var i=p(n,t);for(let e=0,t=o.length;e<t;e++){const n=o[e];a[n]=[h(a[n][0],m(i,y[e]))]}f[r]=[i]}}return new g({data:f,size:[o,1]})}},"DenseMatrix, Array | Matrix":n,"Array, Array | Matrix":function(e,t){return n(r(e),t).valueOf()}});function n(e,n){const i=(n=y(e,n,!0))._data,t=e._size[0],a=e._size[1],o=[],s=e._data;for(let r=a-1;0<=r;r--){const n=i[r][0]||0;let t;if(d(n,0))t=0;else{const y=s[r][r];if(d(y,0))throw new Error("Linear system cannot be solved since matrix is singular");t=p(n,y);for(let e=r-1;0<=e;e--)i[e]=[h(i[e][0]||0,m(t,s[e][r]))]}o[r]=[t]}return new g({data:o,size:[t,1]})}}),su="lsolveAll",uu=s(su,["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],e=>{let{typed:t,matrix:r,divideScalar:m,multiplyScalar:h,subtractScalar:d,equalScalar:g,DenseMatrix:y}=e;const x=iu({DenseMatrix:y});return t(su,{"SparseMatrix, Array | Matrix":function(e,t){{var i=t;const a=[x(e,i,!0)._data.map(e=>e[0])],o=e._size[0],s=e._size[1],u=e._values,c=e._index,l=e._ptr;for(let n=0;n<s;n++){let r=a.length;for(let e=0;e<r;e++){const x=a[e],o=[],s=[],f=l[n],p=l[n+1];let t=0;for(let e=f;e<p;e++){const a=c[e];a===n?t=u[e]:a>n&&(o.push(u[e]),s.push(a))}if(g(t,0))if(g(x[n],0)){if(0===e){const i=[...x];i[n]=1;for(let e=0,t=s.length;e<t;e++){const a=s[e];i[a]=d(i[a],o[e])}a.push(i)}}else{if(0===e)return[];a.splice(e,1),--e,--r}else{x[n]=m(x[n],t);for(let e=0,t=s.length;e<t;e++){const a=s[e];x[a]=d(x[a],h(x[n],o[e]))}}}}return a.map(e=>new y({data:e.map(e=>[e]),size:[o,1]}))}},"DenseMatrix, Array | Matrix":n,"Array, Array | Matrix":function(e,t){return n(r(e),t).map(e=>e.valueOf())}});function n(e,n){const i=[x(e,n,!0)._data.map(e=>e[0])],a=e._data,t=e._size[0],o=e._size[1];for(let r=0;r<o;r++){let t=i.length;for(let e=0;e<t;e++){const x=i[e];if(g(a[r][r],0))if(g(x[r],0)){if(0===e){const n=[...x];n[r]=1;for(let e=r+1;e<o;e++)n[e]=d(n[e],a[e][r]);i.push(n)}}else{if(0===e)return[];i.splice(e,1),--e,--t}else{x[r]=m(x[r],a[r][r]);for(let e=r+1;e<o;e++)x[e]=d(x[e],h(x[r],a[e][r]))}}}return i.map(e=>new y({data:e.map(e=>[e]),size:[t,1]}))}}),cu="usolveAll",lu=s(cu,["typed","matrix","divideScalar","multiplyScalar","subtractScalar","equalScalar","DenseMatrix"],e=>{let{typed:t,matrix:r,divideScalar:p,multiplyScalar:m,subtractScalar:h,equalScalar:d,DenseMatrix:g}=e;const y=iu({DenseMatrix:g});return t(cu,{"SparseMatrix, Array | Matrix":function(e,t){{var i=t;const a=[y(e,i,!0)._data.map(e=>e[0])],o=e._size[0],s=e._size[1],u=e._values,c=e._index,l=e._ptr;for(let n=s-1;0<=n;n--){let r=a.length;for(let e=0;e<r;e++){const y=a[e],o=[],s=[],f=l[n];let t=0;for(let e=l[n+1]-1;e>=f;e--){const a=c[e];a===n?t=u[e]:a<n&&(o.push(u[e]),s.push(a))}if(d(t,0))if(d(y[n],0)){if(0===e){const i=[...y];i[n]=1;for(let e=0,t=s.length;e<t;e++){const a=s[e];i[a]=h(i[a],o[e])}a.push(i)}}else{if(0===e)return[];a.splice(e,1),--e,--r}else{y[n]=p(y[n],t);for(let e=0,t=s.length;e<t;e++){const a=s[e];y[a]=h(y[a],m(y[n],o[e]))}}}}return a.map(e=>new g({data:e.map(e=>[e]),size:[o,1]}))}},"DenseMatrix, Array | Matrix":n,"Array, Array | Matrix":function(e,t){return n(r(e),t).map(e=>e.valueOf())}});function n(n,e){const i=[y(n,e,!0)._data.map(e=>e[0])],a=n._data,t=n._size[0];for(let r=n._size[1]-1;0<=r;r--){let t=i.length;for(let e=0;e<t;e++){const y=i[e];if(d(a[r][r],0))if(d(y[r],0)){if(0===e){const n=[...y];n[r]=1;for(let e=r-1;0<=e;e--)n[e]=h(n[e],a[e][r]);i.push(n)}}else{if(0===e)return[];i.splice(e,1),--e,--t}else{y[r]=p(y[r],a[r][r]);for(let e=r-1;0<=e;e--)y[e]=h(y[e],m(y[r],a[e][r]))}}}return i.map(e=>new g({data:e.map(e=>[e]),size:[t,1]}))}}),fu=s("matAlgo08xS0Sid",["typed","equalScalar"],e=>{let{typed:C,equalScalar:T}=e;return function(t,e,r){var n=t._values,i=t._index,a=t._ptr,o=t._size,s=t._datatype||void 0===t._data?t._datatype:t.getDataType(),u=e._values,c=e._index,l=e._ptr,f=e._size,p=e._datatype||void 0===e._data?e._datatype:e.getDataType();if(o.length!==f.length)throw new z(o.length,f.length);if(o[0]!==f[0]||o[1]!==f[1])throw new RangeError("Dimension mismatch. Matrix A ("+o+") must match Matrix B ("+f+")");if(!n||!u)throw new Error("Cannot perform operation on Pattern Sparse Matrices");var f=o[0],m=o[1];let h,d=T,g=0,y=r;"string"==typeof s&&s===p&&"mixed"!==s&&(h=s,d=C.find(T,[h,h]),g=C.convert(0,h),y=C.find(r,[h,h]));const x=[],b=[],v=[],w=[],N=[];let E,A,S,M;for(let e=0;e<m;e++){v[e]=b.length;const C=e+1;for(A=a[e],S=a[e+1],E=A;E<S;E++)M=i[E],N[M]=C,w[M]=n[E],b.push(M);for(A=l[e],S=l[e+1],E=A;E<S;E++)M=c[E],N[M]===C&&(w[M]=y(w[M],u[E]));for(E=v[e];E<b.length;){M=b[E];const t=w[M];d(t,g)?b.splice(E,1):(x.push(t),E++)}}return v[m]=b.length,t.createSparseMatrix({values:x,index:b,ptr:v,size:[f,m],datatype:s===t._datatype&&p===e._datatype?h:void 0})}}),pu=s("useMatrixForArrayScalar",["typed","matrix"],e=>{let{typed:t,matrix:n}=e;return{"Array, number":t.referTo("DenseMatrix, number",r=>(e,t)=>r(n(e),t).valueOf()),"Array, BigNumber":t.referTo("DenseMatrix, BigNumber",r=>(e,t)=>r(n(e),t).valueOf()),"number, Array":t.referTo("number, DenseMatrix",r=>(e,t)=>r(e,n(t)).valueOf()),"BigNumber, Array":t.referTo("BigNumber, DenseMatrix",r=>(e,t)=>r(e,n(t)).valueOf())}}),mu="leftShift",hu=s(mu,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:a,concat:o}=e;const s=Sa({typed:t}),u=va({typed:t,equalScalar:n}),c=fu({typed:t,equalScalar:n}),l=Ca({typed:t,DenseMatrix:a}),f=x({typed:t,equalScalar:n}),p=ua({typed:t}),m=B({typed:t,matrix:r,concat:o}),h=pu({typed:t,matrix:r});return t(mu,{"number, number":co,"BigNumber, BigNumber":ro,"bigint, bigint":(e,t)=>e<<t,"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():f(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():p(e,t,r,!1)),"number | BigNumber, SparseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):l(t,e,r,!0)),"number | BigNumber, DenseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):p(t,e,r,!0))},h,m({SS:c,DS:s,SD:u}))}),du="rightArithShift",gu=s(du,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:a,concat:o}=e;const s=Sa({typed:t}),u=va({typed:t,equalScalar:n}),c=fu({typed:t,equalScalar:n}),l=Ca({typed:t,DenseMatrix:a}),f=x({typed:t,equalScalar:n}),p=ua({typed:t}),m=B({typed:t,matrix:r,concat:o}),h=pu({typed:t,matrix:r});return t(du,{"number, number":lo,"BigNumber, BigNumber":no,"bigint, bigint":(e,t)=>e>>t,"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():f(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():p(e,t,r,!1)),"number | BigNumber, SparseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):l(t,e,r,!0)),"number | BigNumber, DenseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):p(t,e,r,!0))},h,m({SS:c,DS:s,SD:u}))}),yu="rightLogShift",xu=s(yu,["typed","matrix","equalScalar","zeros","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,zeros:i,DenseMatrix:a,concat:o}=e;const s=Sa({typed:t}),u=va({typed:t,equalScalar:n}),c=fu({typed:t,equalScalar:n}),l=Ca({typed:t,DenseMatrix:a}),f=x({typed:t,equalScalar:n}),p=ua({typed:t}),m=B({typed:t,matrix:r,concat:o}),h=pu({typed:t,matrix:r});return t(yu,{"number, number":fo,"SparseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():f(e,t,r,!1)),"DenseMatrix, number | BigNumber":t.referToSelf(r=>(e,t)=>n(t,0)?e.clone():p(e,t,r,!1)),"number | BigNumber, SparseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):l(t,e,r,!0)),"number | BigNumber, DenseMatrix":t.referToSelf(r=>(e,t)=>n(e,0)?i(t.size(),t.storage()):p(t,e,r,!0))},h,m({SS:c,DS:s,SD:u}))}),bu=s("and",["typed","matrix","equalScalar","zeros","not","concat"],e=>{let{typed:t,matrix:n,equalScalar:r,zeros:i,not:a,concat:o}=e;const s=va({typed:t,equalScalar:r}),u=Ba({typed:t,equalScalar:r}),c=x({typed:t,equalScalar:r}),l=ua({typed:t}),f=B({typed:t,matrix:n,concat:o});return t("and",{"number, number":Mo,"Complex, Complex":function(e,t){return!(0===e.re&&0===e.im||0===t.re&&0===t.im)},"BigNumber, BigNumber":function(e,t){return!(e.isZero()||t.isZero()||e.isNaN()||t.isNaN())},"bigint, bigint":Mo,"Unit, Unit":t.referToSelf(r=>(e,t)=>r(e.value||0,t.value||0)),"SparseMatrix, any":t.referToSelf(r=>(e,t)=>a(t)?i(e.size(),e.storage()):c(e,t,r,!1)),"DenseMatrix, any":t.referToSelf(r=>(e,t)=>a(t)?i(e.size(),e.storage()):l(e,t,r,!1)),"any, SparseMatrix":t.referToSelf(r=>(e,t)=>a(e)?i(e.size(),e.storage()):c(t,e,r,!0)),"any, DenseMatrix":t.referToSelf(r=>(e,t)=>a(e)?i(e.size(),e.storage()):l(t,e,r,!0)),"Array, any":t.referToSelf(r=>(e,t)=>r(n(e),t).valueOf()),"any, Array":t.referToSelf(r=>(e,t)=>r(e,n(t)).valueOf())},f({SS:u,DS:s}))}),vu="compare",wu=s(vu,["typed","config","matrix","equalScalar","BigNumber","Fraction","DenseMatrix","concat"],e=>{let{typed:t,config:r,equalScalar:n,matrix:i,BigNumber:a,Fraction:o,DenseMatrix:s,concat:u}=e;const c=wa({typed:t}),l=Na({typed:t,equalScalar:n}),f=C({typed:t,DenseMatrix:s}),p=B({typed:t,matrix:i,concat:u}),m=ui({typed:t});return t(vu,Nu({typed:t,config:r}),{"boolean, boolean":function(e,t){return e===t?0:t<e?1:-1},"BigNumber, BigNumber":function(e,t){return Jn(e,t,r.relTol,r.absTol)?new a(0):new a(e.cmp(t))},"bigint, bigint":function(e,t){return e===t?0n:t<e?1n:-1n},"Fraction, Fraction":function(e,t){return new o(e.compare(t))},"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},m,p({SS:l,DS:c,Ss:f}))}),Nu=s(vu,["typed","config"],e=>{let{typed:t,config:r}=e;return t(vu,{"number, number":function(e,t){return p(e,t,r.relTol,r.absTol)?0:t<e?1:-1}})});var Eu=kh(1880);const Au="compareNatural",Su=s(Au,["typed","compare"],e=>{let{typed:t,compare:m}=e;const h=m.signatures["boolean,boolean"];return t(Au,{"any, any":function e(t,r){var n=K(t),i=K(r);let a;if(!("number"!==n&&"BigNumber"!==n&&"Fraction"!==n||"number"!==i&&"BigNumber"!==i&&"Fraction"!==i))return"0"!==(a=m(t,r)).toString()?0<a?1:-1:Eu(n,i);const o=["Array","DenseMatrix","SparseMatrix"];if(o.includes(n)||o.includes(i))return 0!==(a=function e(t,r,n){return P(r)&&P(n)?d(t,r.toJSON().values,n.toJSON().values):P(r)?e(t,r.toArray(),n):P(n)?e(t,r,n.toArray()):R(r)?e(t,r.toJSON().data,n):R(n)?e(t,r,n.toJSON().data):Array.isArray(r)?Array.isArray(n)?d(t,r,n):e(t,r,[n]):e(t,[r],n)}(e,t,r))?a:Eu(n,i);if(n!==i)return Eu(n,i);if("Complex"===n)return t.re>r.re?1:t.re<r.re?-1:t.im>r.im?1:t.im<r.im?-1:0;if("Unit"===n)return t.equalBase(r)?e(t.value,r.value):d(e,t.formatUnits(),r.formatUnits());if("boolean"===n)return h(t,r);if("string"===n)return Eu(t,r);if("Object"===n){var s=e,u=t,c=r;const l=Object.keys(u),f=Object.keys(c),p=(l.sort(Eu),f.sort(Eu),d(s,l,f));if(0!==p)return p;for(let e=0;e<l.length;e++){const p=s(u[l[e]],c[f[e]]);if(0!==p)return p}return 0}if("null"===n)return 0;if("undefined"===n)return 0;throw new TypeError('Unsupported type of value "'+n+'"')}});function d(r,n,i){for(let e=0,t=Math.min(n.length,i.length);e<t;e++){var a=r(n[e],i[e]);if(0!==a)return a}return n.length>i.length?1:n.length<i.length?-1:0}}),Mu="compareText",Cu=(pn.signature="any, any",s(Mu,["typed","matrix","concat"],e=>{let{typed:t,matrix:r,concat:n}=e;const i=B({typed:t,matrix:r,concat:n});return t(Mu,pn,i({elop:pn,Ds:!0}))})),Tu="equal",Du=s(Tu,["typed","matrix","equalScalar","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:r,concat:a});return t(Tu,Fu({typed:t,equalScalar:n}),c({elop:n,SS:s,DS:o,Ss:u}))}),Fu=s(Tu,["typed","equalScalar"],e=>{let{typed:t,equalScalar:r}=e;return t(Tu,{"any, any":function(e,t){return null===e?null===t:null===t?null===e:void 0===e?void 0===t:void 0===t?void 0===e:r(e,t)}})}),Bu="equalText",Ou=s(Bu,["typed","compareText","isZero"],e=>{let{typed:t,compareText:r,isZero:n}=e;return t(Bu,{"any, any":function(e,t){return n(r(e,t))}})}),_u="smaller",zu=s(_u,["typed","config","matrix","DenseMatrix","concat"],e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:n,concat:a}),l=ui({typed:t});return t(_u,Iu({typed:t,config:r}),{"boolean, boolean":(e,t)=>e<t,"BigNumber, BigNumber":function(e,t){return e.lt(t)&&!Jn(e,t,r.relTol,r.absTol)},"bigint, bigint":(e,t)=>e<t,"Fraction, Fraction":(e,t)=>-1===e.compare(t),"Complex, Complex":function(e,t){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:o,Ss:u}))}),Iu=s(_u,["typed","config"],e=>{let{typed:t,config:r}=e;return t(_u,{"number, number":function(e,t){return e<t&&!p(e,t,r.relTol,r.absTol)}})}),ku="smallerEq",qu=s(ku,["typed","config","matrix","DenseMatrix","concat"],e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:n,concat:a}),l=ui({typed:t});return t(ku,Ru({typed:t,config:r}),{"boolean, boolean":(e,t)=>e<=t,"BigNumber, BigNumber":function(e,t){return e.lte(t)||Jn(e,t,r.relTol,r.absTol)},"bigint, bigint":(e,t)=>e<=t,"Fraction, Fraction":(e,t)=>1!==e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:o,Ss:u}))}),Ru=s(ku,["typed","config"],e=>{let{typed:t,config:r}=e;return t(ku,{"number, number":function(e,t){return e<=t||p(e,t,r.relTol,r.absTol)}})}),Pu="larger",ju=s(Pu,["typed","config","matrix","DenseMatrix","concat"],e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:n,concat:a}),l=ui({typed:t});return t(Pu,Uu({typed:t,config:r}),{"boolean, boolean":(e,t)=>t<e,"BigNumber, BigNumber":function(e,t){return e.gt(t)&&!Jn(e,t,r.relTol,r.absTol)},"bigint, bigint":(e,t)=>t<e,"Fraction, Fraction":(e,t)=>1===e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:o,Ss:u}))}),Uu=s(Pu,["typed","config"],e=>{let{typed:t,config:r}=e;return t(Pu,{"number, number":function(e,t){return t<e&&!p(e,t,r.relTol,r.absTol)}})}),Lu="largerEq",$u=s(Lu,["typed","config","matrix","DenseMatrix","concat"],e=>{let{typed:t,config:r,matrix:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:n,concat:a}),l=ui({typed:t});return t(Lu,Hu({typed:t,config:r}),{"boolean, boolean":(e,t)=>t<=e,"BigNumber, BigNumber":function(e,t){return e.gte(t)||Jn(e,t,r.relTol,r.absTol)},"bigint, bigint":function(e,t){return t<=e},"Fraction, Fraction":(e,t)=>-1!==e.compare(t),"Complex, Complex":function(){throw new TypeError("No ordering relation is defined for complex numbers")}},l,c({SS:s,DS:o,Ss:u}))}),Hu=s(Lu,["typed","config"],e=>{let{typed:t,config:r}=e;return t(Lu,{"number, number":function(e,t){return t<=e||p(e,t,r.relTol,r.absTol)}})}),Gu="deepEqual",Zu=s(Gu,["typed","equal"],e=>{let{typed:t,equal:i}=e;return t(Gu,{"any, any":function(e,t){return function t(r,n){if(Array.isArray(r)){if(Array.isArray(n)){const i=r.length;if(i!==n.length)return!1;for(let e=0;e<i;e++)if(!t(r[e],n[e]))return!1;return!0}return!1}return!Array.isArray(n)&&i(r,n)}(e.valueOf(),t.valueOf())}})}),Vu="unequal",Wu=s(Vu,["typed","config","equalScalar","matrix","DenseMatrix","concat"],e=>{let{typed:t,equalScalar:r,matrix:n,DenseMatrix:i,concat:a}=e;const o=wa({typed:t}),s=go({typed:t,DenseMatrix:i}),u=C({typed:t,DenseMatrix:i}),c=B({typed:t,matrix:n,concat:a});return t(Vu,Yu({typed:t,equalScalar:r}),c({elop:function(e,t){return!r(e,t)},SS:s,DS:o,Ss:u}))}),Yu=s(Vu,["typed","equalScalar"],e=>{let{typed:t,equalScalar:r}=e;return t(Vu,{"any, any":function(e,t){return null===e?null!==t:null===t?null!==e:void 0===e?void 0!==t:void 0===t?void 0!==e:!r(e,t)}})}),Ju="partitionSelect",Xu=s(Ju,["typed","isNumeric","isNaN","compare"],e=>{let{typed:t,isNumeric:u,isNaN:c,compare:r}=e;const n=r,i=(e,t)=>-r(e,t);return t(Ju,{"Array | Matrix, number":function(e,t){return a(e,t,n)},"Array | Matrix, number, string":function(e,t,r){if("asc"===r)return a(e,t,n);if("desc"===r)return a(e,t,i);throw new Error('Compare string must be "asc" or "desc"')},"Array | Matrix, number, function":a});function a(e,t,r){if(!v(t)||t<0)throw new Error("k must be a non-negative integer");if(_(e)){if(1<e.size().length)throw new Error("Only one dimensional matrices supported");return o(e.valueOf(),t,r)}if(Array.isArray(e))return o(e,t,r)}function o(r,n,i){if(n>=r.length)throw new Error("k out of bounds");for(let e=0;e<r.length;e++)if(u(r[e])&&c(r[e]))return r[e];let a=0,o=r.length-1;for(;a<o;){let e=a,t=o;for(var s=r[Math.floor(Math.random()*(o-a+1))+a];e<t;)if(0<=i(r[e],s)){const n=r[t];r[t]=r[e],r[e]=n,--t}else++e;0<i(r[e],s)&&--e,n<=e?o=e:a=e+1}return r[n]}}),Qu=s("sort",["typed","matrix","compare","compareNatural"],e=>{let{typed:t,matrix:r,compare:n,compareNatural:i}=e;const a=n,o=(e,t)=>-n(e,t);return t("sort",{Array:function(e){return u(e),e.sort(a)},Matrix:function(e){return c(e),r(e.toArray().sort(a),e.storage())},"Array, function":function(e,t){return u(e),e.sort(t)},"Matrix, function":function(e,t){return c(e),r(e.toArray().sort(t),e.storage())},"Array, string":function(e,t){return u(e),e.sort(s(t))},"Matrix, string":function(e,t){return c(e),r(e.toArray().sort(s(t)),e.storage())}});function s(e){if("asc"===e)return a;if("desc"===e)return o;if("natural"===e)return i;throw new Error('String "asc", "desc", or "natural" expected')}function u(e){if(1!==T(e).length)throw new Error("One dimensional array expected")}function c(e){if(1!==e.size().length)throw new Error("One dimensional matrix expected")}}),Ku=s("max",["typed","config","numeric","larger"],e=>{let{typed:t,config:n,numeric:i,larger:a}=e;return t("max",{"Array | Matrix":o,"Array | Matrix, number | BigNumber":function(e,t){return $n(e,t.valueOf(),r)},"...":function(e){if(Un(e))throw new TypeError("Scalar values expected in function max");return o(e)}});function r(e,t){try{return a(e,t)?e:t}catch(e){throw _s(e,"max",t)}}function o(e){let r;if(Ln(e,function(t){try{isNaN(t)&&"number"==typeof t?r=NaN:void 0!==r&&!a(t,r)||(r=t)}catch(e){throw _s(e,"max",t)}}),void 0===r)throw new Error("Cannot calculate max of an empty array");return r="string"==typeof r?i(r,we(r,n)):r}}),ec=s("min",["typed","config","numeric","smaller"],e=>{let{typed:t,config:n,numeric:i,smaller:a}=e;return t("min",{"Array | Matrix":o,"Array | Matrix, number | BigNumber":function(e,t){return $n(e,t.valueOf(),r)},"...":function(e){if(Un(e))throw new TypeError("Scalar values expected in function min");return o(e)}});function r(e,t){try{return a(e,t)?e:t}catch(e){throw _s(e,"min",t)}}function o(e){let r;if(Ln(e,function(t){try{isNaN(t)&&"number"==typeof t?r=NaN:void 0!==r&&!a(t,r)||(r=t)}catch(e){throw _s(e,"min",t)}}),void 0===r)throw new Error("Cannot calculate min of an empty array");return r="string"==typeof r?i(r,we(r,n)):r}}),tc=s("ImmutableDenseMatrix",["smaller","DenseMatrix"],e=>{let{smaller:r,DenseMatrix:n}=e;function i(e,t){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");if(t&&!k(t))throw new Error("Invalid datatype: "+t);if(_(e)||g(e)){const i=new n(e,t);this._data=i._data,this._size=i._size,this._datatype=i._datatype,this._min=null,this._max=null}else if(e&&g(e.data)&&g(e.size))this._data=e.data,this._size=e.size,this._datatype=e.datatype,this._min=void 0!==e.min?e.min:null,this._max=void 0!==e.max?e.max:null;else{if(e)throw new TypeError("Unsupported type of data ("+K(e)+")");this._data=[],this._size=[0],this._datatype=t,this._min=null,this._max=null}}return i.prototype=new n,i.prototype.type="ImmutableDenseMatrix",i.prototype.isImmutableDenseMatrix=!0,i.prototype.subset=function(e){switch(arguments.length){case 1:var t=n.prototype.subset.call(this,e);return _(t)?new i({data:t._data,size:t._size,datatype:t._datatype}):t;case 2:case 3:throw new Error("Cannot invoke set subset on an Immutable Matrix instance");default:throw new SyntaxError("Wrong number of arguments")}},i.prototype.set=function(){throw new Error("Cannot invoke set on an Immutable Matrix instance")},i.prototype.resize=function(){throw new Error("Cannot invoke resize on an Immutable Matrix instance")},i.prototype.reshape=function(){throw new Error("Cannot invoke reshape on an Immutable Matrix instance")},i.prototype.clone=function(){return new i({data:ee(this._data),size:ee(this._size),datatype:this._datatype})},i.prototype.toJSON=function(){return{mathjs:"ImmutableDenseMatrix",data:this._data,size:this._size,datatype:this._datatype}},i.fromJSON=function(e){return new i(e)},i.prototype.swapRows=function(){throw new Error("Cannot invoke swapRows on an Immutable Matrix instance")},i.prototype.min=function(){if(null===this._min){let t=null;this.forEach(function(e){null!==t&&!r(e,t)||(t=e)}),this._min=null!==t?t:void 0}return this._min},i.prototype.max=function(){if(null===this._max){let t=null;this.forEach(function(e){null!==t&&!r(t,e)||(t=e)}),this._max=null!==t?t:void 0}return this._max},i},{isClass:!0}),rc=s("Index",["ImmutableDenseMatrix","getMatrixDataType"],e=>{let{ImmutableDenseMatrix:t,getMatrixDataType:a}=e;function o(e){if(!(this instanceof o))throw new SyntaxError("Constructor must be called with the new operator");this._dimensions=[],this._sourceSize=[],this._isScalar=!0;for(let e=0,t=arguments.length;e<t;e++){const n=arguments[e],o=g(n),i=_(n);let t=null;if(h(n))this._dimensions.push(n),this._isScalar=!1;else if(o||i){let e;"boolean"===a(n)?(o&&(e=s(nc(n).valueOf())),i&&(e=s(nc(n._data).valueOf())),t=n.valueOf().length):e=s(n.valueOf()),this._dimensions.push(e);var r=e.size();1===r.length&&1===r[0]&&null===t||(this._isScalar=!1)}else if("number"==typeof n)this._dimensions.push(s([n]));else{if("string"!=typeof n)throw new TypeError("Dimension must be an Array, Matrix, number, string, or Range");this._dimensions.push(n)}this._sourceSize.push(t)}}function s(r){for(let e=0,t=r.length;e<t;e++)if("number"!=typeof r[e]||!v(r[e]))throw new TypeError("Index parameters must be positive integer numbers");return new t(r)}return o.prototype.type="Index",o.prototype.isIndex=!0,o.prototype.clone=function(){const e=new o;return e._dimensions=ee(this._dimensions),e._isScalar=this._isScalar,e._sourceSize=this._sourceSize,e},o.create=function(e){var t=new o;return o.apply(t,e),t},o.prototype.size=function(){const r=[];for(let e=0,t=this._dimensions.length;e<t;e++){const n=this._dimensions[e];r[e]="string"==typeof n?1:n.size()[0]}return r},o.prototype.max=function(){const r=[];for(let e=0,t=this._dimensions.length;e<t;e++){const n=this._dimensions[e];r[e]="string"==typeof n?n:n.max()}return r},o.prototype.min=function(){const r=[];for(let e=0,t=this._dimensions.length;e<t;e++){const n=this._dimensions[e];r[e]="string"==typeof n?n:n.min()}return r},o.prototype.forEach=function(r){for(let e=0,t=this._dimensions.length;e<t;e++)r(this._dimensions[e],e,this)},o.prototype.dimension=function(e){return this._dimensions[e]||null},o.prototype.isObjectProperty=function(){return 1===this._dimensions.length&&"string"==typeof this._dimensions[0]},o.prototype.getObjectProperty=function(){return this.isObjectProperty()?this._dimensions[0]:null},o.prototype.isScalar=function(){return this._isScalar},o.prototype.toArray=function(){const r=[];for(let e=0,t=this._dimensions.length;e<t;e++){const n=this._dimensions[e];r.push("string"==typeof n?n:n.toArray())}return r},o.prototype.valueOf=o.prototype.toArray,o.prototype.toString=function(){const r=[];for(let e=0,t=this._dimensions.length;e<t;e++){const n=this._dimensions[e];"string"==typeof n?r.push(JSON.stringify(n)):r.push(n.toString())}return"["+r.join(", ")+"]"},o.prototype.toJSON=function(){return{mathjs:"Index",dimensions:this._dimensions}},o.fromJSON=function(e){return o.create(e.dimensions)},o},{isClass:!0});function nc(e){const r=[];return e.forEach((e,t)=>{e&&r.push(t)}),r}const ic=s("FibonacciHeap",["smaller","larger"],e=>{let{smaller:s,larger:u}=e;const c=1/Math.log((1+Math.sqrt(5))/2);function t(){if(!(this instanceof t))throw new SyntaxError("Constructor must be called with the new operator");this._minimum=null,this._size=0}function i(e,t,r){t.left.right=t.right,t.right.left=t.left,r.degree--,r.child===t&&(r.child=t.right),0===r.degree&&(r.child=null),t.left=e,t.right=e.right,((e.right=t).right.left=t).parent=null,t.mark=!1}t.prototype.type="FibonacciHeap",t.prototype.isFibonacciHeap=!0,t.prototype.insert=function(e,t){const r={key:e,value:t,degree:0};if(this._minimum){const t=this._minimum;r.left=t,r.right=t.right,(t.right=r).right.left=r,s(e,t.key)&&(this._minimum=r)}else(r.left=r).right=r,this._minimum=r;return this._size++,r},t.prototype.size=function(){return this._size},t.prototype.clear=function(){this._minimum=null,this._size=0},t.prototype.isEmpty=function(){return 0===this._size},t.prototype.extractMinimum=function(){const e=this._minimum;if(null===e)return e;let t=this._minimum,r=e.degree,n=e.child;for(;0<r;){const e=n.right;n.left.right=n.right,n.right.left=n.left,n.left=t,n.right=t.right,((t.right=n).right.left=n).parent=null,n=e,r--}return e.left.right=e.right,e.right.left=e.left,t=e===e.right?null:function(t,e){const r=Math.floor(Math.log(e)*c)+1,n=new Array(r);let i,a=0,o=t;if(o)for(a++,o=o.right;o!==t;)a++,o=o.right;for(;0<a;){let e=o.degree;const s=o.right;for(;i=n[e];){if(u(o.key,i.key)){const t=i;i=o,o=t}l(i,o),n[e]=null,e++}n[e]=o,o=s,a--}t=null;for(let e=0;e<r;e++)(i=n[e])&&(t?(i.left.right=i.right,i.right.left=i.left,i.left=t,i.right=t.right,(t.right=i).right.left=i,s(i.key,t.key)&&(t=i)):t=i);return t}(t=e.right,this._size),this._size--,this._minimum=t,e},t.prototype.remove=function(e){var t,r;this._minimum=(t=this._minimum,(e=e).key=-1,(r=e.parent)&&s(e.key,r.key)&&(i(t,e,r),function e(t,r){var n=r.parent;n&&(r.mark?(i(t,r,n),e(n)):r.mark=!0)}(t,r)),t=s(e.key,t.key)?e:t),this.extractMinimum()};const l=function(e,t){e.left.right=e.right,e.right.left=e.left,(e.parent=t).child?(e.left=t.child,e.right=t.child.right,(t.child.right=e).right.left=e):((t.child=e).right=e).left=e,t.degree++,e.mark=!1};return t},{isClass:!0}),ac=s("Spa",["addScalar","equalScalar","FibonacciHeap"],e=>{let{addScalar:n,equalScalar:s,FibonacciHeap:t}=e;function r(){if(!(this instanceof r))throw new SyntaxError("Constructor must be called with the new operator");this._values=[],this._heap=new t}return r.prototype.type="Spa",r.prototype.isSpa=!0,r.prototype.set=function(e,t){this._values[e]?this._values[e].value=t:(t=this._heap.insert(e,t),this._values[e]=t)},r.prototype.get=function(e){e=this._values[e];return e?e.value:0},r.prototype.accumulate=function(e,t){let r=this._values[e];r?r.value=n(r.value,t):(r=this._heap.insert(e,t),this._values[e]=r)},r.prototype.forEach=function(e,t,r){const n=this._heap,i=this._values,a=[];let o=n.extractMinimum();for(o&&a.push(o);o&&o.key<=t;)o.key>=e&&(s(o.value,0)||r(o.key,o.value,this)),(o=n.extractMinimum())&&a.push(o);for(let e=0;e<a.length;e++){const t=a[e];o=n.insert(t.key,t.value),i[o.key]=o}},r.prototype.swap=function(e,t){let r=this._values[e],n=this._values[t];if(!r&&n)r=this._heap.insert(e,n.value),this._heap.remove(n),this._values[e]=r,this._values[t]=void 0;else if(r&&!n)n=this._heap.insert(t,r.value),this._heap.remove(r),this._values[t]=n,this._values[e]=void 0;else if(r&&n){const e=r.value;r.value=n.value,n.value=e}},r},{isClass:!0}),oc=kn(function(e){return new e(1).exp()},{hasher:lc}),sc=kn(function(e){return new e(1).plus(new e(5).sqrt()).div(2)},{hasher:lc}),uc=kn(function(e){return e.acos(-1)},{hasher:lc}),cc=kn(function(e){return uc(e).times(2)},{hasher:lc});function lc(e){return e[0].precision}const fc=s("Unit",["?on","config","addScalar","subtractScalar","multiplyScalar","divideScalar","pow","abs","fix","round","equal","isNumeric","format","number","Complex","BigNumber","Fraction"],e=>{let{on:t,config:l,addScalar:u,subtractScalar:c,multiplyScalar:f,divideScalar:o,pow:s,abs:p,fix:m,round:h,equal:d,isNumeric:r,format:k,number:n,Complex:q,BigNumber:g,Fraction:y}=e;const R=n;function x(e,t){if(!(this instanceof x))throw new Error("Constructor must be called with the new operator");if(null!=e&&!r(e)&&!te(e))throw new TypeError("First parameter in Unit constructor must be number, BigNumber, Fraction, Complex, or undefined");if(this.fixPrefix=!1,this.skipAutomaticSimplification=!0,void 0===t)this.units=[],this.dimensions=D.map(e=>0);else if("string"==typeof t){const e=x.parse(t);this.units=e.units,this.dimensions=e.dimensions}else{if(!L(t)||null!==t.value)throw new TypeError("Second parameter in Unit constructor must be a string or valueless Unit");this.fixPrefix=t.fixPrefix,this.skipAutomaticSimplification=t.skipAutomaticSimplification,this.dimensions=t.dimensions.slice(0),this.units=t.units.map(e=>an({},e))}this.value=this._normalize(e)}let b,v,w;function N(){for(;" "===w||"\t"===w;)A()}function E(e){return"0"<=e&&e<="9"}function A(){v++,w=b.charAt(v)}function i(e){v=e,w=b.charAt(v)}function S(){let t="";var e=v;if("+"===w?A():"-"===w&&(t+=w,A()),!("0"<=(r=w)&&r<="9"||"."===r))return i(e),null;if("."===w){if(t+=w,A(),!E(w))return i(e),null}else{for(;E(w);)t+=w,A();"."===w&&(t+=w,A())}for(;E(w);)t+=w,A();if("E"===w||"e"===w){let e="";var r=v;if(e+=w,A(),"+"!==w&&"-"!==w||(e+=w,A()),!E(w))return i(r),t;for(t+=e;E(w);)t+=w,A()}return t}function M(e){return w===e&&(A(),e)}Object.defineProperty(x,"name",{value:"Unit"}),(x.prototype.constructor=x).prototype.type="Unit",x.prototype.isUnit=!0,x.parse=function(e,r){if(r=r||{},b=e,v=-1,w="","string"!=typeof b)throw new TypeError("Invalid argument in Unit.parse, string expected");const n=new x;let i=1,a=!(n.units=[]);A(),N();var o,t=S();let s=null;if(t){if("BigNumber"===l.number)s=new g(t);else if("Fraction"===l.number)try{s=new y(t)}catch(e){s=parseFloat(t)}else s=parseFloat(t);N(),M("*")?(i=1,a=!0):M("/")&&(i=-1,a=!0)}const u=[];let c=1;for(;;){for(N();"("===w;)u.push(i),c*=i,i=1,A(),N();if(!w)break;{const e=w;if(null===(o=function(){let e="";for(;E(w)||x.isValidAlpha(w);)e+=w,A();var t=e.charAt(0);return x.isValidAlpha(t)?e:null}()))throw new SyntaxError('Unexpected "'+e+'" in "'+b+'" at index '+v.toString())}const l=C(o);if(null===l)throw new SyntaxError('Unit "'+o+'" not found.');let t=i*c;if(N(),M("^")){N();const r=S();if(null===r)throw new SyntaxError('In "'+e+'", "^" must be followed by a floating-point number');t*=r}n.units.push({unit:l.unit,prefix:l.prefix,power:t});for(let e=0;e<D.length;e++)n.dimensions[e]+=(l.unit.dimensions[e]||0)*t;for(N();")"===w;){if(0===u.length)throw new SyntaxError('Unmatched ")" in "'+b+'" at index '+v.toString());c/=u.pop(),A(),N()}if(a=!1,M("*")?(i=1,a=!0):M("/")?(i=-1,a=!0):i=1,l.unit.base){const e=l.unit.base.key;z.auto[e]={unit:l.unit,prefix:l.prefix}}}if(N(),w)throw new SyntaxError('Could not parse: "'+e+'"');if(a)throw new SyntaxError('Trailing characters: "'+e+'"');if(0!==u.length)throw new SyntaxError('Unmatched "(" in "'+b+'"');if(0!==n.units.length||r.allowNoUnits)return n.value=void 0!==s?n._normalize(s):null,n;throw new SyntaxError('"'+e+'" contains no units')},x.prototype.clone=function(){const t=new x;t.fixPrefix=this.fixPrefix,t.skipAutomaticSimplification=this.skipAutomaticSimplification,t.value=ee(this.value),t.dimensions=this.dimensions.slice(0),t.units=[];for(let e=0;e<this.units.length;e++){t.units[e]={};for(const r in this.units[e])ue(this.units[e],r)&&(t.units[e][r]=this.units[e][r])}return t},x.prototype.valueType=function(){return K(this.value)},x.prototype._isDerived=function(){return 0!==this.units.length&&(1<this.units.length||1e-15<Math.abs(this.units[0].power-1))},x.prototype._normalize=function(e){if(null==e||0===this.units.length)return e;let t=e;const r=x._getNumberConverter(K(e));for(let e=0;e<this.units.length;e++){var n=r(this.units[e].unit.value),i=r(this.units[e].prefix.value),a=r(this.units[e].power);t=f(t,s(f(n,i),a))}return t},x.prototype._denormalize=function(e,t){if(null==e||0===this.units.length)return e;let r=e;const n=x._getNumberConverter(K(e));for(let e=0;e<this.units.length;e++){const t=n(this.units[e].unit.value),i=n(this.units[e].prefix.value),a=n(this.units[e].power);r=o(r,s(f(t,i),a))}return r};const C=kn(e=>{var t;if(ue(B,e))return{unit:t=B[e],prefix:t.prefixes[""]};for(const o in B)if(ue(B,o)&&(r=e,a=o,n=void 0,i=void 0,n=r.length-a.length,i=r.length,r.substring(n,i)===a)){var r=B[o],n=e.length-o.length,i=e.substring(0,n),a=ue(r.prefixes,i)?r.prefixes[i]:void 0;if(void 0!==a)return{unit:r,prefix:a}}return null},{hasher:e=>e[0],limit:100});function a(e){return e.equalBase(F.NONE)&&null!==e.value&&!l.predictable?e.value:e}x.isValuelessUnit=function(e){return null!==C(e)},x.prototype.hasBase=function(t){if(!(t="string"==typeof t?F[t]:t))return!1;for(let e=0;e<D.length;e++)if(1e-12<Math.abs((this.dimensions[e]||0)-(t.dimensions[e]||0)))return!1;return!0},x.prototype.equalBase=function(t){for(let e=0;e<D.length;e++)if(1e-12<Math.abs((this.dimensions[e]||0)-(t.dimensions[e]||0)))return!1;return!0},x.prototype.equals=function(e){return this.equalBase(e)&&d(this.value,e.value)},x.prototype.multiply=function(e){const t=this.clone(),r=L(e)?e:new x(e);for(let e=0;e<D.length;e++)t.dimensions[e]=(this.dimensions[e]||0)+(r.dimensions[e]||0);for(let e=0;e<r.units.length;e++){var n={...r.units[e]};t.units.push(n)}if(null!==this.value||null!==r.value){const e=null===this.value?this._normalize(1):this.value,i=null===r.value?r._normalize(1):r.value;t.value=f(e,i)}else t.value=null;return L(e)&&(t.skipAutomaticSimplification=!1),a(t)},x.prototype.divideInto=function(e){return new x(e).divide(this)},x.prototype.divide=function(e){const t=this.clone(),r=L(e)?e:new x(e);for(let e=0;e<D.length;e++)t.dimensions[e]=(this.dimensions[e]||0)-(r.dimensions[e]||0);for(let e=0;e<r.units.length;e++){var n={...r.units[e],power:-r.units[e].power};t.units.push(n)}if(null!==this.value||null!==r.value){const e=null===this.value?this._normalize(1):this.value,i=null===r.value?r._normalize(1):r.value;t.value=o(e,i)}else t.value=null;return L(e)&&(t.skipAutomaticSimplification=!1),a(t)},x.prototype.pow=function(t){const r=this.clone();for(let e=0;e<D.length;e++)r.dimensions[e]=(this.dimensions[e]||0)*t;for(let e=0;e<r.units.length;e++)r.units[e].power*=t;return null!==r.value?r.value=s(r.value,t):r.value=null,r.skipAutomaticSimplification=!1,a(r)},x.prototype.abs=function(){const e=this.clone();if(null!==e.value)if(e._isDerived()||0===e.units.length||0===e.units[0].unit.offset)e.value=p(e.value);else{const t=e._numberConverter(),r=t(e.units[0].unit.value),n=t(e.units[0].unit.offset),i=f(r,n);e.value=c(p(u(e.value,i)),i)}for(const a in e.units)"VA"!==e.units[a].unit.name&&"VAR"!==e.units[a].unit.name||(e.units[a].unit=B.W);return e},x.prototype.to=function(e){var t=null===this.value?this._normalize(1):this.value;let r;if("string"==typeof e)r=x.parse(e);else{if(!L(e))throw new Error("String or Unit expected as parameter");r=e.clone()}if(!this.equalBase(r))throw new Error(`Units do not match ('${r.toString()}' != '${this.toString()}')`);if(null!==r.value)throw new Error("Cannot convert to a unit with a value");if(null===this.value||this._isDerived()||0===this.units.length||0===r.units.length||this.units[0].unit.offset===r.units[0].unit.offset)r.value=ee(t);else{const e=x._getNumberConverter(K(t)),n=this.units[0].unit.value,i=this.units[0].unit.offset,L=f(n,i),a=r.units[0].unit.value,o=r.units[0].unit.offset,s=f(a,o);r.value=u(t,e(c(L,s)))}return r.fixPrefix=!0,r.skipAutomaticSimplification=!0,r},x.prototype.toNumber=function(e){return R(this.toNumeric(e))},x.prototype.toNumeric=function(e){let t;return(t=e?this.to(e):this.clone())._isDerived()||0===t.units.length?t._denormalize(t.value):t._denormalize(t.value,t.units[0].prefix.value)},x.prototype.toString=function(){return this.format()},x.prototype.toJSON=function(){return{mathjs:"Unit",value:this._denormalize(this.value),unit:0<this.units.length?this.formatUnits():null,fixPrefix:this.fixPrefix}},x.fromJSON=function(e){var t;const r=new x(e.value,null!=(t=e.unit)?t:void 0);return r.fixPrefix=e.fixPrefix||!1,r},x.prototype.valueOf=x.prototype.toString,x.prototype.simplify=function(){const r=this.clone(),n=[];let t;for(const n in I)if(ue(I,n)&&r.hasBase(F[n])){t=n;break}if("NONE"===t)r.units=[];else{let e;if(e=t&&ue(I,t)?I[t]:e)r.units=[{unit:e.unit,prefix:e.prefix,power:1}];else{let t=!1;for(let e=0;e<D.length;e++){var i=D[e];1e-12<Math.abs(r.dimensions[e]||0)&&(ue(I,i)?n.push({unit:I[i].unit,prefix:I[i].prefix,power:r.dimensions[e]||0}):t=!0)}n.length<r.units.length&&!t&&(r.units=n)}}return r},x.prototype.toSI=function(){const t=this.clone(),r=[];for(let e=0;e<D.length;e++){var n=D[e];if(1e-12<Math.abs(t.dimensions[e]||0)){if(!ue(z.si,n))throw new Error("Cannot express custom unit "+n+" in SI units");r.push({unit:z.si[n].unit,prefix:z.si[n].prefix,power:t.dimensions[e]||0})}}return t.units=r,t.fixPrefix=!0,t.skipAutomaticSimplification=!0,null!==this.value?(t.value=null,this.to(t)):t},x.prototype.formatUnits=function(){let t="",r="",n=0,i=0;for(let e=0;e<this.units.length;e++)0<this.units[e].power?(n++,t+=" "+this.units[e].prefix.name+this.units[e].unit.name,1e-15<Math.abs(this.units[e].power-1)&&(t+="^"+this.units[e].power)):this.units[e].power<0&&i++;if(0<i)for(let e=0;e<this.units.length;e++)this.units[e].power<0&&(0<n?(r+=" "+this.units[e].prefix.name+this.units[e].unit.name,1e-15<Math.abs(this.units[e].power+1)&&(r+="^"+-this.units[e].power)):r=(r+=" "+this.units[e].prefix.name+this.units[e].unit.name)+("^"+this.units[e].power));t=t.substr(1),r=r.substr(1),1<n&&0<i&&(t="("+t+")"),1<i&&0<n&&(r="("+r+")");let e=t;return 0<n&&0<i&&(e+=" / "),e+=r},x.prototype.format=function(e){const t=this.skipAutomaticSimplification||null===this.value?this.clone():this.simplify();let r=!1;void 0!==t.value&&null!==t.value&&te(t.value)&&(r=Math.abs(t.value.re)<1e-14);for(const e in t.units)ue(t.units,e)&&t.units[e].unit&&("VA"===t.units[e].unit.name&&r?t.units[e].unit=B.VAR:"VAR"!==t.units[e].unit.name||r||(t.units[e].unit=B.VA));1!==t.units.length||t.fixPrefix||Math.abs(t.units[0].power-Math.round(t.units[0].power))<1e-14&&(t.units[0].prefix=t._bestPrefix());var n=t._denormalize(t.value);let i=null!==t.value?k(n,e||{}):"";n=t.formatUnits();return t.value&&te(t.value)&&(i="("+i+")"),0<n.length&&0<i.length&&(i+=" "),i+=n},x.prototype._bestPrefix=function(){if(1!==this.units.length)throw new Error("Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!");if(1e-14<=Math.abs(this.units[0].power-Math.round(this.units[0].power)))throw new Error("Can only compute the best prefix for single units with integer powers, like kg, s^2, N^-1, and so forth!");var e=null!==this.value?p(this.value):0,t=p(this.units[0].unit.value);let r=this.units[0].prefix;if(0===e)return r;var n=this.units[0].power;let i=Math.log(e/Math.pow(r.value*t,n))/Math.LN10-1.2;if(-2.200001<i&&i<1.800001)return r;i=Math.abs(i);const a=this.units[0].unit.prefixes;for(const s in a)if(ue(a,s)){var o=a[s];if(o.scientific){const a=Math.abs(Math.log(e/Math.pow(o.value*t,n))/Math.LN10-1.2);(a<i||a===i&&o.name.length<r.name.length)&&(r=o,i=a)}}return r};const T={NONE:{"":{name:"",value:1,scientific:!0}},SHORT:{"":{name:"",value:1,scientific:!0},da:{name:"da",value:10,scientific:!(x.prototype.splitUnit=function(t){let r=this.clone();const n=[];for(let e=0;e<t.length&&(r=r.to(t[e]),e!==t.length-1);e++){const a=r.toNumeric(),o=h(a);var i=new x(d(o,a)?o:m(r.toNumeric()),t[e].toString());n.push(i),r=c(r,i)}let a=0;for(let e=0;e<n.length;e++)a=u(a,n[e].value);return d(a,this.value)&&(r.value=0),n.push(r),n})},h:{name:"h",value:100,scientific:!1},k:{name:"k",value:1e3,scientific:!0},M:{name:"M",value:1e6,scientific:!0},G:{name:"G",value:1e9,scientific:!0},T:{name:"T",value:1e12,scientific:!0},P:{name:"P",value:1e15,scientific:!0},E:{name:"E",value:1e18,scientific:!0},Z:{name:"Z",value:1e21,scientific:!0},Y:{name:"Y",value:1e24,scientific:!0},R:{name:"R",value:1e27,scientific:!0},Q:{name:"Q",value:1e30,scientific:!0},d:{name:"d",value:.1,scientific:!1},c:{name:"c",value:.01,scientific:!1},m:{name:"m",value:.001,scientific:!0},u:{name:"u",value:1e-6,scientific:!0},n:{name:"n",value:1e-9,scientific:!0},p:{name:"p",value:1e-12,scientific:!0},f:{name:"f",value:1e-15,scientific:!0},a:{name:"a",value:1e-18,scientific:!0},z:{name:"z",value:1e-21,scientific:!0},y:{name:"y",value:1e-24,scientific:!0},r:{name:"r",value:1e-27,scientific:!0},q:{name:"q",value:1e-30,scientific:!0}},LONG:{"":{name:"",value:1,scientific:!0},deca:{name:"deca",value:10,scientific:!1},hecto:{name:"hecto",value:100,scientific:!1},kilo:{name:"kilo",value:1e3,scientific:!0},mega:{name:"mega",value:1e6,scientific:!0},giga:{name:"giga",value:1e9,scientific:!0},tera:{name:"tera",value:1e12,scientific:!0},peta:{name:"peta",value:1e15,scientific:!0},exa:{name:"exa",value:1e18,scientific:!0},zetta:{name:"zetta",value:1e21,scientific:!0},yotta:{name:"yotta",value:1e24,scientific:!0},ronna:{name:"ronna",value:1e27,scientific:!0},quetta:{name:"quetta",value:1e30,scientific:!0},deci:{name:"deci",value:.1,scientific:!1},centi:{name:"centi",value:.01,scientific:!1},milli:{name:"milli",value:.001,scientific:!0},micro:{name:"micro",value:1e-6,scientific:!0},nano:{name:"nano",value:1e-9,scientific:!0},pico:{name:"pico",value:1e-12,scientific:!0},femto:{name:"femto",value:1e-15,scientific:!0},atto:{name:"atto",value:1e-18,scientific:!0},zepto:{name:"zepto",value:1e-21,scientific:!0},yocto:{name:"yocto",value:1e-24,scientific:!0},ronto:{name:"ronto",value:1e-27,scientific:!0},quecto:{name:"quecto",value:1e-30,scientific:!0}},SQUARED:{"":{name:"",value:1,scientific:!0},da:{name:"da",value:100,scientific:!1},h:{name:"h",value:1e4,scientific:!1},k:{name:"k",value:1e6,scientific:!0},M:{name:"M",value:1e12,scientific:!0},G:{name:"G",value:1e18,scientific:!0},T:{name:"T",value:1e24,scientific:!0},P:{name:"P",value:1e30,scientific:!0},E:{name:"E",value:1e36,scientific:!0},Z:{name:"Z",value:1e42,scientific:!0},Y:{name:"Y",value:1e48,scientific:!0},R:{name:"R",value:1e54,scientific:!0},Q:{name:"Q",value:1e60,scientific:!0},d:{name:"d",value:.01,scientific:!1},c:{name:"c",value:1e-4,scientific:!1},m:{name:"m",value:1e-6,scientific:!0},u:{name:"u",value:1e-12,scientific:!0},n:{name:"n",value:1e-18,scientific:!0},p:{name:"p",value:1e-24,scientific:!0},f:{name:"f",value:1e-30,scientific:!0},a:{name:"a",value:1e-36,scientific:!0},z:{name:"z",value:1e-42,scientific:!0},y:{name:"y",value:1e-48,scientific:!0},r:{name:"r",value:1e-54,scientific:!0},q:{name:"q",value:1e-60,scientific:!0}},CUBIC:{"":{name:"",value:1,scientific:!0},da:{name:"da",value:1e3,scientific:!1},h:{name:"h",value:1e6,scientific:!1},k:{name:"k",value:1e9,scientific:!0},M:{name:"M",value:1e18,scientific:!0},G:{name:"G",value:1e27,scientific:!0},T:{name:"T",value:1e36,scientific:!0},P:{name:"P",value:1e45,scientific:!0},E:{name:"E",value:1e54,scientific:!0},Z:{name:"Z",value:1e63,scientific:!0},Y:{name:"Y",value:1e72,scientific:!0},R:{name:"R",value:1e81,scientific:!0},Q:{name:"Q",value:1e90,scientific:!0},d:{name:"d",value:.001,scientific:!1},c:{name:"c",value:1e-6,scientific:!1},m:{name:"m",value:1e-9,scientific:!0},u:{name:"u",value:1e-18,scientific:!0},n:{name:"n",value:1e-27,scientific:!0},p:{name:"p",value:1e-36,scientific:!0},f:{name:"f",value:1e-45,scientific:!0},a:{name:"a",value:1e-54,scientific:!0},z:{name:"z",value:1e-63,scientific:!0},y:{name:"y",value:1e-72,scientific:!0},r:{name:"r",value:1e-81,scientific:!0},q:{name:"q",value:1e-90,scientific:!0}},BINARY_SHORT_SI:{"":{name:"",value:1,scientific:!0},k:{name:"k",value:1e3,scientific:!0},M:{name:"M",value:1e6,scientific:!0},G:{name:"G",value:1e9,scientific:!0},T:{name:"T",value:1e12,scientific:!0},P:{name:"P",value:1e15,scientific:!0},E:{name:"E",value:1e18,scientific:!0},Z:{name:"Z",value:1e21,scientific:!0},Y:{name:"Y",value:1e24,scientific:!0}},BINARY_SHORT_IEC:{"":{name:"",value:1,scientific:!0},Ki:{name:"Ki",value:1024,scientific:!0},Mi:{name:"Mi",value:Math.pow(1024,2),scientific:!0},Gi:{name:"Gi",value:Math.pow(1024,3),scientific:!0},Ti:{name:"Ti",value:Math.pow(1024,4),scientific:!0},Pi:{name:"Pi",value:Math.pow(1024,5),scientific:!0},Ei:{name:"Ei",value:Math.pow(1024,6),scientific:!0},Zi:{name:"Zi",value:Math.pow(1024,7),scientific:!0},Yi:{name:"Yi",value:Math.pow(1024,8),scientific:!0}},BINARY_LONG_SI:{"":{name:"",value:1,scientific:!0},kilo:{name:"kilo",value:1e3,scientific:!0},mega:{name:"mega",value:1e6,scientific:!0},giga:{name:"giga",value:1e9,scientific:!0},tera:{name:"tera",value:1e12,scientific:!0},peta:{name:"peta",value:1e15,scientific:!0},exa:{name:"exa",value:1e18,scientific:!0},zetta:{name:"zetta",value:1e21,scientific:!0},yotta:{name:"yotta",value:1e24,scientific:!0}},BINARY_LONG_IEC:{"":{name:"",value:1,scientific:!0},kibi:{name:"kibi",value:1024,scientific:!0},mebi:{name:"mebi",value:Math.pow(1024,2),scientific:!0},gibi:{name:"gibi",value:Math.pow(1024,3),scientific:!0},tebi:{name:"tebi",value:Math.pow(1024,4),scientific:!0},pebi:{name:"pebi",value:Math.pow(1024,5),scientific:!0},exi:{name:"exi",value:Math.pow(1024,6),scientific:!0},zebi:{name:"zebi",value:Math.pow(1024,7),scientific:!0},yobi:{name:"yobi",value:Math.pow(1024,8),scientific:!0}},BTU:{"":{name:"",value:1,scientific:!0},MM:{name:"MM",value:1e6,scientific:!0}}},D=(T.SHORTLONG=an({},T.SHORT,T.LONG),T.BINARY_SHORT=an({},T.BINARY_SHORT_SI,T.BINARY_SHORT_IEC),T.BINARY_LONG=an({},T.BINARY_LONG_SI,T.BINARY_LONG_IEC),["MASS","LENGTH","TIME","CURRENT","TEMPERATURE","LUMINOUS_INTENSITY","AMOUNT_OF_SUBSTANCE","ANGLE","BIT"]),F={NONE:{dimensions:[0,0,0,0,0,0,0,0,0]},MASS:{dimensions:[1,0,0,0,0,0,0,0,0]},LENGTH:{dimensions:[0,1,0,0,0,0,0,0,0]},TIME:{dimensions:[0,0,1,0,0,0,0,0,0]},CURRENT:{dimensions:[0,0,0,1,0,0,0,0,0]},TEMPERATURE:{dimensions:[0,0,0,0,1,0,0,0,0]},LUMINOUS_INTENSITY:{dimensions:[0,0,0,0,0,1,0,0,0]},AMOUNT_OF_SUBSTANCE:{dimensions:[0,0,0,0,0,0,1,0,0]},FORCE:{dimensions:[1,1,-2,0,0,0,0,0,0]},SURFACE:{dimensions:[0,2,0,0,0,0,0,0,0]},VOLUME:{dimensions:[0,3,0,0,0,0,0,0,0]},ENERGY:{dimensions:[1,2,-2,0,0,0,0,0,0]},POWER:{dimensions:[1,2,-3,0,0,0,0,0,0]},PRESSURE:{dimensions:[1,-1,-2,0,0,0,0,0,0]},ELECTRIC_CHARGE:{dimensions:[0,0,1,1,0,0,0,0,0]},ELECTRIC_CAPACITANCE:{dimensions:[-1,-2,4,2,0,0,0,0,0]},ELECTRIC_POTENTIAL:{dimensions:[1,2,-3,-1,0,0,0,0,0]},ELECTRIC_RESISTANCE:{dimensions:[1,2,-3,-2,0,0,0,0,0]},ELECTRIC_INDUCTANCE:{dimensions:[1,2,-2,-2,0,0,0,0,0]},ELECTRIC_CONDUCTANCE:{dimensions:[-1,-2,3,2,0,0,0,0,0]},MAGNETIC_FLUX:{dimensions:[1,2,-2,-1,0,0,0,0,0]},MAGNETIC_FLUX_DENSITY:{dimensions:[1,0,-2,-1,0,0,0,0,0]},FREQUENCY:{dimensions:[0,0,-1,0,0,0,0,0,0]},ANGLE:{dimensions:[0,0,0,0,0,0,0,1,0]},BIT:{dimensions:[0,0,0,0,0,0,0,0,1]}};for(const e in F)ue(F,e)&&(F[e].key=e);const P={name:"",base:{},value:1,offset:0,dimensions:D.map(e=>0)},B={meter:{name:"meter",base:F.LENGTH,prefixes:T.LONG,value:1,offset:0},inch:{name:"inch",base:F.LENGTH,prefixes:T.NONE,value:.0254,offset:0},foot:{name:"foot",base:F.LENGTH,prefixes:T.NONE,value:.3048,offset:0},yard:{name:"yard",base:F.LENGTH,prefixes:T.NONE,value:.9144,offset:0},mile:{name:"mile",base:F.LENGTH,prefixes:T.NONE,value:1609.344,offset:0},link:{name:"link",base:F.LENGTH,prefixes:T.NONE,value:.201168,offset:0},rod:{name:"rod",base:F.LENGTH,prefixes:T.NONE,value:5.0292,offset:0},chain:{name:"chain",base:F.LENGTH,prefixes:T.NONE,value:20.1168,offset:0},angstrom:{name:"angstrom",base:F.LENGTH,prefixes:T.NONE,value:1e-10,offset:0},m:{name:"m",base:F.LENGTH,prefixes:T.SHORT,value:1,offset:0},in:{name:"in",base:F.LENGTH,prefixes:T.NONE,value:.0254,offset:0},ft:{name:"ft",base:F.LENGTH,prefixes:T.NONE,value:.3048,offset:0},yd:{name:"yd",base:F.LENGTH,prefixes:T.NONE,value:.9144,offset:0},mi:{name:"mi",base:F.LENGTH,prefixes:T.NONE,value:1609.344,offset:0},li:{name:"li",base:F.LENGTH,prefixes:T.NONE,value:.201168,offset:0},rd:{name:"rd",base:F.LENGTH,prefixes:T.NONE,value:5.02921,offset:0},ch:{name:"ch",base:F.LENGTH,prefixes:T.NONE,value:20.1168,offset:0},mil:{name:"mil",base:F.LENGTH,prefixes:T.NONE,value:254e-7,offset:0},m2:{name:"m2",base:F.SURFACE,prefixes:T.SQUARED,value:1,offset:0},sqin:{name:"sqin",base:F.SURFACE,prefixes:T.NONE,value:64516e-8,offset:0},sqft:{name:"sqft",base:F.SURFACE,prefixes:T.NONE,value:.09290304,offset:0},sqyd:{name:"sqyd",base:F.SURFACE,prefixes:T.NONE,value:.83612736,offset:0},sqmi:{name:"sqmi",base:F.SURFACE,prefixes:T.NONE,value:2589988.110336,offset:0},sqrd:{name:"sqrd",base:F.SURFACE,prefixes:T.NONE,value:25.29295,offset:0},sqch:{name:"sqch",base:F.SURFACE,prefixes:T.NONE,value:404.6873,offset:0},sqmil:{name:"sqmil",base:F.SURFACE,prefixes:T.NONE,value:6.4516e-10,offset:0},acre:{name:"acre",base:F.SURFACE,prefixes:T.NONE,value:4046.86,offset:0},hectare:{name:"hectare",base:F.SURFACE,prefixes:T.NONE,value:1e4,offset:0},m3:{name:"m3",base:F.VOLUME,prefixes:T.CUBIC,value:1,offset:0},L:{name:"L",base:F.VOLUME,prefixes:T.SHORT,value:.001,offset:0},l:{name:"l",base:F.VOLUME,prefixes:T.SHORT,value:.001,offset:0},litre:{name:"litre",base:F.VOLUME,prefixes:T.LONG,value:.001,offset:0},cuin:{name:"cuin",base:F.VOLUME,prefixes:T.NONE,value:16387064e-12,offset:0},cuft:{name:"cuft",base:F.VOLUME,prefixes:T.NONE,value:.028316846592,offset:0},cuyd:{name:"cuyd",base:F.VOLUME,prefixes:T.NONE,value:.764554857984,offset:0},teaspoon:{name:"teaspoon",base:F.VOLUME,prefixes:T.NONE,value:5e-6,offset:0},tablespoon:{name:"tablespoon",base:F.VOLUME,prefixes:T.NONE,value:15e-6,offset:0},drop:{name:"drop",base:F.VOLUME,prefixes:T.NONE,value:5e-8,offset:0},gtt:{name:"gtt",base:F.VOLUME,prefixes:T.NONE,value:5e-8,offset:0},minim:{name:"minim",base:F.VOLUME,prefixes:T.NONE,value:6.1611519921875e-8,offset:0},fluiddram:{name:"fluiddram",base:F.VOLUME,prefixes:T.NONE,value:36966911953125e-19,offset:0},fluidounce:{name:"fluidounce",base:F.VOLUME,prefixes:T.NONE,value:295735295625e-16,offset:0},gill:{name:"gill",base:F.VOLUME,prefixes:T.NONE,value:.00011829411825,offset:0},cc:{name:"cc",base:F.VOLUME,prefixes:T.NONE,value:1e-6,offset:0},cup:{name:"cup",base:F.VOLUME,prefixes:T.NONE,value:.0002365882365,offset:0},pint:{name:"pint",base:F.VOLUME,prefixes:T.NONE,value:.000473176473,offset:0},quart:{name:"quart",base:F.VOLUME,prefixes:T.NONE,value:.000946352946,offset:0},gallon:{name:"gallon",base:F.VOLUME,prefixes:T.NONE,value:.003785411784,offset:0},beerbarrel:{name:"beerbarrel",base:F.VOLUME,prefixes:T.NONE,value:.117347765304,offset:0},oilbarrel:{name:"oilbarrel",base:F.VOLUME,prefixes:T.NONE,value:.158987294928,offset:0},hogshead:{name:"hogshead",base:F.VOLUME,prefixes:T.NONE,value:.238480942392,offset:0},g:{name:"g",base:F.MASS,prefixes:T.SHORT,value:.001,offset:0},gram:{name:"gram",base:F.MASS,prefixes:T.LONG,value:.001,offset:0},ton:{name:"ton",base:F.MASS,prefixes:T.SHORT,value:907.18474,offset:0},t:{name:"t",base:F.MASS,prefixes:T.SHORT,value:1e3,offset:0},tonne:{name:"tonne",base:F.MASS,prefixes:T.LONG,value:1e3,offset:0},grain:{name:"grain",base:F.MASS,prefixes:T.NONE,value:6479891e-11,offset:0},dram:{name:"dram",base:F.MASS,prefixes:T.NONE,value:.0017718451953125,offset:0},ounce:{name:"ounce",base:F.MASS,prefixes:T.NONE,value:.028349523125,offset:0},poundmass:{name:"poundmass",base:F.MASS,prefixes:T.NONE,value:.45359237,offset:0},hundredweight:{name:"hundredweight",base:F.MASS,prefixes:T.NONE,value:45.359237,offset:0},stick:{name:"stick",base:F.MASS,prefixes:T.NONE,value:.115,offset:0},stone:{name:"stone",base:F.MASS,prefixes:T.NONE,value:6.35029318,offset:0},gr:{name:"gr",base:F.MASS,prefixes:T.NONE,value:6479891e-11,offset:0},dr:{name:"dr",base:F.MASS,prefixes:T.NONE,value:.0017718451953125,offset:0},oz:{name:"oz",base:F.MASS,prefixes:T.NONE,value:.028349523125,offset:0},lbm:{name:"lbm",base:F.MASS,prefixes:T.NONE,value:.45359237,offset:0},cwt:{name:"cwt",base:F.MASS,prefixes:T.NONE,value:45.359237,offset:0},s:{name:"s",base:F.TIME,prefixes:T.SHORT,value:1,offset:0},min:{name:"min",base:F.TIME,prefixes:T.NONE,value:60,offset:0},h:{name:"h",base:F.TIME,prefixes:T.NONE,value:3600,offset:0},second:{name:"second",base:F.TIME,prefixes:T.LONG,value:1,offset:0},sec:{name:"sec",base:F.TIME,prefixes:T.LONG,value:1,offset:0},minute:{name:"minute",base:F.TIME,prefixes:T.NONE,value:60,offset:0},hour:{name:"hour",base:F.TIME,prefixes:T.NONE,value:3600,offset:0},day:{name:"day",base:F.TIME,prefixes:T.NONE,value:86400,offset:0},week:{name:"week",base:F.TIME,prefixes:T.NONE,value:604800,offset:0},month:{name:"month",base:F.TIME,prefixes:T.NONE,value:2629800,offset:0},year:{name:"year",base:F.TIME,prefixes:T.NONE,value:31557600,offset:0},decade:{name:"decade",base:F.TIME,prefixes:T.NONE,value:315576e3,offset:0},century:{name:"century",base:F.TIME,prefixes:T.NONE,value:315576e4,offset:0},millennium:{name:"millennium",base:F.TIME,prefixes:T.NONE,value:315576e5,offset:0},hertz:{name:"Hertz",base:F.FREQUENCY,prefixes:T.LONG,value:1,offset:0,reciprocal:!0},Hz:{name:"Hz",base:F.FREQUENCY,prefixes:T.SHORT,value:1,offset:0,reciprocal:!0},rad:{name:"rad",base:F.ANGLE,prefixes:T.SHORT,value:1,offset:0},radian:{name:"radian",base:F.ANGLE,prefixes:T.LONG,value:1,offset:0},deg:{name:"deg",base:F.ANGLE,prefixes:T.SHORT,value:null,offset:0},degree:{name:"degree",base:F.ANGLE,prefixes:T.LONG,value:null,offset:0},grad:{name:"grad",base:F.ANGLE,prefixes:T.SHORT,value:null,offset:0},gradian:{name:"gradian",base:F.ANGLE,prefixes:T.LONG,value:null,offset:0},cycle:{name:"cycle",base:F.ANGLE,prefixes:T.NONE,value:null,offset:0},arcsec:{name:"arcsec",base:F.ANGLE,prefixes:T.NONE,value:null,offset:0},arcmin:{name:"arcmin",base:F.ANGLE,prefixes:T.NONE,value:null,offset:0},A:{name:"A",base:F.CURRENT,prefixes:T.SHORT,value:1,offset:0},ampere:{name:"ampere",base:F.CURRENT,prefixes:T.LONG,value:1,offset:0},K:{name:"K",base:F.TEMPERATURE,prefixes:T.SHORT,value:1,offset:0},degC:{name:"degC",base:F.TEMPERATURE,prefixes:T.SHORT,value:1,offset:273.15},degF:{name:"degF",base:F.TEMPERATURE,prefixes:T.SHORT,value:new y(5,9),offset:459.67},degR:{name:"degR",base:F.TEMPERATURE,prefixes:T.SHORT,value:new y(5,9),offset:0},kelvin:{name:"kelvin",base:F.TEMPERATURE,prefixes:T.LONG,value:1,offset:0},celsius:{name:"celsius",base:F.TEMPERATURE,prefixes:T.LONG,value:1,offset:273.15},fahrenheit:{name:"fahrenheit",base:F.TEMPERATURE,prefixes:T.LONG,value:new y(5,9),offset:459.67},rankine:{name:"rankine",base:F.TEMPERATURE,prefixes:T.LONG,value:new y(5,9),offset:0},mol:{name:"mol",base:F.AMOUNT_OF_SUBSTANCE,prefixes:T.SHORT,value:1,offset:0},mole:{name:"mole",base:F.AMOUNT_OF_SUBSTANCE,prefixes:T.LONG,value:1,offset:0},cd:{name:"cd",base:F.LUMINOUS_INTENSITY,prefixes:T.SHORT,value:1,offset:0},candela:{name:"candela",base:F.LUMINOUS_INTENSITY,prefixes:T.LONG,value:1,offset:0},N:{name:"N",base:F.FORCE,prefixes:T.SHORT,value:1,offset:0},newton:{name:"newton",base:F.FORCE,prefixes:T.LONG,value:1,offset:0},dyn:{name:"dyn",base:F.FORCE,prefixes:T.SHORT,value:1e-5,offset:0},dyne:{name:"dyne",base:F.FORCE,prefixes:T.LONG,value:1e-5,offset:0},lbf:{name:"lbf",base:F.FORCE,prefixes:T.NONE,value:4.4482216152605,offset:0},poundforce:{name:"poundforce",base:F.FORCE,prefixes:T.NONE,value:4.4482216152605,offset:0},kip:{name:"kip",base:F.FORCE,prefixes:T.LONG,value:4448.2216,offset:0},kilogramforce:{name:"kilogramforce",base:F.FORCE,prefixes:T.NONE,value:9.80665,offset:0},J:{name:"J",base:F.ENERGY,prefixes:T.SHORT,value:1,offset:0},joule:{name:"joule",base:F.ENERGY,prefixes:T.LONG,value:1,offset:0},erg:{name:"erg",base:F.ENERGY,prefixes:T.SHORTLONG,value:1e-7,offset:0},Wh:{name:"Wh",base:F.ENERGY,prefixes:T.SHORT,value:3600,offset:0},BTU:{name:"BTU",base:F.ENERGY,prefixes:T.BTU,value:1055.05585262,offset:0},eV:{name:"eV",base:F.ENERGY,prefixes:T.SHORT,value:1602176565e-28,offset:0},electronvolt:{name:"electronvolt",base:F.ENERGY,prefixes:T.LONG,value:1602176565e-28,offset:0},W:{name:"W",base:F.POWER,prefixes:T.SHORT,value:1,offset:0},watt:{name:"watt",base:F.POWER,prefixes:T.LONG,value:1,offset:0},hp:{name:"hp",base:F.POWER,prefixes:T.NONE,value:745.6998715386,offset:0},VAR:{name:"VAR",base:F.POWER,prefixes:T.SHORT,value:q.I,offset:0},VA:{name:"VA",base:F.POWER,prefixes:T.SHORT,value:1,offset:0},Pa:{name:"Pa",base:F.PRESSURE,prefixes:T.SHORT,value:1,offset:0},psi:{name:"psi",base:F.PRESSURE,prefixes:T.NONE,value:6894.75729276459,offset:0},atm:{name:"atm",base:F.PRESSURE,prefixes:T.NONE,value:101325,offset:0},bar:{name:"bar",base:F.PRESSURE,prefixes:T.SHORTLONG,value:1e5,offset:0},torr:{name:"torr",base:F.PRESSURE,prefixes:T.NONE,value:133.322,offset:0},mmHg:{name:"mmHg",base:F.PRESSURE,prefixes:T.NONE,value:133.322,offset:0},mmH2O:{name:"mmH2O",base:F.PRESSURE,prefixes:T.NONE,value:9.80665,offset:0},cmH2O:{name:"cmH2O",base:F.PRESSURE,prefixes:T.NONE,value:98.0665,offset:0},coulomb:{name:"coulomb",base:F.ELECTRIC_CHARGE,prefixes:T.LONG,value:1,offset:0},C:{name:"C",base:F.ELECTRIC_CHARGE,prefixes:T.SHORT,value:1,offset:0},farad:{name:"farad",base:F.ELECTRIC_CAPACITANCE,prefixes:T.LONG,value:1,offset:0},F:{name:"F",base:F.ELECTRIC_CAPACITANCE,prefixes:T.SHORT,value:1,offset:0},volt:{name:"volt",base:F.ELECTRIC_POTENTIAL,prefixes:T.LONG,value:1,offset:0},V:{name:"V",base:F.ELECTRIC_POTENTIAL,prefixes:T.SHORT,value:1,offset:0},ohm:{name:"ohm",base:F.ELECTRIC_RESISTANCE,prefixes:T.SHORTLONG,value:1,offset:0},henry:{name:"henry",base:F.ELECTRIC_INDUCTANCE,prefixes:T.LONG,value:1,offset:0},H:{name:"H",base:F.ELECTRIC_INDUCTANCE,prefixes:T.SHORT,value:1,offset:0},siemens:{name:"siemens",base:F.ELECTRIC_CONDUCTANCE,prefixes:T.LONG,value:1,offset:0},S:{name:"S",base:F.ELECTRIC_CONDUCTANCE,prefixes:T.SHORT,value:1,offset:0},weber:{name:"weber",base:F.MAGNETIC_FLUX,prefixes:T.LONG,value:1,offset:0},Wb:{name:"Wb",base:F.MAGNETIC_FLUX,prefixes:T.SHORT,value:1,offset:0},tesla:{name:"tesla",base:F.MAGNETIC_FLUX_DENSITY,prefixes:T.LONG,value:1,offset:0},T:{name:"T",base:F.MAGNETIC_FLUX_DENSITY,prefixes:T.SHORT,value:1,offset:0},b:{name:"b",base:F.BIT,prefixes:T.BINARY_SHORT,value:1,offset:0},bits:{name:"bits",base:F.BIT,prefixes:T.BINARY_LONG,value:1,offset:0},B:{name:"B",base:F.BIT,prefixes:T.BINARY_SHORT,value:8,offset:0},bytes:{name:"bytes",base:F.BIT,prefixes:T.BINARY_LONG,value:8,offset:0}},O={meters:"meter",inches:"inch",feet:"foot",yards:"yard",miles:"mile",links:"link",rods:"rod",chains:"chain",angstroms:"angstrom",lt:"l",litres:"litre",liter:"litre",liters:"litre",teaspoons:"teaspoon",tablespoons:"tablespoon",minims:"minim",fldr:"fluiddram",fluiddrams:"fluiddram",floz:"fluidounce",fluidounces:"fluidounce",gi:"gill",gills:"gill",cp:"cup",cups:"cup",pt:"pint",pints:"pint",qt:"quart",quarts:"quart",gal:"gallon",gallons:"gallon",bbl:"beerbarrel",beerbarrels:"beerbarrel",obl:"oilbarrel",oilbarrels:"oilbarrel",hogsheads:"hogshead",gtts:"gtt",grams:"gram",tons:"ton",tonnes:"tonne",grains:"grain",drams:"dram",ounces:"ounce",poundmasses:"poundmass",hundredweights:"hundredweight",sticks:"stick",lb:"lbm",lbs:"lbm",kips:"kip",kgf:"kilogramforce",acres:"acre",hectares:"hectare",sqfeet:"sqft",sqyard:"sqyd",sqmile:"sqmi",sqmiles:"sqmi",mmhg:"mmHg",mmh2o:"mmH2O",cmh2o:"cmH2O",seconds:"second",secs:"second",minutes:"minute",mins:"minute",hours:"hour",hr:"hour",hrs:"hour",days:"day",weeks:"week",months:"month",years:"year",decades:"decade",centuries:"century",millennia:"millennium",hertz:"hertz",radians:"radian",degrees:"degree",gradians:"gradian",cycles:"cycle",arcsecond:"arcsec",arcseconds:"arcsec",arcminute:"arcmin",arcminutes:"arcmin",BTUs:"BTU",watts:"watt",joules:"joule",amperes:"ampere",amps:"ampere",amp:"ampere",coulombs:"coulomb",volts:"volt",ohms:"ohm",farads:"farad",webers:"weber",teslas:"tesla",electronvolts:"electronvolt",moles:"mole",bit:"bits",byte:"bytes"};function _(e){if("BigNumber"===e.number){const e=uc(g);B.rad.value=new g(1),B.deg.value=e.div(180),B.grad.value=e.div(200),B.cycle.value=e.times(2),B.arcsec.value=e.div(648e3),B.arcmin.value=e.div(10800)}else B.rad.value=1,B.deg.value=Math.PI/180,B.grad.value=Math.PI/200,B.cycle.value=2*Math.PI,B.arcsec.value=Math.PI/648e3,B.arcmin.value=Math.PI/10800;B.radian.value=B.rad.value,B.degree.value=B.deg.value,B.gradian.value=B.grad.value}_(l),t&&t("config",function(e,t){e.number!==t.number&&_(e)});const z={si:{NONE:{unit:P,prefix:T.NONE[""]},LENGTH:{unit:B.m,prefix:T.SHORT[""]},MASS:{unit:B.g,prefix:T.SHORT.k},TIME:{unit:B.s,prefix:T.SHORT[""]},CURRENT:{unit:B.A,prefix:T.SHORT[""]},TEMPERATURE:{unit:B.K,prefix:T.SHORT[""]},LUMINOUS_INTENSITY:{unit:B.cd,prefix:T.SHORT[""]},AMOUNT_OF_SUBSTANCE:{unit:B.mol,prefix:T.SHORT[""]},ANGLE:{unit:B.rad,prefix:T.SHORT[""]},BIT:{unit:B.bits,prefix:T.SHORT[""]},FORCE:{unit:B.N,prefix:T.SHORT[""]},ENERGY:{unit:B.J,prefix:T.SHORT[""]},POWER:{unit:B.W,prefix:T.SHORT[""]},PRESSURE:{unit:B.Pa,prefix:T.SHORT[""]},ELECTRIC_CHARGE:{unit:B.C,prefix:T.SHORT[""]},ELECTRIC_CAPACITANCE:{unit:B.F,prefix:T.SHORT[""]},ELECTRIC_POTENTIAL:{unit:B.V,prefix:T.SHORT[""]},ELECTRIC_RESISTANCE:{unit:B.ohm,prefix:T.SHORT[""]},ELECTRIC_INDUCTANCE:{unit:B.H,prefix:T.SHORT[""]},ELECTRIC_CONDUCTANCE:{unit:B.S,prefix:T.SHORT[""]},MAGNETIC_FLUX:{unit:B.Wb,prefix:T.SHORT[""]},MAGNETIC_FLUX_DENSITY:{unit:B.T,prefix:T.SHORT[""]},FREQUENCY:{unit:B.Hz,prefix:T.SHORT[""]}}};z.cgs=JSON.parse(JSON.stringify(z.si)),z.cgs.LENGTH={unit:B.m,prefix:T.SHORT.c},z.cgs.MASS={unit:B.g,prefix:T.SHORT[""]},z.cgs.FORCE={unit:B.dyn,prefix:T.SHORT[""]},z.cgs.ENERGY={unit:B.erg,prefix:T.NONE[""]},z.us=JSON.parse(JSON.stringify(z.si)),z.us.LENGTH={unit:B.ft,prefix:T.NONE[""]},z.us.MASS={unit:B.lbm,prefix:T.NONE[""]},z.us.TEMPERATURE={unit:B.degF,prefix:T.NONE[""]},z.us.FORCE={unit:B.lbf,prefix:T.NONE[""]},z.us.ENERGY={unit:B.BTU,prefix:T.BTU[""]},z.us.POWER={unit:B.hp,prefix:T.NONE[""]},z.us.PRESSURE={unit:B.psi,prefix:T.NONE[""]},z.auto=JSON.parse(JSON.stringify(z.si));let I=z.auto;x.setUnitSystem=function(e){if(!ue(z,e))throw new Error("Unit system "+e+" does not exist. Choices are: "+Object.keys(z).join(", "));I=z[e]},x.getUnitSystem=function(){for(const e in z)if(ue(z,e)&&z[e]===I)return e},x.typeConverters={BigNumber:function(e){return null!=e&&e.isFraction?new g(e.n).div(e.d).times(e.s):new g(e+"")},Fraction:function(e){return new y(e)},Complex:function(e){return e},number:function(e){return null!=e&&e.isFraction?n(e):e}},x.prototype._numberConverter=function(){var e=x.typeConverters[this.valueType()];if(e)return e;throw new TypeError('Unsupported Unit value type "'+this.valueType()+'"')},x._getNumberConverter=function(e){if(x.typeConverters[e])return x.typeConverters[e];throw new TypeError('Unsupported type "'+e+'"')};for(const e in B)if(ue(B,e)){const t=B[e];t.dimensions=t.base.dimensions}for(const e in O)if(ue(O,e)){const t=B[O[e]],l={};for(const e in t)ue(t,e)&&(l[e]=t[e]);l.name=e,B[e]=l}return x.isValidAlpha=function(e){return/^[a-zA-Z]$/.test(e)},x.createUnit=function(t,r){if("object"!=typeof t)throw new TypeError("createUnit expects first parameter to be of type 'Object'");if(r&&r.override)for(const r in t)if(ue(t,r)&&x.deleteUnit(r),t[r].aliases)for(let e=0;e<t[r].aliases.length;e++)x.deleteUnit(t[r].aliases[e]);let e;for(const r in t)ue(t,r)&&(e=x.createUnitSingle(r,t[r]));return e},x.createUnitSingle=function(r,t){if(null==t&&(t={}),"string"!=typeof r)throw new TypeError("createUnitSingle expects first parameter to be of type 'string'");if(ue(B,r))throw new Error('Cannot create unit "'+r+'": a unit with that name already exists');var n=r;for(let e=0;e<n.length;e++){if(w=n.charAt(e),0===e&&!x.isValidAlpha(w))throw new Error('Invalid unit name (must begin with alpha character): "'+n+'"');if(0<e&&!x.isValidAlpha(w)&&!E(w))throw new Error('Invalid unit name (only alphanumeric characters are allowed): "'+n+'"')}let i,a,o,s=null,u=[],c=0;if(t&&"Unit"===t.type)s=t.clone();else if("string"==typeof t)""!==t&&(i=t);else{if("object"!=typeof t)throw new TypeError('Cannot create unit "'+r+'" from "'+t.toString()+'": expecting "string" or "Unit" or "Object"');i=t.definition,a=t.prefixes,c=t.offset,o=t.baseName,t.aliases&&(u=t.aliases.valueOf())}if(u)for(let e=0;e<u.length;e++)if(ue(B,u[e]))throw new Error('Cannot create alias "'+u[e]+'": a unit with that name already exists');if(i&&"string"==typeof i&&!s)try{s=x.parse(i,{allowNoUnits:!0})}catch(t){throw t.message='Could not create unit "'+r+'" from "'+i+'": '+t.message,t}else i&&"Unit"===i.type&&(s=i.clone());u=u||[],c=c||0,a=a&&a.toUpperCase&&T[a.toUpperCase()]||T.NONE;let l={};if(s){let e=!(l={name:r,value:s.value,dimensions:s.dimensions.slice(0),prefixes:a,offset:c});for(const r in F)if(ue(F,r)){let t=!0;for(let e=0;e<D.length;e++)if(1e-12<Math.abs((l.dimensions[e]||0)-(F[r].dimensions[e]||0))){t=!1;break}if(t){e=!0,l.base=F[r];break}}if(!e){o=o||r+"_STUFF";const t={dimensions:s.dimensions.slice(0)};t.key=o,F[o]=t,I[o]={unit:l,prefix:T.NONE[""]},l.base=F[o]}}else{if(o=o||r+"_STUFF",0<=D.indexOf(o))throw new Error('Cannot create new base unit "'+r+'": a base unit with that name already exists (and cannot be overridden)');D.push(o);for(const r in F)ue(F,r)&&(F[r].dimensions[D.length-1]=0);const t={dimensions:[]};for(let e=0;e<D.length;e++)t.dimensions[e]=0;t.dimensions[D.length-1]=1,t.key=o,F[o]=t,l={name:r,value:1,dimensions:F[o].dimensions.slice(0),prefixes:a,offset:c,base:F[o]},I[o]={unit:l,prefix:T.NONE[""]}}x.UNITS[r]=l;for(let e=0;e<u.length;e++){const t=u[e],i={};for(const r in l)ue(l,r)&&(i[r]=l[r]);i.name=t,x.UNITS[t]=i}return delete C.cache,new x(null,r)},x.deleteUnit=function(e){delete x.UNITS[e],delete C.cache},x.PREFIXES=T,x.BASE_DIMENSIONS=D,x.BASE_UNITS=F,x.UNIT_SYSTEMS=z,x.UNITS=B,x},{isClass:!0}),pc=s("unit",["typed","Unit"],e=>{let{typed:t,Unit:r}=e;return t("unit",{Unit:function(e){return e.clone()},string:function(e){return r.isValuelessUnit(e)?new r(null,e):r.parse(e,{allowNoUnits:!0})},"number | BigNumber | Fraction | Complex, string | Unit":function(e,t){return new r(e,t)},"number | BigNumber | Fraction":function(e){return new r(e)},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),mc=s("sparse",["typed","SparseMatrix"],e=>{let{typed:t,SparseMatrix:r}=e;return t("sparse",{"":function(){return new r([])},string:function(e){return new r([],e)},"Array | Matrix":function(e){return new r(e)},"Array | Matrix, string":function(e,t){return new r(e,t)}})}),hc="createUnit",dc=s(hc,["typed","Unit"],e=>{let{typed:t,Unit:i}=e;return t(hc,{"Object, Object":function(e,t){return i.createUnit(e,t)},Object:function(e){return i.createUnit(e,{})},"string, Unit | string | Object, Object":function(e,t,r){const n={};return n[e]=t,i.createUnit(n,r)},"string, Unit | string | Object":function(e,t){const r={};return r[e]=t,i.createUnit(r,{})},string:function(e){const t={};return t[e]={},i.createUnit(t,{})}})}),gc=s("acos",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("acos",{number:function(e){return-1<=e&&e<=1||r.predictable?Math.acos(e):new n(e,0).acos()},Complex:function(e){return e.acos()},BigNumber:function(e){return e.acos()}})}),yc="number";function xc(e){return Oe(e)}function bc(e){return Math.atan(1/e)}function vc(e){return isFinite(e)?(Math.log((e+1)/e)+Math.log(e/(e-1)))/2:0}function wc(e){return Math.asin(1/e)}function Nc(e){e=1/e;return Math.log(e+Math.sqrt(e*e+1))}function Ec(e){return Math.acos(1/e)}function Ac(e){var e=1/e,t=Math.sqrt(e*e-1);return Math.log(t+e)}function Sc(e){return _e(e)}function Mc(e){return ze(e)}function Cc(e){return 1/Math.tan(e)}function Tc(e){e=Math.exp(2*e);return(e+1)/(e-1)}function Dc(e){return 1/Math.sin(e)}function Fc(e){return 0===e?Number.POSITIVE_INFINITY:Math.abs(2/(Math.exp(e)-Math.exp(-e)))*n(e)}function Bc(e){return 1/Math.cos(e)}function Oc(e){return 2/(Math.exp(e)+Math.exp(-e))}function _c(e){return ke(e)}_c.signature=Oc.signature=Bc.signature=Fc.signature=Dc.signature=Tc.signature=Cc.signature=Mc.signature=Sc.signature=Ac.signature=Ec.signature=Nc.signature=wc.signature=vc.signature=bc.signature=xc.signature=yc;const zc=s("acosh",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("acosh",{number:function(e){return 1<=e||r.predictable?xc(e):e<=-1?new n(Math.log(Math.sqrt(e*e-1)-e),Math.PI):new n(e,0).acosh()},Complex:function(e){return e.acosh()},BigNumber:function(e){return e.acosh()}})}),Ic=s("acot",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("acot",{number:bc,Complex:function(e){return e.acot()},BigNumber:function(e){return new r(1).div(e).atan()}})}),kc=s("acoth",["typed","config","Complex","BigNumber"],e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t("acoth",{number:function(e){return 1<=e||e<=-1||r.predictable?vc(e):new n(e,0).acoth()},Complex:function(e){return e.acoth()},BigNumber:function(e){return new i(1).div(e).atanh()}})}),qc=s("acsc",["typed","config","Complex","BigNumber"],e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t("acsc",{number:function(e){return e<=-1||1<=e||r.predictable?wc(e):new n(e,0).acsc()},Complex:function(e){return e.acsc()},BigNumber:function(e){return new i(1).div(e).asin()}})}),Rc=s("acsch",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("acsch",{number:Nc,Complex:function(e){return e.acsch()},BigNumber:function(e){return new r(1).div(e).asinh()}})}),Pc=s("asec",["typed","config","Complex","BigNumber"],e=>{let{typed:t,config:r,Complex:n,BigNumber:i}=e;return t("asec",{number:function(e){return e<=-1||1<=e||r.predictable?Ec(e):new n(e,0).asec()},Complex:function(e){return e.asec()},BigNumber:function(e){return new i(1).div(e).acos()}})}),jc=s("asech",["typed","config","Complex","BigNumber"],e=>{let{typed:t,config:n,Complex:i,BigNumber:r}=e;return t("asech",{number:function(e){if(e<=1&&-1<=e||n.predictable){var t=1/e;if(0<t||n.predictable)return Ac(e);var r=Math.sqrt(t*t-1);return new i(Math.log(r-t),Math.PI)}return new i(e,0).asech()},Complex:function(e){return e.asech()},BigNumber:function(e){return new r(1).div(e).acosh()}})}),Uc=s("asin",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("asin",{number:function(e){return-1<=e&&e<=1||r.predictable?Math.asin(e):new n(e,0).asin()},Complex:function(e){return e.asin()},BigNumber:function(e){return e.asin()}})}),Lc=s("asinh",["typed"],e=>{let t=e["typed"];return t("asinh",{number:Sc,Complex:function(e){return e.asinh()},BigNumber:function(e){return e.asinh()}})}),$c=s("atan",["typed"],e=>{let t=e["typed"];return t("atan",{number:function(e){return Math.atan(e)},Complex:function(e){return e.atan()},BigNumber:function(e){return e.atan()}})}),Hc=s("atan2",["typed","matrix","equalScalar","BigNumber","DenseMatrix","concat"],e=>{let{typed:t,matrix:r,equalScalar:n,BigNumber:i,DenseMatrix:a,concat:o}=e;const s=va({typed:t,equalScalar:n}),u=wa({typed:t}),c=Va({typed:t,equalScalar:n}),l=x({typed:t,equalScalar:n}),f=C({typed:t,DenseMatrix:a}),p=B({typed:t,matrix:r,concat:o});return t("atan2",{"number, number":Math.atan2,"BigNumber, BigNumber":(e,t)=>i.atan2(e,t)},p({scalar:"number | BigNumber",SS:c,DS:u,SD:s,Ss:l,sS:f}))}),Gc=s("atanh",["typed","config","Complex"],e=>{let{typed:t,config:r,Complex:n}=e;return t("atanh",{number:function(e){return e<=1&&-1<=e||r.predictable?Mc(e):new n(e,0).atanh()},Complex:function(e){return e.atanh()},BigNumber:function(e){return e.atanh()}})}),Zc=s("trigUnit",["typed"],e=>{let r=e["typed"];return{Unit:r.referToSelf(t=>e=>{if(e.hasBase(e.constructor.BASE_UNITS.ANGLE))return r.find(t,e.valueType())(e.value);throw new TypeError("Unit in function cot is no angle")})}}),Vc=s("cos",["typed"],e=>{let t=e["typed"];e=Zc({typed:t});return t("cos",{number:Math.cos,"Complex | BigNumber":e=>e.cos()},e)}),Wc=s("cosh",["typed"],e=>{let t=e["typed"];return t("cosh",{number:Ie,"Complex | BigNumber":e=>e.cosh()})}),Yc=s("cot",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("cot",{number:Cc,Complex:e=>e.cot(),BigNumber:e=>new r(1).div(e.tan())},Zc({typed:t}))}),Jc=s("coth",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("coth",{number:Tc,Complex:e=>e.coth(),BigNumber:e=>new r(1).div(e.tanh())})}),Xc=s("csc",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("csc",{number:Dc,Complex:e=>e.csc(),BigNumber:e=>new r(1).div(e.sin())},Zc({typed:t}))}),Qc=s("csch",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("csch",{number:Fc,Complex:e=>e.csch(),BigNumber:e=>new r(1).div(e.sinh())})}),Kc=s("sec",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("sec",{number:Bc,Complex:e=>e.sec(),BigNumber:e=>new r(1).div(e.cos())},Zc({typed:t}))}),el=s("sech",["typed","BigNumber"],e=>{let{typed:t,BigNumber:r}=e;return t("sech",{number:Oc,Complex:e=>e.sech(),BigNumber:e=>new r(1).div(e.cosh())})}),tl=s("sin",["typed"],e=>{let t=e["typed"];e=Zc({typed:t});return t("sin",{number:Math.sin,"Complex | BigNumber":e=>e.sin()},e)}),rl=s("sinh",["typed"],e=>{let t=e["typed"];return t("sinh",{number:_c,"Complex | BigNumber":e=>e.sinh()})}),nl=s("tan",["typed"],e=>{let t=e["typed"];e=Zc({typed:t});return t("tan",{number:Math.tan,"Complex | BigNumber":e=>e.tan()},e)}),il=s("tanh",["typed"],e=>{let t=e["typed"];return t("tanh",{number:qe,"Complex | BigNumber":e=>e.tanh()})}),al="setCartesian",ol=s(al,["typed","size","subset","compareNatural","Index","DenseMatrix"],e=>{let{typed:t,size:n,subset:i,compareNatural:a,Index:o,DenseMatrix:s}=e;return t(al,{"Array | Matrix, Array | Matrix":function(e,t){let r=[];if(0!==i(n(e),new o(0))&&0!==i(n(t),new o(0))){const n=A(Array.isArray(e)?e:e.toArray()).sort(a),i=A(Array.isArray(t)?t:t.toArray()).sort(a);r=[];for(let t=0;t<n.length;t++)for(let e=0;e<i.length;e++)r.push([n[t],i[e]])}return Array.isArray(e)&&Array.isArray(t)?r:new s(r)}})}),sl="setDifference",ul=s(sl,["typed","size","subset","compareNatural","Index","DenseMatrix"],e=>{let{typed:t,size:i,subset:a,compareNatural:o,Index:r,DenseMatrix:s}=e;return t(sl,{"Array | Matrix, Array | Matrix":function(e,t){let n;if(0===a(i(e),new r(0)))n=[];else{if(0===a(i(t),new r(0)))return A(e.toArray());{const i=Tn(A(Array.isArray(e)?e:e.toArray()).sort(o)),a=Tn(A(Array.isArray(t)?t:t.toArray()).sort(o));let r;n=[];for(let t=0;t<i.length;t++){r=!1;for(let e=0;e<a.length;e++)if(0===o(i[t].value,a[e].value)&&i[t].identifier===a[e].identifier){r=!0;break}r||n.push(i[t])}}}return Array.isArray(e)&&Array.isArray(t)?Dn(n):new s(Dn(n))}})}),cl="setDistinct",ll=s(cl,["typed","size","subset","compareNatural","Index","DenseMatrix"],e=>{let{typed:t,size:r,subset:n,compareNatural:i,Index:a,DenseMatrix:o}=e;return t(cl,{"Array | Matrix":function(e){let t;if(0===n(r(e),new a(0)))t=[];else{const r=A(Array.isArray(e)?e:e.toArray()).sort(i);(t=[]).push(r[0]);for(let e=1;e<r.length;e++)0!==i(r[e],r[e-1])&&t.push(r[e])}return Array.isArray(e)?t:new o(t)}})}),fl="setIntersect",pl=s(fl,["typed","size","subset","compareNatural","Index","DenseMatrix"],e=>{let{typed:t,size:n,subset:i,compareNatural:a,Index:o,DenseMatrix:s}=e;return t(fl,{"Array | Matrix, Array | Matrix":function(e,t){let r;if(0===i(n(e),new o(0))||0===i(n(t),new o(0)))r=[];else{const n=Tn(A(Array.isArray(e)?e:e.toArray()).sort(a)),i=Tn(A(Array.isArray(t)?t:t.toArray()).sort(a));r=[];for(let t=0;t<n.length;t++)for(let e=0;e<i.length;e++)if(0===a(n[t].value,i[e].value)&&n[t].identifier===i[e].identifier){r.push(n[t]);break}}return Array.isArray(e)&&Array.isArray(t)?Dn(r):new s(Dn(r))}})}),ml="setIsSubset",hl=s(ml,["typed","size","subset","compareNatural","Index"],e=>{let{typed:t,size:a,subset:o,compareNatural:s,Index:u}=e;return t(ml,{"Array | Matrix, Array | Matrix":function(e,t){if(0===o(a(e),new u(0)))return!0;if(0===o(a(t),new u(0)))return!1;var r=Tn(A(Array.isArray(e)?e:e.toArray()).sort(s)),n=Tn(A(Array.isArray(t)?t:t.toArray()).sort(s));let i;for(let t=0;t<r.length;t++){i=!1;for(let e=0;e<n.length;e++)if(0===s(r[t].value,n[e].value)&&r[t].identifier===n[e].identifier){i=!0;break}if(!1===i)return!1}return!0}})}),dl="setMultiplicity",gl=s(dl,["typed","size","subset","compareNatural","Index"],e=>{let{typed:t,size:i,subset:a,compareNatural:o,Index:s}=e;return t(dl,{"number | BigNumber | Fraction | Complex, Array | Matrix":function(t,e){if(0===a(i(e),new s(0)))return 0;var r=A(Array.isArray(e)?e:e.toArray());let n=0;for(let e=0;e<r.length;e++)0===o(r[e],t)&&n++;return n}})}),yl="setPowerset",xl=s(yl,["typed","size","subset","compareNatural","Index"],e=>{let{typed:t,size:o,subset:s,compareNatural:u,Index:c}=e;return t(yl,{"Array | Matrix":function(e){if(0===s(o(e),new c(0)))return[];const t=A(Array.isArray(e)?e:e.toArray()).sort(u),r=[];let n=0;for(;n.toString(2).length<=t.length;)r.push(function(t,r){const n=[];for(let e=0;e<r.length;e++)"1"===r[e]&&n.push(t[e]);return n}(t,n.toString(2).split("").reverse())),n++;var i,a=r;for(let t=a.length-1;0<t;t--)for(let e=0;e<t;e++)a[e].length>a[e+1].length&&(i=a[e],a[e]=a[e+1],a[e+1]=i);return a}})}),bl="setSize",vl=s(bl,["typed","compareNatural"],e=>{let{typed:t,compareNatural:n}=e;return t(bl,{"Array | Matrix":function(e){return(Array.isArray(e)?A(e):A(e.toArray())).length},"Array | Matrix, boolean":function(e,r){if(!1===r||0===e.length)return(Array.isArray(e)?A(e):A(e.toArray())).length;{const r=A(Array.isArray(e)?e:e.toArray()).sort(n);let t=1;for(let e=1;e<r.length;e++)0!==n(r[e],r[e-1])&&t++;return t}}})}),wl="setSymDifference",Nl=s(wl,["typed","size","concat","subset","setDifference","Index"],e=>{let{typed:t,size:r,concat:n,subset:i,setDifference:a,Index:o}=e;return t(wl,{"Array | Matrix, Array | Matrix":function(e,t){if(0===i(r(e),new o(0)))return A(t);if(0===i(r(t),new o(0)))return A(e);e=A(e),t=A(t);return n(a(e,t),a(t,e))}})}),El="setUnion",Al=s(El,["typed","size","concat","subset","setIntersect","setSymDifference","Index"],e=>{let{typed:t,size:r,concat:n,subset:i,setIntersect:a,setSymDifference:o,Index:s}=e;return t(El,{"Array | Matrix, Array | Matrix":function(e,t){if(0===i(r(e),new s(0)))return A(t);if(0===i(r(t),new s(0)))return A(e);e=A(e),t=A(t);return n(o(e,t),a(e,t))}})}),Sl=s("add",["typed","matrix","addScalar","equalScalar","DenseMatrix","SparseMatrix","concat"],e=>{let{typed:t,matrix:r,addScalar:n,equalScalar:i,DenseMatrix:a,concat:o}=e;const s=Sa({typed:t}),u=Ma({typed:t,equalScalar:i}),c=Ca({typed:t,DenseMatrix:a}),l=B({typed:t,matrix:r,concat:o});return t("add",{"any, any":n,"any, any, ...any":t.referToSelf(i=>(e,t,r)=>{let n=i(e,t);for(let e=0;e<r.length;e++)n=i(n,r[e]);return n})},l({elop:n,DS:s,SS:u,Ss:c}))}),Ml=s("hypot",["typed","abs","addScalar","divideScalar","multiplyScalar","sqrt","smaller","isPositive"],e=>{let{typed:t,abs:a,addScalar:o,divideScalar:s,multiplyScalar:u,sqrt:c,smaller:l,isPositive:f}=e;return t("hypot",{"... number | BigNumber":r,Array:r,Matrix:e=>r(A(e.toArray()))});function r(t){let r=0,n=0;for(let e=0;e<t.length;e++){if(te(t[e]))throw new TypeError("Unexpected type of argument to hypot");var i=a(t[e]);l(n,i)?(r=u(r,u(s(n,i),s(n,i))),r=o(r,1),n=i):r=o(r,f(i)?u(s(i,n),s(i,n)):i)}return u(n,c(r))}}),Cl=s("norm",["typed","abs","add","pow","conj","sqrt","multiply","equalScalar","larger","smaller","matrix","ctranspose","eigs"],e=>{let{typed:t,abs:s,add:u,pow:c,conj:l,sqrt:f,multiply:p,equalScalar:m,larger:h,smaller:d,matrix:r,ctranspose:g,eigs:y}=e;return t("norm",{number:Math.abs,Complex:function(e){return e.abs()},BigNumber:function(e){return e.abs()},boolean:function(e){return Math.abs(e)},Array:function(e){return x(r(e),2)},Matrix:function(e){return x(e,2)},"Array, number | BigNumber | string":function(e,t){return x(r(e),t)},"Matrix, number | BigNumber | string":x});function x(e,t){var r=e.size();if(1===r.length){var n=e,i=t;if(i===Number.POSITIVE_INFINITY||"inf"===i){let t=0;return n.forEach(function(e){e=s(e);h(e,t)&&(t=e)},!0),t}if(i===Number.NEGATIVE_INFINITY||"-inf"===i){let t;return n.forEach(function(e){e=s(e);t&&!d(e,t)||(t=e)},!0),t||0}if("fro"===i)return x(n,2);if("number"!=typeof i||isNaN(i))throw new Error("Unsupported parameter value");if(m(i,0))return Number.POSITIVE_INFINITY;{let t=0;return n.forEach(function(e){t=u(c(s(e),i),t)},!0),c(t,1/i)}}if(2===r.length){if(r[0]&&r[1]){n=e,r=t;if(1===r){const a=[];let r=0;return n.forEach(function(e,t){t=t[1],e=u(a[t]||0,s(e));h(e,r)&&(r=e),a[t]=e},!0),r}if(r===Number.POSITIVE_INFINITY||"inf"===r){const o=[];let r=0;return n.forEach(function(e,t){t=t[0],e=u(o[t]||0,s(e));h(e,r)&&(r=e),o[t]=e},!0),r}if("fro"===r){let r=0;return n.forEach(function(e,t){r=u(r,p(e,l(e)))}),s(f(r))}if(2!==r)throw new Error("Unsupported parameter value "+r);if((n=(r=n).size())[0]!==n[1])throw new RangeError("Invalid matrix dimensions");return n=g(r),n=p(n,r),r=y(n).values.toArray(),n=r[r.length-1],s(f(n))}throw new RangeError("Invalid matrix dimensions")}}}),Tl=s("dot",["typed","addScalar","multiplyScalar","conj","size"],e=>{let{typed:c,addScalar:f,multiplyScalar:p,conj:l,size:t}=e;return c("dot",{"Array | DenseMatrix, Array | DenseMatrix":function(e,t){var r=m(e,t),n=_(e)?e._data:e,i=_(e)?e._datatype||e.getDataType():void 0,a=_(t)?t._data:t,o=_(t)?t._datatype||t.getDataType():void 0,e=2===h(e).length,t=2===h(t).length;let s=f,u=p;if(i&&o&&i===o&&"string"==typeof i&&"mixed"!==i){const e=i;s=c.find(f,[e,e]),u=c.find(p,[e,e])}if(!e&&!t){let t=u(l(n[0]),a[0]);for(let e=1;e<r;e++)t=s(t,u(l(n[e]),a[e]));return t}if(!e&&t){let t=u(l(n[0]),a[0][0]);for(let e=1;e<r;e++)t=s(t,u(l(n[e]),a[e][0]));return t}if(e&&!t){let t=u(l(n[0][0]),a[0]);for(let e=1;e<r;e++)t=s(t,u(l(n[e][0]),a[e]));return t}if(e&&t){let t=u(l(n[0][0]),a[0][0]);for(let e=1;e<r;e++)t=s(t,u(l(n[e][0]),a[e][0]));return t}},"SparseMatrix, SparseMatrix":function(e,t){m(e,t);var r=e._index,n=e._values,i=t._index,a=t._values;let o=0;const s=f,u=p;let c=0,l=0;for(;c<r.length&&l<i.length;){const e=r[c],t=i[l];e<t?c++:e>t?l++:e===t&&(o=s(o,u(n[c],a[l])),c++,l++)}return o}});function m(e,t){const r=h(e),n=h(t);let i,a;if(1===r.length)i=r[0];else{if(2!==r.length||1!==r[1])throw new RangeError("Expected a column vector, instead got a matrix of size ("+r.join(", ")+")");i=r[0]}if(1===n.length)a=n[0];else{if(2!==n.length||1!==n[1])throw new RangeError("Expected a column vector, instead got a matrix of size ("+n.join(", ")+")");a=n[0]}if(i!==a)throw new RangeError("Vectors must have equal length ("+i+" != "+a+")");if(0===i)throw new RangeError("Cannot calculate the dot product of empty vectors");return i}function h(e){return _(e)?e.size():t(e)}}),Dl=s("trace",["typed","matrix","add"],e=>{let{typed:t,matrix:r,add:u}=e;return t("trace",{Array:function(e){return n(r(e))},SparseMatrix:function(e){const n=e._values,i=e._index,a=e._ptr,t=e._size,o=t[0],s=t[1];if(o!==s)throw new RangeError("Matrix must be square (size: "+S(t)+")");{let r=0;if(0<n.length)for(let t=0;t<s;t++){const o=a[t],s=a[t+1];for(let e=o;e<s;e++){const o=i[e];if(o===t){r=u(r,n[e]);break}if(o>t)break}}return r}},DenseMatrix:n,any:ee});function n(r){var e=r._size,n=r._data;switch(e.length){case 1:if(1===e[0])return ee(n[0]);throw new RangeError("Matrix must be square (size: "+S(e)+")");case 2:{const r=e[0];if(r!==e[1])throw new RangeError("Matrix must be square (size: "+S(e)+")");{let t=0;for(let e=0;e<r;e++)t=u(t,n[e][e]);return t}}default:throw new RangeError("Matrix must be two dimensional (size: "+S(e)+")")}}}),Fl=s("index",["typed","Index"],e=>{let{typed:t,Index:r}=e;return t("index",{"...number | string | BigNumber | Range | Array | Matrix":function(e){var e=e.map(function(e){return Q(e)?e.toNumber():g(e)||_(e)?e.map(function(e){return Q(e)?e.toNumber():e}):e}),t=new r;return r.apply(t,e),t}})}),Bl=new Set(["end"]),Ol=s("Node",["mathWithTransform"],e=>{let t=e["mathWithTransform"];return class{get type(){return"Node"}get isNode(){return!0}evaluate(e){return this.compile().evaluate(e)}compile(){const n=this._compile(t,{}),i={};return{evaluate:function(e){var e=nt(e),t=e;for(const r of[...Bl])if(t.has(r))throw new Error('Scope contains an illegal symbol, "'+r+'" is a reserved keyword');return n(e,i,null)}}}_compile(e,t){throw new Error("Method _compile must be implemented by type "+this.type)}forEach(e){throw new Error("Cannot run forEach on a Node interface")}map(e){throw new Error("Cannot run map on a Node interface")}_ifNode(e){if(O(e))return e;throw new TypeError("Callback function must return a Node")}traverse(e){e(this,null,null),function n(e,i){e.forEach(function(e,t,r){i(e,t,r),n(e,i)})}(this,e)}transform(i){return function e(t,r,n){r=i(t,r,n);return r!==t?r:t.map(e)}(this,null,null)}filter(n){const i=[];return this.traverse(function(e,t,r){n(e,t,r)&&i.push(e)}),i}clone(){throw new Error("Cannot clone a Node interface")}cloneDeep(){return this.map(function(e){return e.cloneDeep()})}equals(e){return!!e&&this.type===e.type&&Ue(this,e)}toString(e){var t=this._getCustomString(e);return void 0!==t?t:this._toString(e)}_toString(){throw new Error("_toString not implemented for "+this.type)}toJSON(){throw new Error("Cannot serialize object: toJSON not implemented by "+this.type)}toHTML(e){var t=this._getCustomString(e);return void 0!==t?t:this._toHTML(e)}_toHTML(){throw new Error("_toHTML not implemented for "+this.type)}toTex(e){var t=this._getCustomString(e);return void 0!==t?t:this._toTex(e)}_toTex(e){throw new Error("_toTex not implemented for "+this.type)}_getCustomString(e){if(e&&"object"==typeof e)switch(typeof e.handler){case"object":case"undefined":return;case"function":return e.handler(this,e);default:throw new TypeError("Object or function expected as callback")}}getIdentifier(){return this.type}getContent(){return this}}},{isClass:!0,isNode:!0});function _l(e){return(_l="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function zl(e,t,r){var n;n=function(e){if("object"!=_l(e)||!e)return e;var t=e[Symbol.toPrimitive];if(void 0===t)return String(e);t=t.call(e,"string");if("object"!=_l(t))return t;throw new TypeError("@@toPrimitive must return a primitive value.")}(t),(t="symbol"==_l(n)?n:n+"")in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r}function Il(e){return e&&e.isIndexError?new mn(e.index+1,e.min+1,void 0!==e.max?e.max+1:void 0):e}function kl(e){let r=e["subset"];return function(e,t){try{if(Array.isArray(e))return r(e,t);if(e&&"function"==typeof e.subset)return e.subset(t);if("string"==typeof e)return r(e,t);if("object"!=typeof e)throw new TypeError("Cannot apply index: unsupported type of object");if(t.isObjectProperty())return Ze(e,t.getObjectProperty());throw new TypeError("Cannot apply a numeric index as object property")}catch(e){throw Il(e)}}}const ql="AccessorNode",Rl=s(ql,["subset","Node"],e=>{var{subset:e,Node:t}=e;const o=kl({subset:e});function r(e){return!(le(e)||X(e)||ae(e)||me(e)||de(e)||ge(e)||se(e))}class n extends t{constructor(e,t){if(super(),!O(e))throw new TypeError('Node expected for parameter "object"');if(!he(t))throw new TypeError('IndexNode expected for parameter "index"');this.object=e,this.index=t}get name(){return this.index?this.index.isObjectProperty()?this.index.getObjectProperty():"":this.object.name||""}get type(){return ql}get isAccessorNode(){return!0}_compile(n,e){const i=this.object._compile(n,e),a=this.index._compile(n,e);if(this.index.isObjectProperty()){const n=this.index.getObjectProperty();return function(e,t,r){return Ze(i(e,t,r),n)}}return function(e,t,r){r=i(e,t,r),e=a(e,t,r);return o(r,e)}}forEach(e){e(this.object,"object",this),e(this.index,"index",this)}map(e){return new n(this._ifNode(e(this.object,"object",this)),this._ifNode(e(this.index,"index",this)))}clone(){return new n(this.object,this.index)}_toString(e){let t=this.object.toString(e);return(t=r(this.object)?"("+t+")":t)+this.index.toString(e)}_toHTML(e){let t=this.object.toHTML(e);return(t=r(this.object)?'<span class="math-parenthesis math-round-parenthesis">(</span>'+t+'<span class="math-parenthesis math-round-parenthesis">)</span>':t)+this.index.toHTML(e)}_toTex(e){let t=this.object.toTex(e);return(t=r(this.object)?"\\left(' + object + '\\right)":t)+this.index.toTex(e)}toJSON(){return{mathjs:ql,object:this.object,index:this.index}}static fromJSON(e){return new n(e.object,e.index)}}return zl(n,"name",ql),n},{isClass:!0,isNode:!0}),Pl="ArrayNode",jl=s(Pl,["Node"],e=>{e=e.Node;class n extends e{constructor(e){if(super(),this.items=e||[],!Array.isArray(this.items)||!this.items.every(O))throw new TypeError("Array containing Nodes expected")}get type(){return Pl}get isArrayNode(){return!0}_compile(t,i){const e=En(this.items,function(e){return e._compile(t,i)});if("Array"===t.config.matrix)return function(t,r,n){return En(e,function(e){return e(t,r,n)})};{const i=t.matrix;return function(t,r,n){return i(En(e,function(e){return e(t,r,n)}))}}}forEach(t){for(let e=0;e<this.items.length;e++)t(this.items[e],"items["+e+"]",this)}map(t){const r=[];for(let e=0;e<this.items.length;e++)r[e]=this._ifNode(t(this.items[e],"items["+e+"]",this));return new n(r)}clone(){return new n(this.items.slice(0))}_toString(t){return"["+this.items.map(function(e){return e.toString(t)}).join(", ")+"]"}toJSON(){return{mathjs:Pl,items:this.items}}static fromJSON(e){return new n(e.items)}_toHTML(t){return'<span class="math-parenthesis math-square-parenthesis">[</span>'+this.items.map(function(e){return e.toHTML(t)}).join('<span class="math-separator">,</span>')+'<span class="math-parenthesis math-square-parenthesis">]</span>'}_toTex(o){return function t(e,r){var n=e.some(X)&&!e.every(X),i=r||n,a=i?"&":"\\\\",e=e.map(function(e){return e.items?t(e.items,!r):e.toTex(o)}).join(a);return n||!i||i&&!r?"\\begin{bmatrix}"+e+"\\end{bmatrix}":e}(this.items,!1)}}return zl(n,"name",Pl),n},{isClass:!0,isNode:!0}),Ul=[{AssignmentNode:{},FunctionAssignmentNode:{}},{ConditionalNode:{latexLeftParens:!1,latexRightParens:!1,latexParens:!1}},{"OperatorNode:or":{op:"or",associativity:"left",associativeWith:[]}},{"OperatorNode:xor":{op:"xor",associativity:"left",associativeWith:[]}},{"OperatorNode:and":{op:"and",associativity:"left",associativeWith:[]}},{"OperatorNode:bitOr":{op:"|",associativity:"left",associativeWith:[]}},{"OperatorNode:bitXor":{op:"^|",associativity:"left",associativeWith:[]}},{"OperatorNode:bitAnd":{op:"&",associativity:"left",associativeWith:[]}},{"OperatorNode:equal":{op:"==",associativity:"left",associativeWith:[]},"OperatorNode:unequal":{op:"!=",associativity:"left",associativeWith:[]},"OperatorNode:smaller":{op:"<",associativity:"left",associativeWith:[]},"OperatorNode:larger":{op:">",associativity:"left",associativeWith:[]},"OperatorNode:smallerEq":{op:"<=",associativity:"left",associativeWith:[]},"OperatorNode:largerEq":{op:">=",associativity:"left",associativeWith:[]},RelationalNode:{associativity:"left",associativeWith:[]}},{"OperatorNode:leftShift":{op:"<<",associativity:"left",associativeWith:[]},"OperatorNode:rightArithShift":{op:">>",associativity:"left",associativeWith:[]},"OperatorNode:rightLogShift":{op:">>>",associativity:"left",associativeWith:[]}},{"OperatorNode:to":{op:"to",associativity:"left",associativeWith:[]}},{RangeNode:{}},{"OperatorNode:add":{op:"+",associativity:"left",associativeWith:["OperatorNode:add","OperatorNode:subtract"]},"OperatorNode:subtract":{op:"-",associativity:"left",associativeWith:[]}},{"OperatorNode:multiply":{op:"*",associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","Operator:dotMultiply","Operator:dotDivide"]},"OperatorNode:divide":{op:"/",associativity:"left",associativeWith:[],latexLeftParens:!1,latexRightParens:!1,latexParens:!1},"OperatorNode:dotMultiply":{op:".*",associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","OperatorNode:dotMultiply","OperatorNode:doDivide"]},"OperatorNode:dotDivide":{op:"./",associativity:"left",associativeWith:[]},"OperatorNode:mod":{op:"mod",associativity:"left",associativeWith:[]}},{"OperatorNode:multiply":{associativity:"left",associativeWith:["OperatorNode:multiply","OperatorNode:divide","Operator:dotMultiply","Operator:dotDivide"]}},{"OperatorNode:unaryPlus":{op:"+",associativity:"right"},"OperatorNode:unaryMinus":{op:"-",associativity:"right"},"OperatorNode:bitNot":{op:"~",associativity:"right"},"OperatorNode:not":{op:"not",associativity:"right"}},{"OperatorNode:pow":{op:"^",associativity:"right",associativeWith:[],latexRightParens:!1},"OperatorNode:dotPow":{op:".^",associativity:"right",associativeWith:[]}},{"OperatorNode:factorial":{op:"!",associativity:"left"}},{"OperatorNode:ctranspose":{op:"'",associativity:"left"}}];function Ll(e,t){if(!t||"auto"!==t)return e;let r=e;for(;ge(r);)r=r.content;return r}function m(e,t,r,n){let i=e;var a=(i="keep"!==t?e.getContent():i).getIdentifier();let o=null;for(let e=0;e<Ul.length;e++)if(a in Ul[e]){o=e;break}if("OperatorNode:multiply"===a&&i.implicit&&"show"!==r){const e=Ll(i.args[0],t);ae(e)&&n&&"OperatorNode:divide"===n.getIdentifier()&&fe(Ll(n.args[0],t))||"OperatorNode:divide"===e.getIdentifier()&&fe(Ll(e.args[0],t))&&ae(Ll(e.args[1]))||(o+=1)}return o}function $l(e,t){let r=e;e=(r="keep"!==t?e.getContent():r).getIdentifier(),t=m(r,t);if(null===t)return null;t=Ul[t][e];if(ue(t,"associativity")){if("left"===t.associativity)return"left";if("right"===t.associativity)return"right";throw Error("'"+e+"' has the invalid associativity '"+t.associativity+"'.")}return null}function Hl(e,t,r){const n="keep"!==r?e.getContent():e,i="keep"!==r?e.getContent():t,a=n.getIdentifier(),o=i.getIdentifier(),s=m(n,r);if(null===s)return null;var u=Ul[s][a];if(ue(u,"associativeWith")&&u.associativeWith instanceof Array){for(let e=0;e<u.associativeWith.length;e++)if(u.associativeWith[e]===o)return!0;return!1}return null}const Gl="AssignmentNode",Zl=s(Gl,["subset","?matrix","Node"],e=>{var{subset:t,matrix:r,Node:e}=e;const f=kl({subset:t}),p=function(){let{subset:n,matrix:i}={subset:t,matrix:r};return function(r,e,t){try{if(Array.isArray(r))return i(r).subset(e,t).valueOf().forEach((e,t)=>{r[t]=e}),r;if(r&&"function"==typeof r.subset)return r.subset(e,t);if("string"==typeof r)return n(r,e,t);if("object"!=typeof r)throw new TypeError("Cannot apply index: unsupported type of object");if(e.isObjectProperty())return Ve(r,e.getObjectProperty(),t),r;throw TypeError("Cannot apply a numeric index as object property")}catch(r){throw Il(r)}}}();function i(e,t,r){var n=m(e,t=t||"keep",r),e=m(e.value,t,r);return"all"===t||null!==e&&e<=n}class n extends e{constructor(e,t,r){if(super(),this.object=e,this.index=r?t:null,this.value=r||t,!se(e)&&!le(e))throw new TypeError('SymbolNode or AccessorNode expected as "object"');if(se(e)&&"end"===e.name)throw new Error('Cannot assign to symbol "end"');if(this.index&&!he(this.index))throw new TypeError('IndexNode expected as "index"');if(!O(this.value))throw new TypeError('Node expected as "value"')}get name(){return this.index?this.index.isObjectProperty()?this.index.getObjectProperty():"":this.object.name||""}get type(){return Gl}get isAssignmentNode(){return!0}_compile(o,e){const s=this.object._compile(o,e),u=this.index?this.index._compile(o,e):null,c=this.value._compile(o,e),l=this.object.name;if(this.index){if(this.index.isObjectProperty()){const o=this.index.getObjectProperty();return function(e,t,r){var n=s(e,t,r),e=c(e,t,r);return Ve(n,o,e),e}}if(se(this.object))return function(e,t,r){var n=s(e,t,r),r=c(e,t,r),t=u(e,t,n);return e.set(l,p(n,t,r)),r};{const s=this.object.object._compile(o,e);if(this.object.index.isObjectProperty()){const o=this.object.index.getObjectProperty();return function(e,t,r){var n=s(e,t,r),i=Ze(n,o),a=u(e,t,i),e=c(e,t,r);return Ve(n,o,p(i,a,e)),e}}{const l=this.object.index._compile(o,e);return function(e,t,r){var n=s(e,t,r),i=l(e,t,n),a=f(n,i),o=u(e,t,a),e=c(e,t,r);return p(n,i,p(a,o,e)),e}}}}if(se(this.object))return function(e,t,r){t=c(e,t,r);return e.set(l,t),t};throw new TypeError("SymbolNode expected as object")}forEach(e){e(this.object,"object",this),this.index&&e(this.index,"index",this),e(this.value,"value",this)}map(e){var t=this._ifNode(e(this.object,"object",this)),r=this.index?this._ifNode(e(this.index,"index",this)):null,e=this._ifNode(e(this.value,"value",this));return new n(t,r,e)}clone(){return new n(this.object,this.index,this.value)}_toString(e){var t=this.object.toString(e),r=this.index?this.index.toString(e):"";let n=this.value.toString(e);return t+r+" = "+(n=i(this,e&&e.parenthesis,e&&e.implicit)?"("+n+")":n)}toJSON(){return{mathjs:Gl,object:this.object,index:this.index,value:this.value}}static fromJSON(e){return new n(e.object,e.index,e.value)}_toHTML(e){var t=this.object.toHTML(e),r=this.index?this.index.toHTML(e):"";let n=this.value.toHTML(e);return t+r+'<span class="math-operator math-assignment-operator math-variable-assignment-operator math-binary-operator">=</span>'+(n=i(this,e&&e.parenthesis,e&&e.implicit)?'<span class="math-paranthesis math-round-parenthesis">(</span>'+n+'<span class="math-paranthesis math-round-parenthesis">)</span>':n)}_toTex(e){var t=this.object.toTex(e),r=this.index?this.index.toTex(e):"";let n=this.value.toTex(e);return t+r+"="+(n=i(this,e&&e.parenthesis,e&&e.implicit)?`\\left(${n}\\right)`:n)}}return zl(n,"name",Gl),n},{isClass:!0,isNode:!0}),Vl="BlockNode",Wl=s(Vl,["ResultSet","Node"],e=>{let{ResultSet:o,Node:t}=e;class i extends t{constructor(e){if(super(),!Array.isArray(e))throw new Error("Array expected");this.blocks=e.map(function(e){var t=e&&e.node,e=!e||void 0===e.visible||e.visible;if(!O(t))throw new TypeError('Property "node" must be a Node');if("boolean"!=typeof e)throw new TypeError('Property "visible" must be a boolean');return{node:t,visible:e}})}get type(){return Vl}get isBlockNode(){return!0}_compile(t,r){const e=En(this.blocks,function(e){return{evaluate:e.node._compile(t,r),visible:e.visible}});return function(r,n,i){const a=[];return An(e,function(e){var t=e.evaluate(r,n,i);e.visible&&a.push(t)}),new o(a)}}forEach(t){for(let e=0;e<this.blocks.length;e++)t(this.blocks[e].node,"blocks["+e+"].node",this)}map(t){const r=[];for(let e=0;e<this.blocks.length;e++){const i=this.blocks[e],n=this._ifNode(t(i.node,"blocks["+e+"].node",this));r[e]={node:n,visible:i.visible}}return new i(r)}clone(){var e=this.blocks.map(function(e){return{node:e.node,visible:e.visible}});return new i(e)}_toString(t){return this.blocks.map(function(e){return e.node.toString(t)+(e.visible?"":";")}).join("\n")}toJSON(){return{mathjs:Vl,blocks:this.blocks}}static fromJSON(e){return new i(e.blocks)}_toHTML(t){return this.blocks.map(function(e){return e.node.toHTML(t)+(e.visible?"":'<span class="math-separator">;</span>')}).join('<span class="math-separator"><br /></span>')}_toTex(t){return this.blocks.map(function(e){return e.node.toTex(t)+(e.visible?"":";")}).join("\\;\\;\n")}}return zl(i,"name",Vl),i},{isClass:!0,isNode:!0}),Yl="ConditionalNode",Jl=s(Yl,["Node"],e=>{e=e.Node;class t extends e{constructor(e,t,r){if(super(),!O(e))throw new TypeError("Parameter condition must be a Node");if(!O(t))throw new TypeError("Parameter trueExpr must be a Node");if(!O(r))throw new TypeError("Parameter falseExpr must be a Node");this.condition=e,this.trueExpr=t,this.falseExpr=r}get type(){return Yl}get isConditionalNode(){return!0}_compile(e,t){const n=this.condition._compile(e,t),i=this.trueExpr._compile(e,t),a=this.falseExpr._compile(e,t);return function(e,t,r){return(function(e){if("number"==typeof e||"boolean"==typeof e||"string"==typeof e)return e;if(e){if(Q(e))return!e.isZero();if(te(e))return e.re||e.im;if(L(e))return e.value}if(null!=e)throw new TypeError('Unsupported type of condition "'+K(e)+'"')}(n(e,t,r))?i:a)(e,t,r)}}forEach(e){e(this.condition,"condition",this),e(this.trueExpr,"trueExpr",this),e(this.falseExpr,"falseExpr",this)}map(e){return new t(this._ifNode(e(this.condition,"condition",this)),this._ifNode(e(this.trueExpr,"trueExpr",this)),this._ifNode(e(this.falseExpr,"falseExpr",this)))}clone(){return new t(this.condition,this.trueExpr,this.falseExpr)}_toString(e){var t=e&&e.parenthesis?e.parenthesis:"keep",r=m(this,t,e&&e.implicit);let n=this.condition.toString(e);var i=m(this.condition,t,e&&e.implicit);("all"===t||"OperatorNode"===this.condition.type||null!==i&&i<=r)&&(n="("+n+")");let a=this.trueExpr.toString(e);i=m(this.trueExpr,t,e&&e.implicit);("all"===t||"OperatorNode"===this.trueExpr.type||null!==i&&i<=r)&&(a="("+a+")");let o=this.falseExpr.toString(e);i=m(this.falseExpr,t,e&&e.implicit);return("all"===t||"OperatorNode"===this.falseExpr.type||null!==i&&i<=r)&&(o="("+o+")"),n+" ? "+a+" : "+o}toJSON(){return{mathjs:Yl,condition:this.condition,trueExpr:this.trueExpr,falseExpr:this.falseExpr}}static fromJSON(e){return new t(e.condition,e.trueExpr,e.falseExpr)}_toHTML(e){var t=e&&e.parenthesis?e.parenthesis:"keep",r=m(this,t,e&&e.implicit);let n=this.condition.toHTML(e);var i=m(this.condition,t,e&&e.implicit);("all"===t||"OperatorNode"===this.condition.type||null!==i&&i<=r)&&(n='<span class="math-parenthesis math-round-parenthesis">(</span>'+n+'<span class="math-parenthesis math-round-parenthesis">)</span>');let a=this.trueExpr.toHTML(e);i=m(this.trueExpr,t,e&&e.implicit);("all"===t||"OperatorNode"===this.trueExpr.type||null!==i&&i<=r)&&(a='<span class="math-parenthesis math-round-parenthesis">(</span>'+a+'<span class="math-parenthesis math-round-parenthesis">)</span>');let o=this.falseExpr.toHTML(e);i=m(this.falseExpr,t,e&&e.implicit);return("all"===t||"OperatorNode"===this.falseExpr.type||null!==i&&i<=r)&&(o='<span class="math-parenthesis math-round-parenthesis">(</span>'+o+'<span class="math-parenthesis math-round-parenthesis">)</span>'),n+'<span class="math-operator math-conditional-operator">?</span>'+a+'<span class="math-operator math-conditional-operator">:</span>'+o}_toTex(e){return"\\begin{cases} {"+this.trueExpr.toTex(e)+"}, &\\quad{\\text{if }\\;"+this.condition.toTex(e)+"}\\\\{"+this.falseExpr.toTex(e)+"}, &\\quad{\\text{otherwise}}\\end{cases}"}}return zl(t,"name",Yl),t},{isClass:!0,isNode:!0});var Xl=kh(3144);const Ql={Alpha:"A",alpha:"\\alpha",Beta:"B",beta:"\\beta",Gamma:"\\Gamma",gamma:"\\gamma",Delta:"\\Delta",delta:"\\delta",Epsilon:"E",epsilon:"\\epsilon",varepsilon:"\\varepsilon",Zeta:"Z",zeta:"\\zeta",Eta:"H",eta:"\\eta",Theta:"\\Theta",theta:"\\theta",vartheta:"\\vartheta",Iota:"I",iota:"\\iota",Kappa:"K",kappa:"\\kappa",varkappa:"\\varkappa",Lambda:"\\Lambda",lambda:"\\lambda",Mu:"M",mu:"\\mu",Nu:"N",nu:"\\nu",Xi:"\\Xi",xi:"\\xi",Omicron:"O",omicron:"o",Pi:"\\Pi",pi:"\\pi",varpi:"\\varpi",Rho:"P",rho:"\\rho",varrho:"\\varrho",Sigma:"\\Sigma",sigma:"\\sigma",varsigma:"\\varsigma",Tau:"T",tau:"\\tau",Upsilon:"\\Upsilon",upsilon:"\\upsilon",Phi:"\\Phi",phi:"\\phi",varphi:"\\varphi",Chi:"X",chi:"\\chi",Psi:"\\Psi",psi:"\\psi",Omega:"\\Omega",omega:"\\omega",true:"\\mathrm{True}",false:"\\mathrm{False}",i:"i",inf:"\\infty",Inf:"\\infty",infinity:"\\infty",Infinity:"\\infty",oo:"\\infty",lim:"\\lim",undefined:"\\mathbf{?}"},f={transpose:"^\\top",ctranspose:"^H",factorial:"!",pow:"^",dotPow:".^\\wedge",unaryPlus:"+",unaryMinus:"-",bitNot:"\\~",not:"\\neg",multiply:"\\cdot",divide:"\\frac",dotMultiply:".\\cdot",dotDivide:".:",mod:"\\mod",add:"+",subtract:"-",to:"\\rightarrow",leftShift:"<<",rightArithShift:">>",rightLogShift:">>>",equal:"=",unequal:"\\neq",smaller:"<",larger:">",smallerEq:"\\leq",largerEq:"\\geq",bitAnd:"\\&",bitXor:"\\underline{|}",bitOr:"|",and:"\\wedge",xor:"\\veebar",or:"\\vee"},Kl={abs:{1:"\\left|${args[0]}\\right|"},add:{2:`\\left(\${args[0]}${f.add}\${args[1]}\\right)`},cbrt:{1:"\\sqrt[3]{${args[0]}}"},ceil:{1:"\\left\\lceil${args[0]}\\right\\rceil"},cube:{1:"\\left(${args[0]}\\right)^3"},divide:{2:"\\frac{${args[0]}}{${args[1]}}"},dotDivide:{2:`\\left(\${args[0]}${f.dotDivide}\${args[1]}\\right)`},dotMultiply:{2:`\\left(\${args[0]}${f.dotMultiply}\${args[1]}\\right)`},dotPow:{2:`\\left(\${args[0]}${f.dotPow}\${args[1]}\\right)`},exp:{1:"\\exp\\left(${args[0]}\\right)"},expm1:`\\left(e${f.pow}{\${args[0]}}-1\\right)`,fix:{1:"\\mathrm{${name}}\\left(${args[0]}\\right)"},floor:{1:"\\left\\lfloor${args[0]}\\right\\rfloor"},gcd:"\\gcd\\left(${args}\\right)",hypot:"\\hypot\\left(${args}\\right)",log:{1:"\\ln\\left(${args[0]}\\right)",2:"\\log_{${args[1]}}\\left(${args[0]}\\right)"},log10:{1:"\\log_{10}\\left(${args[0]}\\right)"},log1p:{1:"\\ln\\left(${args[0]}+1\\right)",2:"\\log_{${args[1]}}\\left(${args[0]}+1\\right)"},log2:"\\log_{2}\\left(${args[0]}\\right)",mod:{2:`\\left(\${args[0]}${f.mod}\${args[1]}\\right)`},multiply:{2:`\\left(\${args[0]}${f.multiply}\${args[1]}\\right)`},norm:{1:"\\left\\|${args[0]}\\right\\|",2:void 0},nthRoot:{2:"\\sqrt[${args[1]}]{${args[0]}}"},nthRoots:{2:"\\{y : $y^{args[1]} = {${args[0]}}\\}"},pow:{2:`\\left(\${args[0]}\\right)${f.pow}{\${args[1]}}`},round:{1:"\\left\\lfloor${args[0]}\\right\\rceil",2:void 0},sign:{1:"\\mathrm{${name}}\\left(${args[0]}\\right)"},sqrt:{1:"\\sqrt{${args[0]}}"},square:{1:"\\left(${args[0]}\\right)^2"},subtract:{2:`\\left(\${args[0]}${f.subtract}\${args[1]}\\right)`},unaryMinus:{1:f.unaryMinus+"\\left(${args[0]}\\right)"},unaryPlus:{1:f.unaryPlus+"\\left(${args[0]}\\right)"},bitAnd:{2:`\\left(\${args[0]}${f.bitAnd}\${args[1]}\\right)`},bitNot:{1:f.bitNot+"\\left(${args[0]}\\right)"},bitOr:{2:`\\left(\${args[0]}${f.bitOr}\${args[1]}\\right)`},bitXor:{2:`\\left(\${args[0]}${f.bitXor}\${args[1]}\\right)`},leftShift:{2:`\\left(\${args[0]}${f.leftShift}\${args[1]}\\right)`},rightArithShift:{2:`\\left(\${args[0]}${f.rightArithShift}\${args[1]}\\right)`},rightLogShift:{2:`\\left(\${args[0]}${f.rightLogShift}\${args[1]}\\right)`},bellNumbers:{1:"\\mathrm{B}_{${args[0]}}"},catalan:{1:"\\mathrm{C}_{${args[0]}}"},stirlingS2:{2:"\\mathrm{S}\\left(${args}\\right)"},arg:{1:"\\arg\\left(${args[0]}\\right)"},conj:{1:"\\left(${args[0]}\\right)^*"},im:{1:"\\Im\\left\\lbrace${args[0]}\\right\\rbrace"},re:{1:"\\Re\\left\\lbrace${args[0]}\\right\\rbrace"},and:{2:`\\left(\${args[0]}${f.and}\${args[1]}\\right)`},not:{1:f.not+"\\left(${args[0]}\\right)"},or:{2:`\\left(\${args[0]}${f.or}\${args[1]}\\right)`},xor:{2:`\\left(\${args[0]}${f.xor}\${args[1]}\\right)`},cross:{2:"\\left(${args[0]}\\right)\\times\\left(${args[1]}\\right)"},ctranspose:{1:"\\left(${args[0]}\\right)"+f.ctranspose},det:{1:"\\det\\left(${args[0]}\\right)"},dot:{2:"\\left(${args[0]}\\cdot${args[1]}\\right)"},expm:{1:"\\exp\\left(${args[0]}\\right)"},inv:{1:"\\left(${args[0]}\\right)^{-1}"},pinv:{1:"\\left(${args[0]}\\right)^{+}"},sqrtm:{1:`{\${args[0]}}${f.pow}{\\frac{1}{2}}`},trace:{1:"\\mathrm{tr}\\left(${args[0]}\\right)"},transpose:{1:"\\left(${args[0]}\\right)"+f.transpose},combinations:{2:"\\binom{${args[0]}}{${args[1]}}"},combinationsWithRep:{2:"\\left(\\!\\!{\\binom{${args[0]}}{${args[1]}}}\\!\\!\\right)"},factorial:{1:"\\left(${args[0]}\\right)"+f.factorial},gamma:{1:"\\Gamma\\left(${args[0]}\\right)"},lgamma:{1:"\\ln\\Gamma\\left(${args[0]}\\right)"},equal:{2:`\\left(\${args[0]}${f.equal}\${args[1]}\\right)`},larger:{2:`\\left(\${args[0]}${f.larger}\${args[1]}\\right)`},largerEq:{2:`\\left(\${args[0]}${f.largerEq}\${args[1]}\\right)`},smaller:{2:`\\left(\${args[0]}${f.smaller}\${args[1]}\\right)`},smallerEq:{2:`\\left(\${args[0]}${f.smallerEq}\${args[1]}\\right)`},unequal:{2:`\\left(\${args[0]}${f.unequal}\${args[1]}\\right)`},erf:{1:"erf\\left(${args[0]}\\right)"},max:"\\max\\left(${args}\\right)",min:"\\min\\left(${args}\\right)",variance:"\\mathrm{Var}\\left(${args}\\right)",acos:{1:"\\cos^{-1}\\left(${args[0]}\\right)"},acosh:{1:"\\cosh^{-1}\\left(${args[0]}\\right)"},acot:{1:"\\cot^{-1}\\left(${args[0]}\\right)"},acoth:{1:"\\coth^{-1}\\left(${args[0]}\\right)"},acsc:{1:"\\csc^{-1}\\left(${args[0]}\\right)"},acsch:{1:"\\mathrm{csch}^{-1}\\left(${args[0]}\\right)"},asec:{1:"\\sec^{-1}\\left(${args[0]}\\right)"},asech:{1:"\\mathrm{sech}^{-1}\\left(${args[0]}\\right)"},asin:{1:"\\sin^{-1}\\left(${args[0]}\\right)"},asinh:{1:"\\sinh^{-1}\\left(${args[0]}\\right)"},atan:{1:"\\tan^{-1}\\left(${args[0]}\\right)"},atan2:{2:"\\mathrm{atan2}\\left(${args}\\right)"},atanh:{1:"\\tanh^{-1}\\left(${args[0]}\\right)"},cos:{1:"\\cos\\left(${args[0]}\\right)"},cosh:{1:"\\cosh\\left(${args[0]}\\right)"},cot:{1:"\\cot\\left(${args[0]}\\right)"},coth:{1:"\\coth\\left(${args[0]}\\right)"},csc:{1:"\\csc\\left(${args[0]}\\right)"},csch:{1:"\\mathrm{csch}\\left(${args[0]}\\right)"},sec:{1:"\\sec\\left(${args[0]}\\right)"},sech:{1:"\\mathrm{sech}\\left(${args[0]}\\right)"},sin:{1:"\\sin\\left(${args[0]}\\right)"},sinh:{1:"\\sinh\\left(${args[0]}\\right)"},tan:{1:"\\tan\\left(${args[0]}\\right)"},tanh:{1:"\\tanh\\left(${args[0]}\\right)"},to:{2:`\\left(\${args[0]}${f.to}\${args[1]}\\right)`},numeric:function(e,t){return e.args[0].toTex()},number:{0:"0",1:"\\left(${args[0]}\\right)",2:"\\left(\\left(${args[0]}\\right)${args[1]}\\right)"},string:{0:'\\mathtt{""}',1:"\\mathrm{string}\\left(${args[0]}\\right)"},bignumber:{0:"0",1:"\\left(${args[0]}\\right)"},bigint:{0:"0",1:"\\left(${args[0]}\\right)"},complex:{0:"0",1:"\\left(${args[0]}\\right)",2:`\\left(\\left(\${args[0]}\\right)+${Ql.i}\\cdot\\left(\${args[1]}\\right)\\right)`},matrix:{0:"\\begin{bmatrix}\\end{bmatrix}",1:"\\left(${args[0]}\\right)",2:"\\left(${args[0]}\\right)"},sparse:{0:"\\begin{bsparse}\\end{bsparse}",1:"\\left(${args[0]}\\right)"},unit:{1:"\\left(${args[0]}\\right)",2:"\\left(\\left(${args[0]}\\right)${args[1]}\\right)"}},ef={deg:"^\\circ"};function tf(e){return Xl(e,{preserveFormatting:!0})}function rf(e,t){return(t=void 0!==t&&t)?ue(ef,e)?ef[e]:"\\mathrm{"+tf(e)+"}":ue(Ql,e)?Ql[e]:tf(e)}const nf="ConstantNode",af=s(nf,["Node"],e=>{e=e.Node;class t extends e{constructor(e){super(),this.value=e}get type(){return nf}get isConstantNode(){return!0}_compile(e,t){const r=this.value;return function(){return r}}forEach(e){}map(e){return this.clone()}clone(){return new t(this.value)}_toString(e){return S(this.value,e)}_toHTML(e){var t=this._toString(e);switch(K(this.value)){case"number":case"bigint":case"BigNumber":case"Fraction":return'<span class="math-number">'+t+"</span>";case"string":return'<span class="math-string">'+t+"</span>";case"boolean":return'<span class="math-boolean">'+t+"</span>";case"null":return'<span class="math-null-symbol">'+t+"</span>";case"undefined":return'<span class="math-undefined">'+t+"</span>";default:return'<span class="math-symbol">'+t+"</span>"}}toJSON(){return{mathjs:nf,value:this.value}}static fromJSON(e){return new t(e.value)}_toTex(e){const t=this._toString(e),r=K(this.value);switch(r){case"string":return"\\mathtt{"+tf(t)+"}";case"number":case"BigNumber":{if(!("BigNumber"===r?this.value.isFinite():isFinite(this.value)))return this.value.valueOf()<0?"-\\infty":"\\infty";const e=t.toLowerCase().indexOf("e");return-1!==e?t.substring(0,e)+"\\cdot10^{"+t.substring(e+1)+"}":t}case"bigint":return t.toString();case"Fraction":return this.value.toLatex();default:return t}}}return zl(t,"name",nf),t},{isClass:!0,isNode:!0}),of="FunctionAssignmentNode",sf=s(of,["typed","Node"],e=>{let{typed:l,Node:t}=e;function i(e,t,r){var n=m(e,t,r),e=m(e.expr,t,r);return"all"===t||null!==e&&e<=n}class r extends t{constructor(e,t,r){if(super(),"string"!=typeof e)throw new TypeError('String expected for parameter "name"');if(!Array.isArray(t))throw new TypeError('Array containing strings or objects expected for parameter "params"');if(!O(r))throw new TypeError('Node expected for parameter "expr"');if(Bl.has(e))throw new Error('Illegal function name, "'+e+'" is a reserved keyword');const n=new Set;for(const e of t){const t="string"==typeof e?e:e.name;if(n.has(t))throw new Error(`Duplicate parameter name "${t}"`);n.add(t)}this.name=e,this.params=t.map(function(e){return e&&e.name||e}),this.types=t.map(function(e){return e&&e.type||"any"}),this.expr=r}get type(){return of}get isFunctionAssignmentNode(){return!0}_compile(e,t){const r=Object.create(t),a=(An(this.params,function(e){r[e]=!0}),this.expr._compile(e,r)),o=this.name,s=this.params,u=Cn(this.types,","),c=o+"("+Cn(this.params,", ")+")";return function(e,r,n){const t={},i=(t[u]=function(){const t=Object.create(r);for(let e=0;e<s.length;e++)t[s[e]]=arguments[e];return a(e,t,n)},l(o,t));return i.syntax=c,e.set(o,i),i}}forEach(e){e(this.expr,"expr",this)}map(e){e=this._ifNode(e(this.expr,"expr",this));return new r(this.name,this.params.slice(0),e)}clone(){return new r(this.name,this.params.slice(0),this.expr)}_toString(e){var t=e&&e.parenthesis?e.parenthesis:"keep";let r=this.expr.toString(e);return i(this,t,e&&e.implicit)&&(r="("+r+")"),this.name+"("+this.params.join(", ")+") = "+r}toJSON(){const r=this.types;return{mathjs:of,name:this.name,params:this.params.map(function(e,t){return{name:e,type:r[t]}}),expr:this.expr}}static fromJSON(e){return new r(e.name,e.params,e.expr)}_toHTML(e){const t=e&&e.parenthesis?e.parenthesis:"keep",r=[];for(let e=0;e<this.params.length;e++)r.push('<span class="math-symbol math-parameter">'+fn(this.params[e])+"</span>");let n=this.expr.toHTML(e);return i(this,t,e&&e.implicit)&&(n='<span class="math-parenthesis math-round-parenthesis">(</span>'+n+'<span class="math-parenthesis math-round-parenthesis">)</span>'),'<span class="math-function">'+fn(this.name)+'</span><span class="math-parenthesis math-round-parenthesis">(</span>'+r.join('<span class="math-separator">,</span>')+'<span class="math-parenthesis math-round-parenthesis">)</span><span class="math-operator math-assignment-operator math-variable-assignment-operator math-binary-operator">=</span>'+n}_toTex(e){var t=e&&e.parenthesis?e.parenthesis:"keep";let r=this.expr.toTex(e);return i(this,t,e&&e.implicit)&&(r=`\\left(${r}\\right)`),"\\mathrm{"+this.name+"}\\left("+this.params.map(rf).join(",")+"\\right)="+r}}return zl(r,"name",of),r},{isClass:!0,isNode:!0}),uf="IndexNode",cf=s(uf,["Node","size"],e=>{let{Node:t,size:s}=e;class n extends t{constructor(e,t){if(super(),this.dimensions=e,this.dotNotation=t||!1,!Array.isArray(e)||!e.every(O))throw new TypeError('Array containing Nodes expected for parameter "dimensions"');if(this.dotNotation&&!this.isObjectProperty())throw new Error("dotNotation only applicable for object properties")}get type(){return uf}get isIndexNode(){return!0}_compile(r,n){const i=En(this.dimensions,function(e,a){if(0<e.filter(e=>e.isSymbolNode&&"end"===e.name).length){const t=Object.create(n),o=(t.end=!0,e._compile(r,t));return function(e,t,r){if(!_(r)&&!g(r)&&!k(r))throw new TypeError('Cannot resolve "end": context must be a Matrix, Array, or string but is '+K(r));const n=s(r).valueOf(),i=Object.create(t);return i.end=n[a],o(e,i,r)}}return e._compile(r,n)}),a=Ze(r,"index");return function(t,r,n){var e=En(i,function(e){return e(t,r,n)});return a(...e)}}forEach(t){for(let e=0;e<this.dimensions.length;e++)t(this.dimensions[e],"dimensions["+e+"]",this)}map(t){const r=[];for(let e=0;e<this.dimensions.length;e++)r[e]=this._ifNode(t(this.dimensions[e],"dimensions["+e+"]",this));return new n(r,this.dotNotation)}clone(){return new n(this.dimensions.slice(0),this.dotNotation)}isObjectProperty(){return 1===this.dimensions.length&&ae(this.dimensions[0])&&"string"==typeof this.dimensions[0].value}getObjectProperty(){return this.isObjectProperty()?this.dimensions[0].value:null}_toString(e){return this.dotNotation?"."+this.getObjectProperty():"["+this.dimensions.join(", ")+"]"}toJSON(){return{mathjs:uf,dimensions:this.dimensions,dotNotation:this.dotNotation}}static fromJSON(e){return new n(e.dimensions,e.dotNotation)}_toHTML(e){const t=[];for(let e=0;e<this.dimensions.length;e++)t[e]=this.dimensions[e].toHTML();return this.dotNotation?'<span class="math-operator math-accessor-operator">.</span><span class="math-symbol math-property">'+fn(this.getObjectProperty())+"</span>":'<span class="math-parenthesis math-square-parenthesis">[</span>'+t.join('<span class="math-separator">,</span>')+'<span class="math-parenthesis math-square-parenthesis">]</span>'}_toTex(t){const e=this.dimensions.map(function(e){return e.toTex(t)});return this.dotNotation?"."+this.getObjectProperty():"_{"+e.join(",")+"}"}}return zl(n,"name",uf),n},{isClass:!0,isNode:!0}),lf="ObjectNode",ff=s(lf,["Node"],e=>{e=e.Node;class r extends e{constructor(t){if(super(),this.properties=t||{},t&&("object"!=typeof t||!Object.keys(t).every(function(e){return O(t[e])})))throw new TypeError("Object containing Nodes expected")}get type(){return lf}get isObjectNode(){return!0}_compile(e,t){const a={};for(const r in this.properties)if(ue(this.properties,r)){const n=cn(r),i=JSON.parse(n),o=Ze(this.properties,r);a[i]=o._compile(e,t)}return function(e,t,r){const n={};for(const i in a)ue(a,i)&&(n[i]=a[i](e,t,r));return n}}forEach(e){for(const t in this.properties)ue(this.properties,t)&&e(this.properties[t],"properties["+cn(t)+"]",this)}map(e){const t={};for(const r in this.properties)ue(this.properties,r)&&(t[r]=this._ifNode(e(this.properties[r],"properties["+cn(r)+"]",this)));return new r(t)}clone(){const e={};for(const t in this.properties)ue(this.properties,t)&&(e[t]=this.properties[t]);return new r(e)}_toString(e){const t=[];for(const r in this.properties)ue(this.properties,r)&&t.push(cn(r)+": "+this.properties[r].toString(e));return"{"+t.join(", ")+"}"}toJSON(){return{mathjs:lf,properties:this.properties}}static fromJSON(e){return new r(e.properties)}_toHTML(e){const t=[];for(const r in this.properties)ue(this.properties,r)&&t.push('<span class="math-symbol math-property">'+fn(r)+'</span><span class="math-operator math-assignment-operator math-property-assignment-operator math-binary-operator">:</span>'+this.properties[r].toHTML(e));return'<span class="math-parenthesis math-curly-parenthesis">{</span>'+t.join('<span class="math-separator">,</span>')+'<span class="math-parenthesis math-curly-parenthesis">}</span>'}_toTex(e){const t=[];for(const r in this.properties)ue(this.properties,r)&&t.push("\\mathbf{"+r+":} & "+this.properties[r].toTex(e)+"\\\\");return"\\left\\{\\begin{array}{ll}"+t.join("\n")+"\\end{array}\\right\\}"}}return zl(r,"name",lf),r},{isClass:!0,isNode:!0});function pf(e,t){return new et(e,new Ke(t),new Set(Object.keys(t)))}const mf="OperatorNode",hf=s(mf,["Node"],e=>{e=e.Node;function c(a,o,s,r,e){const u=m(a,o,s),c=$l(a,o);if("all"===o||2<r.length&&"OperatorNode:add"!==a.getIdentifier()&&"OperatorNode:multiply"!==a.getIdentifier())return r.map(function(e){switch(e.getContent().type){case"ArrayNode":case"ConstantNode":case"SymbolNode":case"ParenthesisNode":return!1;default:return!0}});let l;switch(r.length){case 0:l=[];break;case 1:{const n=m(r[0],o,s,a);if(e&&null!==n){let e,t;if(t="keep"===o?(e=r[0].getIdentifier(),a.getIdentifier()):(e=r[0].getContent().getIdentifier(),a.getContent().getIdentifier()),!1===Ul[u][t].latexLeftParens){l=[!1];break}if(!1===Ul[n][e].latexParens){l=[!1];break}}if(null===n){l=[!1];break}if(n<=u){l=[!0];break}l=[!1]}break;case 2:{let n;var f=m(r[0],o,s,a),p=Hl(a,r[0],o);let i;n=null!==f&&(f===u&&"right"===c&&!p||f<u);var p=m(r[1],o,s,a),t=Hl(a,r[1],o);if(i=null!==p&&(p===u&&"left"===c&&!t||p<u),e){let e,t,r;r="keep"===o?(e=a.getIdentifier(),t=a.args[0].getIdentifier(),a.args[1].getIdentifier()):(e=a.getContent().getIdentifier(),t=a.args[0].getContent().getIdentifier(),a.args[1].getContent().getIdentifier()),null!==f&&(!1===Ul[u][e].latexLeftParens&&(n=!1),!1===Ul[f][t].latexParens&&(n=!1)),null!==p&&(!1===Ul[u][e].latexRightParens&&(i=!1),!1===Ul[p][r].latexParens&&(i=!1))}l=[n,i]}break;default:"OperatorNode:add"!==a.getIdentifier()&&"OperatorNode:multiply"!==a.getIdentifier()||(l=r.map(function(e){var t=m(e,o,s,a),r=Hl(a,e,o),e=$l(e,o);return null!==t&&(u===t&&c===e&&!r||t<u)}))}if(2<=r.length&&"OperatorNode:multiply"===a.getIdentifier()&&a.implicit&&"all"!==o&&"hide"===s)for(let e=1;e<l.length;++e)!function e(t,r){let n=t;if("auto"===r)for(;ge(n);)n=n.content;return!!ae(n)||!!oe(n)&&e(n.args[0],r)}(r[e],o)||l[e-1]||"keep"===o&&ge(r[e-1])||(l[e]=!0);return l}class n extends e{constructor(e,t,r,n,i){if(super(),"string"!=typeof e)throw new TypeError('string expected for parameter "op"');if("string"!=typeof t)throw new TypeError('string expected for parameter "fn"');if(!Array.isArray(r)||!r.every(O))throw new TypeError('Array containing Nodes expected for parameter "args"');this.implicit=!0===n,this.isPercentage=!0===i,this.op=e,this.fn=t,this.args=r||[]}get type(){return mf}get isOperatorNode(){return!0}_compile(n,i){if("string"!=typeof this.fn||!Ye(n,this.fn))throw n[this.fn]?new Error('No access to function "'+this.fn+'"'):new Error("Function "+this.fn+' missing in provided namespace "math"');const a=Ze(n,this.fn),e=En(this.args,function(e){return e._compile(n,i)});if("function"==typeof a&&!0===a.rawArgs){const i=this.args;return function(e,t,r){return a(i,n,pf(e,t))}}if(1===e.length){const n=e[0];return function(e,t,r){return a(n(e,t,r))}}if(2!==e.length)return function(t,r,n){return a.apply(null,En(e,function(e){return e(t,r,n)}))};{const n=e[0],i=e[1];return function(e,t,r){return a(n(e,t,r),i(e,t,r))}}}forEach(t){for(let e=0;e<this.args.length;e++)t(this.args[e],"args["+e+"]",this)}map(t){const r=[];for(let e=0;e<this.args.length;e++)r[e]=this._ifNode(t(this.args[e],"args["+e+"]",this));return new n(this.op,this.fn,r,this.implicit,this.isPercentage)}clone(){return new n(this.op,this.fn,this.args.slice(0),this.implicit,this.isPercentage)}isUnary(){return 1===this.args.length}isBinary(){return 2===this.args.length}_toString(r){const t=r&&r.parenthesis?r.parenthesis:"keep",n=r&&r.implicit?r.implicit:"hide",i=this.args,a=c(this,t,n,i,!1);if(1===i.length){const n=$l(this,t);let e=i[0].toString(r);a[0]&&(e="("+e+")");var o=/[a-zA-Z]+/.test(this.op);return"right"===n?this.op+(o?" ":"")+e:"left"===n?e+(o?" ":"")+this.op:e+this.op}if(2===i.length){let e=i[0].toString(r),t=i[1].toString(r);return a[0]&&(e="("+e+")"),a[1]&&(t="("+t+")"),this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===n?e+" "+t:e+" "+this.op+" "+t}if(2<i.length&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())){const t=i.map(function(e,t){return e=e.toString(r),e=a[t]?"("+e+")":e});return this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===n?t.join(" "):t.join(" "+this.op+" ")}return this.fn+"("+this.args.join(", ")+")"}toJSON(){return{mathjs:mf,op:this.op,fn:this.fn,args:this.args,implicit:this.implicit,isPercentage:this.isPercentage}}static fromJSON(e){return new n(e.op,e.fn,e.args,e.implicit,e.isPercentage)}_toHTML(r){const t=r&&r.parenthesis?r.parenthesis:"keep",n=r&&r.implicit?r.implicit:"hide",i=this.args,a=c(this,t,n,i,!1);if(1===i.length){const n=$l(this,t);let e=i[0].toHTML(r);return a[0]&&(e='<span class="math-parenthesis math-round-parenthesis">(</span>'+e+'<span class="math-parenthesis math-round-parenthesis">)</span>'),"right"===n?'<span class="math-operator math-unary-operator math-lefthand-unary-operator">'+fn(this.op)+"</span>"+e:e+'<span class="math-operator math-unary-operator math-righthand-unary-operator">'+fn(this.op)+"</span>"}if(2===i.length){let e=i[0].toHTML(r),t=i[1].toHTML(r);return a[0]&&(e='<span class="math-parenthesis math-round-parenthesis">(</span>'+e+'<span class="math-parenthesis math-round-parenthesis">)</span>'),a[1]&&(t='<span class="math-parenthesis math-round-parenthesis">(</span>'+t+'<span class="math-parenthesis math-round-parenthesis">)</span>'),this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===n?e+'<span class="math-operator math-binary-operator math-implicit-binary-operator"></span>'+t:e+'<span class="math-operator math-binary-operator math-explicit-binary-operator">'+fn(this.op)+"</span>"+t}{const t=i.map(function(e,t){return e=e.toHTML(r),e=a[t]?'<span class="math-parenthesis math-round-parenthesis">(</span>'+e+'<span class="math-parenthesis math-round-parenthesis">)</span>':e});return 2<i.length&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())?this.implicit&&"OperatorNode:multiply"===this.getIdentifier()&&"hide"===n?t.join('<span class="math-operator math-binary-operator math-implicit-binary-operator"></span>'):t.join('<span class="math-operator math-binary-operator math-explicit-binary-operator">'+fn(this.op)+"</span>"):'<span class="math-function">'+fn(this.fn)+'</span><span class="math-paranthesis math-round-parenthesis">(</span>'+t.join('<span class="math-separator">,</span>')+'<span class="math-paranthesis math-round-parenthesis">)</span>'}}_toTex(n){const i=n&&n.parenthesis?n.parenthesis:"keep",a=n&&n.implicit?n.implicit:"hide",o=this.args,s=c(this,i,a,o,!0);let u=f[this.fn];if(u=void 0===u?this.op:u,1===o.length){const a=$l(this,i);let e=o[0].toTex(n);return s[0]&&(e=`\\left(${e}\\right)`),"right"===a?u+e:e+u}if(2===o.length){const c=o[0];let e=c.toTex(n);s[0]&&(e=`\\left(${e}\\right)`);let t,r=o[1].toTex(n);switch(s[1]&&(r=`\\left(${r}\\right)`),t=("keep"===i?c:c.getContent()).getIdentifier(),this.getIdentifier()){case"OperatorNode:divide":return u+"{"+e+"}{"+r+"}";case"OperatorNode:pow":switch(e="{"+e+"}",r="{"+r+"}",t){case"ConditionalNode":case"OperatorNode:divide":e=`\\left(${e}\\right)`}break;case"OperatorNode:multiply":if(this.implicit&&"hide"===a)return e+"~"+r}return e+u+r}if(2<o.length&&("OperatorNode:add"===this.getIdentifier()||"OperatorNode:multiply"===this.getIdentifier())){const i=o.map(function(e,t){return e=e.toTex(n),e=s[t]?`\\left(${e}\\right)`:e});return"OperatorNode:multiply"===this.getIdentifier()&&this.implicit&&"hide"===a?i.join("~"):i.join(u)}return"\\mathrm{"+this.fn+"}\\left("+o.map(function(e){return e.toTex(n)}).join(",")+"\\right)"}getIdentifier(){return this.type+":"+this.fn}}return zl(n,"name",mf),n},{isClass:!0,isNode:!0}),df="ParenthesisNode",gf=s(df,["Node"],e=>{e=e.Node;class t extends e{constructor(e){if(super(),!O(e))throw new TypeError('Node expected for parameter "content"');this.content=e}get type(){return df}get isParenthesisNode(){return!0}_compile(e,t){return this.content._compile(e,t)}getContent(){return this.content.getContent()}forEach(e){e(this.content,"content",this)}map(e){e=e(this.content,"content",this);return new t(e)}clone(){return new t(this.content)}_toString(e){return!e||!e.parenthesis||e&&"keep"===e.parenthesis?"("+this.content.toString(e)+")":this.content.toString(e)}toJSON(){return{mathjs:df,content:this.content}}static fromJSON(e){return new t(e.content)}_toHTML(e){return!e||!e.parenthesis||e&&"keep"===e.parenthesis?'<span class="math-parenthesis math-round-parenthesis">(</span>'+this.content.toHTML(e)+'<span class="math-parenthesis math-round-parenthesis">)</span>':this.content.toHTML(e)}_toTex(e){return!e||!e.parenthesis||e&&"keep"===e.parenthesis?`\\left(${this.content.toTex(e)}\\right)`:this.content.toTex(e)}}return zl(t,"name",df),t},{isClass:!0,isNode:!0}),yf="RangeNode",xf=s(yf,["Node"],e=>{e=e.Node;function a(e,t,r){const n=m(e,t,r),i={},a=m(e.start,t,r);if(i.start=null!==a&&a<=n||"all"===t,e.step){const a=m(e.step,t,r);i.step=null!==a&&a<=n||"all"===t}e=m(e.end,t,r);return i.end=null!==e&&e<=n||"all"===t,i}class t extends e{constructor(e,t,r){if(super(),!O(e))throw new TypeError("Node expected");if(!O(t))throw new TypeError("Node expected");if(r&&!O(r))throw new TypeError("Node expected");if(3<arguments.length)throw new Error("Too many arguments");this.start=e,this.end=t,this.step=r||null}get type(){return yf}get isRangeNode(){return!0}needsEnd(){return 0<this.filter(function(e){return se(e)&&"end"===e.name}).length}_compile(e,t){const n=e.range,i=this.start._compile(e,t),a=this.end._compile(e,t);if(this.step){const o=this.step._compile(e,t);return function(e,t,r){return n(i(e,t,r),a(e,t,r),o(e,t,r))}}return function(e,t,r){return n(i(e,t,r),a(e,t,r))}}forEach(e){e(this.start,"start",this),e(this.end,"end",this),this.step&&e(this.step,"step",this)}map(e){return new t(this._ifNode(e(this.start,"start",this)),this._ifNode(e(this.end,"end",this)),this.step&&this._ifNode(e(this.step,"step",this)))}clone(){return new t(this.start,this.end,this.step&&this.step)}_toString(t){var r=a(this,t&&t.parenthesis?t.parenthesis:"keep",t&&t.implicit);let n,e=this.start.toString(t);if(r.start&&(e="("+e+")"),n=e,this.step){let e=this.step.toString(t);r.step&&(e="("+e+")"),n+=":"+e}let i=this.end.toString(t);return r.end&&(i="("+i+")"),n+=":"+i}toJSON(){return{mathjs:yf,start:this.start,end:this.end,step:this.step}}static fromJSON(e){return new t(e.start,e.end,e.step)}_toHTML(t){var r=a(this,t&&t.parenthesis?t.parenthesis:"keep",t&&t.implicit);let n,e=this.start.toHTML(t);if(r.start&&(e='<span class="math-parenthesis math-round-parenthesis">(</span>'+e+'<span class="math-parenthesis math-round-parenthesis">)</span>'),n=e,this.step){let e=this.step.toHTML(t);r.step&&(e='<span class="math-parenthesis math-round-parenthesis">(</span>'+e+'<span class="math-parenthesis math-round-parenthesis">)</span>'),n+='<span class="math-operator math-range-operator">:</span>'+e}let i=this.end.toHTML(t);return r.end&&(i='<span class="math-parenthesis math-round-parenthesis">(</span>'+i+'<span class="math-parenthesis math-round-parenthesis">)</span>'),n+='<span class="math-operator math-range-operator">:</span>'+i}_toTex(t){var r=a(this,t&&t.parenthesis?t.parenthesis:"keep",t&&t.implicit);let n=this.start.toTex(t);if(r.start&&(n=`\\left(${n}\\right)`),this.step){let e=this.step.toTex(t);r.step&&(e=`\\left(${e}\\right)`),n+=":"+e}let e=this.end.toTex(t);return r.end&&(e=`\\left(${e}\\right)`),n+=":"+e}}return zl(t,"name",yf),t},{isClass:!0,isNode:!0}),bf="RelationalNode",vf=s(bf,["Node"],e=>{e=e.Node;const o={equal:"==",unequal:"!=",smaller:"<",larger:">",smallerEq:"<=",largerEq:">="};class t extends e{constructor(e,t){if(super(),!Array.isArray(e))throw new TypeError("Parameter conditionals must be an array");if(!Array.isArray(t))throw new TypeError("Parameter params must be an array");if(e.length!==t.length-1)throw new TypeError("Parameter params must contain exactly one more element than parameter conditionals");this.conditionals=e,this.params=t}get type(){return bf}get isRelationalNode(){return!0}_compile(o,t){const s=this,u=this.params.map(e=>e._compile(o,t));return function(t,r,n){let i,a=u[0](t,r,n);for(let e=0;e<s.conditionals.length;e++)if(i=a,a=u[e+1](t,r,n),!Ze(o,s.conditionals[e])(i,a))return!1;return!0}}forEach(r){this.params.forEach((e,t)=>r(e,"params["+t+"]",this),this)}map(r){return new t(this.conditionals.slice(),this.params.map((e,t)=>this._ifNode(r(e,"params["+t+"]",this)),this))}clone(){return new t(this.conditionals,this.params)}_toString(n){const i=n&&n.parenthesis?n.parenthesis:"keep",a=m(this,i,n&&n.implicit),t=this.params.map(function(e,t){var r=m(e,i,n&&n.implicit);return"all"===i||null!==r&&r<=a?"("+e.toString(n)+")":e.toString(n)});let r=t[0];for(let e=0;e<this.conditionals.length;e++)r=(r+=" "+o[this.conditionals[e]])+(" "+t[e+1]);return r}toJSON(){return{mathjs:bf,conditionals:this.conditionals,params:this.params}}static fromJSON(e){return new t(e.conditionals,e.params)}_toHTML(n){const i=n&&n.parenthesis?n.parenthesis:"keep",a=m(this,i,n&&n.implicit),t=this.params.map(function(e,t){var r=m(e,i,n&&n.implicit);return"all"===i||null!==r&&r<=a?'<span class="math-parenthesis math-round-parenthesis">(</span>'+e.toHTML(n)+'<span class="math-parenthesis math-round-parenthesis">)</span>':e.toHTML(n)});let r=t[0];for(let e=0;e<this.conditionals.length;e++)r+='<span class="math-operator math-binary-operator math-explicit-binary-operator">'+fn(o[this.conditionals[e]])+"</span>"+t[e+1];return r}_toTex(n){const i=n&&n.parenthesis?n.parenthesis:"keep",a=m(this,i,n&&n.implicit),t=this.params.map(function(e,t){var r=m(e,i,n&&n.implicit);return"all"===i||null!==r&&r<=a?"\\left("+e.toTex(n)+"\right)":e.toTex(n)});let r=t[0];for(let e=0;e<this.conditionals.length;e++)r+=f[this.conditionals[e]]+t[e+1];return r}}return zl(t,"name",bf),t},{isClass:!0,isNode:!0}),wf=s("SymbolNode",["math","?Unit","Node"],e=>{let{math:n,Unit:a,Node:t}=e;function o(e){return!!a&&a.isValuelessUnit(e)}class s extends t{constructor(e){if(super(),"string"!=typeof e)throw new TypeError('String expected for parameter "name"');this.name=e}get type(){return"SymbolNode"}get isSymbolNode(){return!0}_compile(n,e){const i=this.name;if(!0===e[i])return function(e,t,r){return Ze(t,i)};if(i in n)return function(e,t,r){return e.has(i)?e.get(i):Ze(n,i)};{const n=o(i);return function(e,t,r){return e.has(i)?e.get(i):n?new a(null,i):s.onUndefinedSymbol(i)}}}forEach(e){}map(e){return this.clone()}static onUndefinedSymbol(e){throw new Error("Undefined symbol "+e)}clone(){return new s(this.name)}_toString(e){return this.name}_toHTML(e){var t=fn(this.name);return"true"===t||"false"===t?'<span class="math-symbol math-boolean">'+t+"</span>":"i"===t?'<span class="math-symbol math-imaginary-symbol">'+t+"</span>":"Infinity"===t?'<span class="math-symbol math-infinity-symbol">'+t+"</span>":"NaN"===t?'<span class="math-symbol math-nan-symbol">'+t+"</span>":"null"===t?'<span class="math-symbol math-null-symbol">'+t+"</span>":"undefined"===t?'<span class="math-symbol math-undefined-symbol">'+t+"</span>":'<span class="math-symbol">'+t+"</span>"}toJSON(){return{mathjs:"SymbolNode",name:this.name}}static fromJSON(e){return new s(e.name)}_toTex(e){let t=!1;void 0===n[this.name]&&o(this.name)&&(t=!0);var r=rf(this.name,t);return"\\"===r[0]?r:" "+r}}return s},{isClass:!0,isNode:!0}),Nf="FunctionNode",Ef=s(Nf,["math","Node","SymbolNode"],e=>{var t;let{math:i,Node:r,SymbolNode:n}=e;const h=e=>S(e,{truncate:78});function a(e,t,r){let n="";const i=/\$(?:\{([a-z_][a-z_0-9]*)(?:\[([0-9]+)\])?\}|\$)/gi;let a,o=0;for(;null!==(a=i.exec(e));)if(n+=e.substring(o,a.index),o=a.index,"$$"===a[0])n+="$",o++;else{o+=a[0].length;const e=t[a[1]];if(!e)throw new ReferenceError("Template: Property "+a[1]+" does not exist.");if(void 0===a[2])switch(typeof e){case"string":n+=e;break;case"object":if(O(e))n+=e.toTex(r);else{if(!Array.isArray(e))throw new TypeError("Template: "+a[1]+" has to be a Node, String or array of Nodes");n+=e.map(function(e,t){if(O(e))return e.toTex(r);throw new TypeError("Template: "+a[1]+"["+t+"] is not a Node.")}).join(",")}break;default:throw new TypeError("Template: "+a[1]+" has to be a Node, String or array of Nodes")}else{if(!O(e[a[2]]&&e[a[2]]))throw new TypeError("Template: "+a[1]+"["+a[2]+"] is not a Node.");n+=e[a[2]].toTex(r)}}return n+=e.slice(o)}class d extends r{constructor(e,t){if(super(),!O(e="string"==typeof e?new n(e):e))throw new TypeError('Node expected as parameter "fn"');if(!Array.isArray(t)||!t.every(O))throw new TypeError('Array containing Nodes expected for parameter "args"');this.fn=e,this.args=t||[]}get name(){return this.fn.name||""}get type(){return Nf}get isFunctionNode(){return!0}_compile(a,i){const o=this.args.map(e=>e._compile(a,i));if(!se(this.fn)){if(le(this.fn)&&he(this.fn.index)&&this.fn.index.isObjectProperty()){const s=this.fn.object._compile(a,i),u=this.fn.index.getObjectProperty(),h=this.args;return function(t,r,n){const e=s(t,r,n),i=function(e,t){if(Ye(e,t))return e[t];throw new Error('No access to method "'+t+'"')}(e,u);if(null!=i&&i.rawArgs)return i(h,a,pf(t,r));{const a=o.map(e=>e(t,r,n));return i.apply(e,a)}}}{const c=this.fn.toString(),l=this.fn._compile(a,i),f=this.args;return function(t,r,n){const e=l(t,r,n);if("function"!=typeof e)throw new TypeError(`Expression '${c}' did not evaluate to a function; value is:
-  `+h(e));if(e.rawArgs)return e(f,a,pf(t,r));{const a=o.map(e=>e(t,r,n));return e.apply(e,a)}}}}{const p=this.fn.name;if(i[p]){const i=this.args;return function(t,r,n){const e=Ze(r,p);if("function"!=typeof e)throw new TypeError(`Argument '${p}' was not a function; received: `+h(e));if(e.rawArgs)return e(i,a,pf(t,r));{const a=o.map(e=>e(t,r,n));return e.apply(e,a)}}}{const i=p in a?Ze(a,p):void 0,e="function"==typeof i&&!0===i.rawArgs,m=e=>{let t;if(e.has(p))t=e.get(p);else{if(!(p in a))return d.onUndefinedFunction(p);t=Ze(a,p)}if("function"==typeof t)return t;throw new TypeError(`'${p}' is not a function; its value is:
-  `+h(t))};if(e){const i=this.args;return function(e,t,r){return m(e)(i,a,pf(e,t))}}switch(o.length){case 0:return function(e,t,r){return m(e)()};case 1:return function(e,t,r){return m(e)((0,o[0])(e,t,r))};case 2:return function(e,t,r){const n=m(e),i=o[0],a=o[1];return n(i(e,t,r),a(e,t,r))};default:return function(t,r,n){return m(t)(...o.map(e=>e(t,r,n)))}}}}}forEach(t){t(this.fn,"fn",this);for(let e=0;e<this.args.length;e++)t(this.args[e],"args["+e+"]",this)}map(t){const e=this._ifNode(t(this.fn,"fn",this)),r=[];for(let e=0;e<this.args.length;e++)r[e]=this._ifNode(t(this.args[e],"args["+e+"]",this));return new d(e,r)}clone(){return new d(this.fn,this.args.slice(0))}toString(e){let t;var r=this.fn.toString(e);return void 0!==(t=e&&"object"==typeof e.handler&&ue(e.handler,r)?e.handler[r](this,e):t)?t:super.toString(e)}_toString(t){const e=this.args.map(function(e){return e.toString(t)});return(pe(this.fn)?"("+this.fn.toString(t)+")":this.fn.toString(t))+"("+e.join(", ")+")"}toJSON(){return{mathjs:Nf,fn:this.fn,args:this.args}}_toHTML(t){const e=this.args.map(function(e){return e.toHTML(t)});return'<span class="math-function">'+fn(this.fn)+'</span><span class="math-paranthesis math-round-parenthesis">(</span>'+e.join('<span class="math-separator">,</span>')+'<span class="math-paranthesis math-round-parenthesis">)</span>'}toTex(e){let t;return void 0!==(t=e&&"object"==typeof e.handler&&ue(e.handler,this.name)?e.handler[this.name](this,e):t)?t:super.toTex(e)}_toTex(t){var e=this.args.map(function(e){return e.toTex(t)});let r,n;switch(Kl[this.name]&&(r=Kl[this.name]),typeof(r=!i[this.name]||"function"!=typeof i[this.name].toTex&&"object"!=typeof i[this.name].toTex&&"string"!=typeof i[this.name].toTex?r:i[this.name].toTex)){case"function":n=r(this,t);break;case"string":n=a(r,this,t);break;case"object":switch(typeof r[e.length]){case"function":n=r[e.length](this,t);break;case"string":n=a(r[e.length],this,t)}}return void 0!==n?n:a("\\mathrm{${name}}\\left(${args}\\right)",this,t)}getIdentifier(){return this.type+":"+this.name}}return zl(t=d,"name",Nf),zl(d,"onUndefinedFunction",function(e){throw new Error("Undefined function "+e)}),zl(d,"fromJSON",function(e){return new t(e.fn,e.args)}),d},{isClass:!0,isNode:!0}),Af=s("parse",["typed","numeric","config","AccessorNode","ArrayNode","AssignmentNode","BlockNode","ConditionalNode","ConstantNode","FunctionAssignmentNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","RangeNode","RelationalNode","SymbolNode"],k=>{let{typed:e,numeric:l,config:q,AccessorNode:i,ArrayNode:f,AssignmentNode:o,BlockNode:R,ConditionalNode:P,ConstantNode:p,FunctionAssignmentNode:j,FunctionNode:U,IndexNode:a,ObjectNode:L,OperatorNode:s,ParenthesisNode:$,RangeNode:n,RelationalNode:H,SymbolNode:m}=k;const u=e("parse",{string:function(e){return M(e,{})},"Array | Matrix":function(e){return t(e,{})},"string, Object":function(e,t){return M(e,void 0!==t.nodes?t.nodes:{})},"Array | Matrix, Object":t});function t(e){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};const r=void 0!==t.nodes?t.nodes:{};return ce(e,function(e){if("string"!=typeof e)throw new TypeError("String expected");return M(e,r)})}const h={NULL:0,DELIMITER:1,NUMBER:2,SYMBOL:3,UNKNOWN:4},c={",":!0,"(":!0,")":!0,"[":!0,"]":!0,"{":!0,"}":!0,'"':!0,"'":!0,";":!0,"+":!0,"-":!0,"*":!0,".*":!0,"/":!0,"./":!0,"%":!0,"^":!0,".^":!0,"~":!0,"!":!0,"&":!0,"|":!0,"^|":!0,"=":!0,":":!0,"?":!0,"==":!0,"!=":!0,"<":!0,">":!0,"<=":!0,">=":!0,"<<":!0,">>":!0,">>>":!0},d={mod:!0,to:!0,in:!0,and:!0,xor:!0,or:!0,not:!0},g={true:!0,false:!1,null:null,undefined:void 0},G=["NaN","Infinity"],Z={'"':'"',"'":"'","\\":"\\","/":"/",b:"\b",f:"\f",n:"\n",r:"\r",t:"\t"};function y(e,t){return e.expression.substr(e.index,t)}function x(e){return y(e,1)}function b(e){e.index++}function v(e){return e.expression.charAt(e.index-1)}function w(e){return e.expression.charAt(e.index+1)}function N(e){for(e.tokenType=h.NULL,e.token="",e.comment="";;){if("#"===x(e))for(;"\n"!==x(e)&&""!==x(e);)e.comment+=x(e),b(e);if(!u.isWhitespace(x(e),e.nestingLevel))break;b(e)}if(""===x(e))return e.tokenType=h.DELIMITER;if("\n"===x(e)&&!e.nestingLevel)return e.tokenType=h.DELIMITER,e.token=x(e),b(e);const t=x(e),r=y(e,2),n=y(e,3);if(3===n.length&&c[n])return e.tokenType=h.DELIMITER,e.token=n,b(e),b(e),b(e);if(2===r.length&&c[r])return e.tokenType=h.DELIMITER,e.token=r,b(e),b(e);if(c[t])return e.tokenType=h.DELIMITER,e.token=t,b(e);if(u.isDigitDot(t)){e.tokenType=h.NUMBER;const t=y(e,2);if("0b"===t||"0o"===t||"0x"===t){for(e.token+=x(e),b(e),e.token+=x(e),b(e);u.isHexDigit(x(e));)e.token+=x(e),b(e);if("."===x(e))for(e.token+=".",b(e);u.isHexDigit(x(e));)e.token+=x(e),b(e);else if("i"===x(e))for(e.token+="i",b(e);u.isDigit(x(e));)e.token+=x(e),b(e)}else{if("."===x(e)){if(e.token+=x(e),b(e),!u.isDigit(x(e)))return e.tokenType=h.DELIMITER}else{for(;u.isDigit(x(e));)e.token+=x(e),b(e);u.isDecimalMark(x(e),w(e))&&(e.token+=x(e),b(e))}for(;u.isDigit(x(e));)e.token+=x(e),b(e);if("E"===x(e)||"e"===x(e))if(u.isDigit(w(e))||"-"===w(e)||"+"===w(e)){if(e.token+=x(e),b(e),"+"!==x(e)&&"-"!==x(e)||(e.token+=x(e),b(e)),!u.isDigit(x(e)))throw I(e,'Digit expected, got "'+x(e)+'"');for(;u.isDigit(x(e));)e.token+=x(e),b(e);if(u.isDecimalMark(x(e),w(e)))throw I(e,'Digit expected, got "'+x(e)+'"')}else if("."===w(e))throw b(e),I(e,'Digit expected, got "'+x(e)+'"')}}else{if(!u.isAlpha(x(e),v(e),w(e))){for(e.tokenType=h.UNKNOWN;""!==x(e);)e.token+=x(e),b(e);throw I(e,'Syntax error in part "'+e.token+'"')}for(;u.isAlpha(x(e),v(e),w(e))||u.isDigit(x(e));)e.token+=x(e),b(e);ue(d,e.token)?e.tokenType=h.DELIMITER:e.tokenType=h.SYMBOL}}function E(e){for(;N(e),"\n"===e.token;);}function A(e){e.nestingLevel++}function S(e){e.nestingLevel--}function M(e,t){var r={extraNodes:{},expression:"",comment:"",index:0,token:"",tokenType:h.NULL,nestingLevel:0,conditionalLevel:null},e=(an(r,{expression:e,extraNodes:t}),N(r),function(e){let t;const r=[];let n;for(""!==e.token&&"\n"!==e.token&&";"!==e.token&&(t=C(e),e.comment&&(t.comment=e.comment));"\n"===e.token||";"===e.token;)0===r.length&&t&&(n=";"!==e.token,r.push({node:t,visible:n})),N(e),"\n"!==e.token&&";"!==e.token&&""!==e.token&&(t=C(e),e.comment&&(t.comment=e.comment),n=";"!==e.token,r.push({node:t,visible:n}));return 0<r.length?new R(r):(t||(t=new p(void 0),e.comment&&(t.comment=e.comment)),t)}(r));if(""!==r.token)throw r.tokenType===h.DELIMITER?ie(r,"Unexpected operator "+r.token):I(r,'Unexpected part "'+r.token+'"');return e}function C(e){let t,r,n,i;const a=function(e){let t=function(e){let t=T(e);for(;"or"===e.token;)E(e),t=new s("or","or",[t,T(e)]);return t}(e);for(;"?"===e.token;){var r=e.conditionalLevel,n=(e.conditionalLevel=e.nestingLevel,E(e),t),i=C(e);if(":"!==e.token)throw I(e,"False part of conditional expression expected");e.conditionalLevel=null,E(e);var a=C(e);t=new P(n,i,a),e.conditionalLevel=r}return t}(e);if("="!==e.token)return a;if(se(a))return t=a.name,E(e),n=C(e),new o(new m(t),n);if(le(a))return E(e),n=C(e),new o(a.object,a.index,n);if(me(a)&&se(a.fn)&&(i=!0,r=[],t=a.name,a.args.forEach(function(e,t){se(e)?r[t]=e.name:i=!1}),i))return E(e),n=C(e),new j(t,r,n);throw I(e,"Invalid left hand side of assignment operator =")}function T(e){let t=r(e);for(;"xor"===e.token;)E(e),t=new s("xor","xor",[t,r(e)]);return t}function r(e){let t=D(e);for(;"and"===e.token;)E(e),t=new s("and","and",[t,D(e)]);return t}function D(e){let t=F(e);for(;"|"===e.token;)E(e),t=new s("|","bitOr",[t,F(e)]);return t}function F(e){let t=B(e);for(;"^|"===e.token;)E(e),t=new s("^|","bitXor",[t,B(e)]);return t}function B(e){let t=O(e);for(;"&"===e.token;)E(e),t=new s("&","bitAnd",[t,O(e)]);return t}function O(e){const t=[V(e)],r=[],n={"==":"equal","!=":"unequal","<":"smaller",">":"larger","<=":"smallerEq",">=":"largerEq"};for(;ue(n,e.token);){var i={name:e.token,fn:n[e.token]};r.push(i),E(e),t.push(V(e))}return 1===t.length?t[0]:2===t.length?new s(r[0].name,r[0].fn,t):new H(r.map(e=>e.fn),t)}function V(e){let t,r,n,i;t=W(e);for(var a={"<<":"leftShift",">>":"rightArithShift",">>>":"rightLogShift"};ue(a,e.token);)n=a[r=e.token],E(e),i=[t,W(e)],t=new s(r,n,i);return t}function W(e){let t,r,n,i;t=Y(e);for(var a={to:"to",in:"to"};ue(a,e.token);)n=a[r=e.token],E(e),t="in"===r&&""===e.token?new s("*","multiply",[t,new m("in")],!0):(i=[t,Y(e)],new s(r,n,i));return t}function Y(e){let t;const r=[];if(t=":"===e.token?new p(1):J(e),":"===e.token&&e.conditionalLevel!==e.nestingLevel){for(r.push(t);":"===e.token&&r.length<3;)E(e),")"===e.token||"]"===e.token||","===e.token||""===e.token?r.push(new m("end")):r.push(J(e));t=3===r.length?new n(r[0],r[2],r[1]):new n(r[0],r[1])}return t}function J(e){let t,r,n,i;t=X(e);for(var a={"+":"add","-":"subtract"};ue(a,e.token);){n=a[r=e.token],E(e);var o=X(e);i=o.isPercentage?[t,new s("*","multiply",[t,o])]:[t,o],t=new s(r,n,i)}return t}function X(e){let t,r,n,i;t=Q(e);for(var a={"*":"multiply",".*":"dotMultiply","/":"divide","./":"dotDivide"};ue(a,e.token);)i=a[n=e.token],E(e),r=Q(e),t=new s(n,i,[t,r]);return t}function Q(e){let t,r;for(t=K(e),r=t;e.tokenType===h.SYMBOL||"in"===e.token&&ae(t)||!(e.tokenType!==h.NUMBER||ae(r)||oe(r)&&"!"!==r.op)||"("===e.token;)r=K(e),t=new s("*","multiply",[t,r],!0);return t}function K(e){let t=ee(e),r=t;const n=[];for(;"/"===e.token&&fe(r);){if(n.push(an({},e)),E(e),e.tokenType!==h.NUMBER){an(e,n.pop());break}if(n.push(an({},e)),E(e),e.tokenType!==h.SYMBOL&&"("!==e.token){n.pop(),an(e,n.pop());break}an(e,n.pop()),n.pop(),r=ee(e),t=new s("/","divide",[t,r])}return t}function ee(e){let t,r,n,i;t=_(e);for(var a={"%":"mod",mod:"mod"};ue(a,e.token);)n=a[r=e.token],E(e),t="%"===r&&e.tokenType===h.DELIMITER&&"("!==e.token?new s("/","divide",[t,new p(100)],!1,!0):(i=[t,_(e)],new s(r,n,i));return t}function _(i){var e,t={"-":"unaryMinus","+":"unaryPlus","~":"bitNot",not:"not"};if(ue(t,i.token))return t=t[i.token],a=i.token,E(i),e=[_(i)],new s(a,t,e);{var a=i;let e,t,r,n;return e=function(e){let t,r,n,i;t=function(e){let t=[];if(e.tokenType===h.SYMBOL&&ue(e.extraNodes,e.token)){const l=e.extraNodes[e.token];if(N(e),"("===e.token){if(t=[],A(e),N(e),")"!==e.token)for(t.push(C(e));","===e.token;)N(e),t.push(C(e));if(")"!==e.token)throw I(e,"Parenthesis ) expected");S(e),N(e)}return new l(t)}var r=e;if(r.tokenType===h.SYMBOL||r.tokenType===h.DELIMITER&&r.token in d)return i=r.token,N(r),z(r,ue(g,i)?new p(g[i]):G.includes(i)?new p(l(i,"number")):new m(i));var i=r;if('"'===i.token||"'"===i.token)return u=te(i,i.token),z(i,new p(u));{var a=i;let e,t,r,n;if("["!==a.token){var o=a;if("{"!==o.token){var s,u=o;if(u.tokenType===h.NUMBER)return i=u.token,N(u),c=we(i,q),i=l(i,c),new p(i);var c=u;if("("!==c.token)throw""===(s=c).token?I(s,"Unexpected end of expression"):I(s,"Value expected");if(A(c),N(c),s=C(c),")"!==c.token)throw I(c,"Parenthesis ) expected");return S(c),N(c),z(c,new $(s))}{let e;A(o);const l={};do{if(N(o),"}"!==o.token){if('"'===o.token||"'"===o.token)e=te(o,o.token);else{if(!(o.tokenType===h.SYMBOL||o.tokenType===h.DELIMITER&&o.token in d))throw I(o,"Symbol or string expected as object key");e=o.token,N(o)}if(":"!==o.token)throw I(o,"Colon : expected after object key");N(o),l[e]=C(o)}}while(","===o.token);if("}"!==o.token)throw I(o,"Comma , or bracket } expected after object value");return S(o),N(o),z(o,new L(l))}}if(A(a),N(a),"]"!==a.token){const l=re(a);if(";"===a.token){for(r=1,t=[l];";"===a.token;)N(a),"]"!==a.token&&(t[r]=re(a),r++);if("]"!==a.token)throw I(a,"End of matrix ] expected");S(a),N(a),n=t[0].items.length;for(let e=1;e<r;e++)if(t[e].items.length!==n)throw ie(a,"Column dimensions mismatch ("+t[e].items.length+" !== "+n+")");e=new f(t)}else{if("]"!==a.token)throw I(a,"End of matrix ] expected");S(a),N(a),e=l}}else S(a),N(a),e=new f([]);return z(a,e)}}(e);for(var a={"!":"factorial","'":"ctranspose"};ue(a,e.token);)n=a[r=e.token],N(e),i=[t],t=z(e,t=new s(r,n,i));return t}(a),"^"!==a.token&&".^"!==a.token||(r="^"===(t=a.token)?"pow":"dotPow",E(a),n=[e,_(a)],e=new s(t,r,n)),e}}function z(e,t,r){let n;for(;("("===e.token||"["===e.token||"."===e.token)&&(!r||r.includes(e.token));)if(n=[],"("===e.token){if(!se(t)&&!le(t))return t;if(A(e),N(e),")"!==e.token)for(n.push(C(e));","===e.token;)N(e),n.push(C(e));if(")"!==e.token)throw I(e,"Parenthesis ) expected");S(e),N(e),t=new U(t,n)}else if("["===e.token){if(A(e),N(e),"]"!==e.token)for(n.push(C(e));","===e.token;)N(e),n.push(C(e));if("]"!==e.token)throw I(e,"Parenthesis ] expected");S(e),N(e),t=new i(t,new a(n))}else{if(N(e),!(e.tokenType===h.SYMBOL||e.tokenType===h.DELIMITER&&e.token in d))throw I(e,"Property name expected after dot");n.push(new p(e.token)),N(e),t=new i(t,new a(n,!0))}return t}function te(e,t){let r="";for(;""!==x(e)&&x(e)!==t;)if("\\"===x(e)){b(e);const t=x(e),n=Z[t];if(void 0!==n)r+=n,e.index+=1;else{if("u"!==t)throw I(e,"Bad escape character \\"+t);{const t=e.expression.slice(e.index+1,e.index+5);if(!/^[0-9A-Fa-f]{4}$/.test(t))throw I(e,"Invalid unicode character \\u"+t);r+=String.fromCharCode(parseInt(t,16)),e.index+=5}}}else r+=x(e),b(e);if(N(e),e.token!==t)throw I(e,`End of string ${t} expected`);return N(e),r}function re(e){const t=[C(e)];let r=1;for(;","===e.token;)N(e),"]"!==e.token&&";"!==e.token&&(t[r]=C(e),r++);return new f(t)}function ne(e){return e.index-e.token.length+1}function I(e,t){const r=ne(e),n=new SyntaxError(t+" (char "+r+")");return n.char=r,n}function ie(e,t){const r=ne(e),n=new SyntaxError(t+" (char "+r+")");return n.char=r,n}return u.isAlpha=function(e,t,r){return u.isValidLatinOrGreek(e)||u.isValidMathSymbol(e,r)||u.isValidMathSymbol(t,e)},u.isValidLatinOrGreek=function(e){return/^[a-zA-Z_$\u00C0-\u02AF\u0370-\u03FF\u2100-\u214F]$/.test(e)},u.isValidMathSymbol=function(e,t){return/^[\uD835]$/.test(e)&&/^[\uDC00-\uDFFF]$/.test(t)&&/^[^\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(t)},u.isWhitespace=function(e,t){return" "===e||"\t"===e||"\n"===e&&0<t},u.isDecimalMark=function(e,t){return"."===e&&"/"!==t&&"*"!==t&&"^"!==t},u.isDigitDot=function(e){return"0"<=e&&e<="9"||"."===e},u.isDigit=function(e){return"0"<=e&&e<="9"},u.isHexDigit=function(e){return"0"<=e&&e<="9"||"a"<=e&&e<="f"||"A"<=e&&e<="F"},e.addConversion({from:"string",to:"Node",convert:u}),u}),Sf="compile",Mf=s(Sf,["typed","parse"],e=>{let{typed:t,parse:r}=e;return t(Sf,{string:function(e){return r(e).compile()},"Array | Matrix":function(e){return ce(e,function(e){return r(e).compile()})}})}),Cf="evaluate",Tf=s(Cf,["typed","parse"],e=>{let{typed:t,parse:r}=e;return t(Cf,{string:function(e){var t=rt();return r(e).compile().evaluate(t)},"string, Map | Object":function(e,t){return r(e).compile().evaluate(t)},"Array | Matrix":function(e){const t=rt();return ce(e,function(e){return r(e).compile().evaluate(t)})},"Array | Matrix, Map | Object":function(e,t){return ce(e,function(e){return r(e).compile().evaluate(t)})}})}),Df=s("Parser",["evaluate"],e=>{let t=e["evaluate"];function r(){if(!(this instanceof r))throw new SyntaxError("Constructor must be called with the new operator");Object.defineProperty(this,"scope",{value:rt(),writable:!1})}return r.prototype.type="Parser",r.prototype.isParser=!0,r.prototype.evaluate=function(e){return t(e,this.scope)},r.prototype.get=function(e){if(this.scope.has(e))return this.scope.get(e)},r.prototype.getAll=function(){var e=this.scope;if(e instanceof Ke)return e.wrappedObject;var t={};for(const r of e.keys())Ve(t,r,e.get(r));return t},r.prototype.getAllAsMap=function(){return this.scope},r.prototype.set=function(e,t){return this.scope.set(e,t),t},r.prototype.remove=function(e){this.scope.delete(e)},r.prototype.clear=function(){this.scope.clear()},r},{isClass:!0}),Ff=s("parser",["typed","Parser"],e=>{let{typed:t,Parser:r}=e;return t("parser",{"":function(){return new r}})}),Bf=s("lup",["typed","matrix","abs","addScalar","divideScalar","multiplyScalar","subtractScalar","larger","equalScalar","unaryMinus","DenseMatrix","SparseMatrix","Spa"],e=>{let{typed:t,matrix:r,abs:C,addScalar:g,divideScalar:T,multiplyScalar:D,subtractScalar:y,larger:F,equalScalar:B,unaryMinus:O,DenseMatrix:x,SparseMatrix:_,Spa:z}=e;return t("lup",{DenseMatrix:n,SparseMatrix:function(n){{var o=n,s,u,c,l;const f=o._size[0],p=o._size[1],m=Math.min(f,p),h=o._values,d=o._index,g=o._ptr,y=[],x=[],b=[],v=[f,m],w=[],N=[],E=[],A=[m,p];let e,r,t;const S=[],M=[];for(e=0;e<f;e++)S[e]=e,M[e]=e;for(r=0;r<p;r++){const o=new z,p=(r<f&&(b.push(y.length),y.push(1),x.push(r)),E.push(w.length),g[r]),m=g[r+1];for(t=p;t<m;t++)e=d[t],o.set(S[e],h[t]);0<r&&o.forEach(0,r-1,function(r,n){_._forEachRow(r,y,x,b,function(e,t){r<e&&o.accumulate(e,O(D(t,n)))})});let n=r,i=o.get(r),a=C(i);o.forEach(r+1,f-1,function(e,t){var r=C(t);F(r,a)&&(n=e,a=r,i=t)}),r!==n&&(_._swapRows(r,n,v[1],y,x,b),_._swapRows(r,n,A[1],w,N,E),o.swap(r,n),s=r,u=n,l=c=void 0,c=M[s],l=M[u],S[c]=u,S[l]=s,M[s]=l,M[u]=c),o.forEach(0,f-1,function(e,t){e<=r?(w.push(t),N.push(e)):(t=T(t,i),B(t,0)||(y.push(t),x.push(e)))})}return E.push(w.length),b.push(y.length),{L:new _({values:y,index:x,ptr:b,size:v}),U:new _({values:w,index:N,ptr:E,size:A}),p:S,toString:function(){return"L: "+this.L.toString()+"\nU: "+this.U.toString()+"\nP: "+this.p}}}},Array:function(e){const t=n(r(e));return{L:t.L.valueOf(),U:t.U.valueOf(),p:t.p}}});function n(n){const i=n._size[0],e=n._size[1];var t=Math.min(i,e);const a=ee(n._data),r=[],o=[i,t],s=[],u=[t,e];let c,l,f;const p=[];for(c=0;c<i;c++)p[c]=c;for(l=0;l<e;l++){if(0<l)for(c=0;c<i;c++){const n=Math.min(c,l);let e=0;for(f=0;f<n;f++)e=g(e,D(a[c][f],a[f][l]));a[c][l]=y(a[c][l],e)}let e=l,t=0,r=0;for(c=l;c<i;c++){const i=a[c][l],g=C(i);F(g,t)&&(e=c,t=g,r=i)}if(l!==e&&(p[l]=[p[e],p[e]=p[l]][0],x._swapRows(l,e,a)),l<i)for(c=l+1;c<i;c++){const n=a[c][l];B(n,0)||(a[c][l]=T(a[c][l],r))}}for(l=0;l<e;l++)for(c=0;c<i;c++)0===l&&(c<e&&(s[c]=[]),r[c]=[]),c<l?(c<e&&(s[c][l]=a[c][l]),l<i&&(r[c][l]=0)):c!==l?(c<e&&(s[c][l]=0),l<i&&(r[c][l]=a[c][l])):(c<e&&(s[c][l]=a[c][l]),l<i&&(r[c][l]=1));const m=new x({data:r,size:o}),h=new x({data:s,size:u}),d=[];for(c=0,t=p.length;c<t;c++)d[p[c]]=c;return{L:m,U:h,p:d,toString:function(){return"L: "+this.L.toString()+"\nU: "+this.U.toString()+"\nP: "+this.p}}}}),Of=s("qr",["typed","matrix","zeros","identity","isZero","equal","sign","sqrt","conj","unaryMinus","addScalar","divideScalar","multiplyScalar","subtractScalar","complex"],e=>{let{typed:t,matrix:r,zeros:f,identity:p,isZero:m,equal:h,sign:d,sqrt:g,conj:y,unaryMinus:x,addScalar:b,divideScalar:v,multiplyScalar:w,subtractScalar:N,complex:i}=e;return an(t("qr",{DenseMatrix:n,SparseMatrix:function(e){throw new Error("qr not implemented for sparse matrices yet")},Array:function(e){const t=n(r(e));return{Q:t.Q.valueOf(),R:t.R.valueOf()}}}),{_denseQRimpl:a});function a(t){const r=t._size[0],n=t._size[1],e=p([r],"dense"),i=e._data,a=t.clone(),o=a._data;let s,u,c;const l=f([r],"");for(c=0;c<Math.min(n,r);++c){const t=o[c][c],f=x(h(t,0)?1:d(t)),p=y(f);let e=0;for(s=c;s<r;s++)e=b(e,w(o[s][c],y(o[s][c])));const a=w(f,g(e));if(!m(a)){const f=N(t,a);for(l[c]=1,s=c+1;s<r;s++)l[s]=v(o[s][c],f);const m=x(y(v(f,a)));let e;for(u=c;u<n;u++){for(e=0,s=c;s<r;s++)e=b(e,w(y(l[s]),o[s][u]));for(e=w(e,m),s=c;s<r;s++)o[s][u]=w(N(o[s][u],w(l[s],e)),p)}for(s=0;s<r;s++){for(e=0,u=c;u<r;u++)e=b(e,w(i[s][u],l[u]));for(e=w(e,m),u=c;u<r;++u)i[s][u]=v(N(i[s][u],w(e,y(l[u]))),p)}}}return{Q:e,R:a,toString:function(){return"Q: "+this.Q.toString()+"\nR: "+this.R.toString()}}}function n(r){const e=a(r),n=e.R._data;if(0<r._data.length){const r="Complex"===n[0][0].type?i(0):0;for(let t=0;t<n.length;++t)for(let e=0;e<t&&e<(n[0]||[]).length;++e)n[t][e]=r}return e}});function _f(e,t,r,n,i,a,o){let s=0;for(r[o]=e;0<=s;){const e=r[o+s],u=r[n+e];-1===u?(s--,a[t++]=e):(r[n+e]=r[i+u],r[o+ ++s]=u)}return t}const zf=s("csAmd",["add","multiply","transpose"],e=>{let{add:H,multiply:G,transpose:Z}=e;return function(i,e){if(!e||i<=0||3<i)return null;var t=e._size,k=t[0],a=t[1];let o=0,q=Math.max(16,10*Math.sqrt(a));t=function(n,i,e,t,a){var o=Z(i);if(1===n&&t===e)return H(i,o);if(2!==n)return G(o,i);{const n=o._index,H=o._ptr;let r=0;for(let t=0;t<e;t++){let e=H[t];if(H[t]=r,!(H[t+1]-e>a))for(const i=H[t+1];e<i;e++)n[r++]=n[e]}return H[e]=r,i=Z(o),G(o,i)}}(i,e,k,a,q=Math.min(a-2,q));{var R=W;const n=t._values,z=t._index,I=t._ptr,$=t._size[1];let r=0;for(let t=0;t<$;t++){let e=I[t];for(I[t]=r;e<I[t+1];e++)R(z[e],t,n?n[e]:1,null)&&(z[r]=z[e],n&&(n[r]=n[e]),r++)}I[$]=r,z.splice(r,z.length-r),n&&n.splice(r,n.length-r)}const s=t._index,u=t._ptr;let P=u[a];const r=[],c=[],l=a+1,f=2*(a+1),p=3*(a+1),m=4*(a+1),h=5*(a+1),d=6*(a+1),g=7*(a+1),y=r;let x,b,v,w,j,N,U,E,A,S,M,C,L,T,D,F,B=function(t,r,n,i,a,o,s,u,c,l,f){for(let e=0;e<t;e++)n[0+e]=r[e+1]-r[e];for(let e=n[0+t]=0;e<=t;e++)n[i+e]=-1,a[e]=-1,n[o+e]=-1,n[s+e]=-1,n[u+e]=1,n[c+e]=1,n[l+e]=0,n[f+e]=n[0+e];var e=V(0,0,n,c,t);return n[l+t]=-2,r[t]=-1,n[c+t]=0,e}(a,u,c,p,y,f,g,l,d,m,h),O=function(t,r,n,i,a,o,s,u,c,l,f){let p=0;for(let e=0;e<t;e++){var m=n[i+e];if(0===m)n[a+e]=-2,p++,r[e]=-1,n[o+e]=0;else if(s<m)n[u+e]=0,n[a+e]=-1,p++,r[e]=-t-2,n[u+t]++;else{const t=n[c+m];-1!==t&&(l[t]=e),n[f+e]=n[c+m],n[c+m]=e}}return p}(a,u,c,h,m,d,q,l,p,y,f),_=0;for(;O<a;){for(v=-1;_<a&&-1===(v=c[p+_]);_++);-1!==c[f+v]&&(y[c[f+v]]=-1),c[p+_]=c[f+v];const i=c[m+v];let e=c[l+v],t=(O+=e,0),r=(c[l+v]=-e,u[v]);const W=0===i?r:P;let n=W;for(w=1;w<=i+1;w++){for(E=w>i?(N=v,U=r,c[0+v]-i):(N=s[r++],U=u[N],c[0+N]),j=1;j<=E;j++)x=s[U++],(A=c[l+x])<=0||(t+=A,c[l+x]=-A,s[n++]=x,-1!==c[f+x]&&(y[c[f+x]]=y[x]),-1!==y[x]?c[f+y[x]]=c[f+x]:c[p+c[h+x]]=c[f+x]);N!==v&&(u[N]=-v-2,c[d+N]=0)}for(0!==i&&(P=n),c[h+v]=t,u[v]=W,c[0+v]=n-W,c[m+v]=-2,B=V(B,o,c,d,a),S=W;S<n;S++)if(x=s[S],!((M=c[m+x])<=0)){A=-c[l+x];const i=B-A;for(r=u[x],C=u[x]+M-1;r<=C;r++)N=s[r],c[d+N]>=B?c[d+N]-=A:0!==c[d+N]&&(c[d+N]=c[h+N]+i)}for(S=W;S<n;S++){for(x=s[S],L=(C=u[x])+c[m+x]-1,T=C,D=0,F=0,r=C;r<=L;r++)if(N=s[r],0!==c[d+N]){const i=c[d+N]-B;0<i?(F+=i,s[T++]=N,D+=N):(u[N]=-v-2,c[d+N]=0)}c[m+x]=T-C+1;const i=T,V=C+c[0+x];for(r=1+L;r<V;r++){b=s[r];const i=c[l+b];i<=0||(F+=i,s[T++]=b,D+=b)}0===F?(u[x]=-v-2,A=-c[l+x],t-=A,e+=A,O+=A,c[l+x]=0,c[m+x]=-1):(c[h+x]=Math.min(c[h+x],F),s[T]=s[i],s[i]=s[C],s[C]=v,c[0+x]=T-C+1,D=(D<0?-D:D)%a,c[f+x]=c[g+D],c[g+D]=x,y[x]=D)}for(c[h+v]=t,o=Math.max(o,t),B=V(B+o,o,c,d,a),S=W;S<n;S++)if(x=s[S],!(0<=c[l+x]))for(D=y[x],x=c[g+D],c[g+D]=-1;-1!==x&&-1!==c[f+x];x=c[f+x],B++){for(E=c[0+x],M=c[m+x],r=u[x]+1;r<=u[x]+E-1;r++)c[d+s[r]]=B;let t=x;for(b=c[f+x];-1!==b;){let e=c[0+b]===E&&c[m+b]===M;for(r=u[b]+1;e&&r<=u[b]+E-1;r++)c[d+s[r]]!==B&&(e=0);e?(u[b]=-x-2,c[l+x]+=c[l+b],c[l+b]=0,c[m+b]=-1,b=c[f+b],c[f+t]=b):(t=b,b=c[f+b])}}for(r=W,S=W;S<n;S++)x=s[S],(A=-c[l+x])<=0||(c[l+x]=A,F=c[h+x]+t-A,F=Math.min(F,a-O-A),-1!==c[p+F]&&(y[c[p+F]]=x),c[f+x]=c[p+F],y[x]=-1,c[p+F]=x,_=Math.min(_,F),c[h+x]=F,s[r++]=x);c[l+v]=e,0==(c[0+v]=r-W)&&(u[v]=-1,c[d+v]=0),0!==i&&(P=r)}for(x=0;x<a;x++)u[x]=-u[x]-2;for(b=0;b<=a;b++)c[p+b]=-1;for(b=a;0<=b;b--)0<c[l+b]||(c[f+b]=c[p+u[b]],c[p+u[b]]=b);for(N=a;0<=N;N--)c[l+N]<=0||-1!==u[N]&&(c[f+N]=c[p+u[N]],c[p+u[N]]=N);for(v=0,x=0;x<=a;x++)-1===u[x]&&(v=_f(x,v,c,p,f,r,d));return r.splice(r.length-1,1),r};function V(e,t,r,n,i){if(e<2||e+t<0){for(let e=0;e<i;e++)0!==r[n+e]&&(r[n+e]=1);e=2}return e}function W(e,t){return e!==t}});const If=s("csCounts",["transpose"],e=>{let S=e["transpose"];return function(e,t,r,n){if(!e||!t||!r)return null;var i=e._size,a=i[0],o=i[1];let s,u,c,l,f,p,m;const h=4*o+(n?o+a+1:0),d=[],g=o,y=2*o,x=3*o,b=4*o,v=5*o+1;for(c=0;c<h;c++)d[c]=-1;const w=[],N=S(e),E=N._index,A=N._ptr;for(c=0;c<o;c++)for(u=r[c],w[u]=-1===d[x+u]?1:0;-1!==u&&-1===d[x+u];u=t[u])d[x+u]=c;if(n){for(c=0;c<o;c++)d[r[c]]=c;for(s=0;s<a;s++){for(c=o,p=A[s],m=A[s+1],f=p;f<m;f++)c=Math.min(c,d[E[f]]);d[v+s]=d[b+c],d[b+c]=s}}for(s=0;s<o;s++)d[0+s]=s;for(c=0;c<o;c++){for(-1!==t[u=r[c]]&&w[t[u]]--,l=n?d[b+c]:u;-1!==l;l=n?d[v+l]:-1)for(f=A[l];f<A[l+1];f++){const e=function(e,t,r,n,i,a,o){let s,u,c,l=0;if(e<=t||r[n+t]<=r[i+e])return-1;if(r[i+e]=r[n+t],i=r[a+e],r[a+e]=t,-1===i)l=1,c=e;else{for(l=2,c=i;c!==r[o+c];c=r[o+c]);for(s=i;s!==c;s=u)u=r[o+s],r[o+s]=c}return{jleaf:l,q:c}}(s=E[f],u,d,x,g,y,0);1<=e.jleaf&&w[u]++,2===e.jleaf&&w[e.q]--}-1!==t[u]&&(d[0+u]=t[u])}for(u=0;u<o;u++)-1!==t[u]&&(w[t[u]]+=w[u]);return w}}),kf=s("csSqr",["add","multiply","transpose"],e=>{var{add:e,multiply:t,transpose:r}=e;const s=zf({add:e,multiply:t,transpose:r}),u=If({transpose:r});return function(e,t,r){const n=t._ptr,i=t._size[1];let a;const o={};if(o.q=s(e,t),e&&!o.q)return null;if(r){const r=e?function(n,t){n._values;const i=n._index,a=n._ptr,e=n._size,r=n._datatype,o=e[0],s=e[1],u=[],c=[];let l=0;for(let e=0;e<s;e++){c[e]=l;const f=t?t[e]:e;for(let e=a[f],t=a[f+1],r=e;r<t;r++){const n=i[r];u[l]=n,l++}}return c[s]=l,n.createSparseMatrix({values:null,index:u,ptr:c,size:[o,s],datatype:r})}(t,o.q):t,n=(o.parent=function(e){if(!e)return null;const i=e._index,a=e._ptr,t=e._size,r=t[0],o=t[1],s=[],u=[],c=o;let l,f;for(l=0;l<r;l++)u[c+l]=-1;for(let n=0;n<o;n++){s[n]=-1,u[0+n]=-1;for(let e=a[n],t=a[n+1],r=e;r<t;r++){const a=i[r];for(l=u[c+a];-1!==l&&l<n;l=f)f=u[0+l],u[0+l]=n,-1===f&&(s[l]=n);u[c+a]=n}}return s}(r),function(e,t){if(!e)return null;let r,n=0;const i=[],a=[],o=t,s=2*t;for(r=0;r<t;r++)a[0+r]=-1;for(r=t-1;0<=r;r--)-1!==e[r]&&(a[o+r]=a[0+e[r]],a[0+e[r]]=r);for(r=0;r<t;r++)-1===e[r]&&(n=_f(r,n,a,0,o,i,s));return i}(o.parent,i));if(o.cp=u(r,o.parent,n,1),r&&o.parent&&o.cp&&function(e,t){var r=e._ptr,n=e._index,e=e._size,i=e[0],a=e[1];t.pinv=[],t.leftmost=[];const o=t.parent,s=t.pinv,u=t.leftmost,c=[],l=i,f=i+a,p=i+2*a;let m,h,d,g,y;for(h=0;h<a;h++)c[l+h]=-1,c[f+h]=-1,c[p+h]=0;for(m=0;m<i;m++)u[m]=-1;for(h=a-1;0<=h;h--)for(g=r[h],y=r[h+1],d=g;d<y;d++)u[n[d]]=h;for(m=i-1;0<=m;m--)(s[m]=-1)!==(h=u[m])&&(0==c[p+h]++&&(c[f+h]=m),c[0+m]=c[l+h],c[l+h]=m);for(t.lnz=0,t.m2=i,h=0;h<a;h++)if(m=c[l+h],t.lnz++,m<0&&(m=t.m2++),s[m]=h,!(--p[h]<=0)){t.lnz+=c[p+h];const e=o[h];-1!==e&&(0===c[p+e]&&(c[f+e]=c[f+h]),c[0+c[f+h]]=c[l+e],c[l+e]=c[0+m],c[p+e]+=c[p+h])}for(m=0;m<i;m++)s[m]<0&&(s[m]=h++);return 1}(r,o))for(o.unz=0,a=0;a<i;a++)o.unz+=o.cp[a]}else o.unz=4*n[i]+i,o.lnz=o.unz;return o}});function qf(e,t){e[t]=-e[t]-2}function Rf(e){return e<0?-e-2:e}const Pf=s("csSpsolve",["divideScalar","multiply","subtract"],e=>{let{divideScalar:x,multiply:b,subtract:v}=e;return function(t,r,p,n,i,a,o){var s=t._values,u=t._index,c=t._ptr,l=t._size[1],e=r._values,f=r._index,m=r._ptr;let h,d,g,y;t=function(e,t,r,n){var i=e._ptr,a=e._size,o=t._index,t=t._ptr,s=a[1];let u,c,l,f=s;for(c=t[p],l=t[p+1],u=c;u<l;u++){const t=o[u];i[t]<0||(f=function(t,r,n,i,a){var o=r._index,s=r._ptr,u=r._size[1];let c,l,f,p=0;for(i[0]=t;0<=p;){t=i[p];const r=a?a[t]:t;s[t]<0||(qf(s,t),i[u+p]=r<0?0:Rf(s[r]));let e=1;for(l=i[u+p],f=r<0?0:Rf(s[r+1]);l<f;l++)if(!(s[c=o[l]]<0)){i[u+p]=l,i[++p]=c,e=0;break}e&&(p--,i[--n]=t)}return n}(t,e,f,r,n))}for(u=f;u<s;u++)qf(i,r[u]);return f}(t,r,n,a);for(h=t;h<l;h++)i[n[h]]=0;for(d=m[p],g=m[p+1],h=d;h<g;h++)i[f[h]]=e[h];for(let e=t;e<l;e++){const r=n[e],p=a?a[r]:r;if(!(p<0))for(d=c[p],g=c[p+1],i[r]=x(i[r],s[o?d:g-1]),h=o?d+1:d,y=o?g:g-1;h<y;h++){const t=u[h];i[t]=v(i[t],b(s[h],i[r]))}}return t}}),jf=s("csLu",["abs","divideScalar","multiply","subtract","larger","largerEq","SparseMatrix"],e=>{let{abs:E,divideScalar:A,multiply:S,subtract:t,larger:M,largerEq:C,SparseMatrix:T}=e;const D=Pf({divideScalar:A,multiply:S,subtract:t});return function(n,e,i){if(!n)return null;var a=n._size[1];let o,s=100,u=100;e&&(o=e.q,s=e.lnz||s,u=e.unz||u);const c=[],l=[],f=[],p=new T({values:c,index:l,ptr:f,size:[a,a]}),m=[],h=[],d=[],g=new T({values:m,index:h,ptr:d,size:[a,a]}),y=[];let x,b;const v=[],w=[];for(x=0;x<a;x++)v[x]=0,y[x]=-1,f[x+1]=0;s=0;for(let r=u=0;r<a;r++){f[r]=s,d[r]=u;const T=o?o[r]:r,g=D(p,n,T,w,v,y,1);let e=-1,t=-1;for(b=g;b<a;b++)if(x=w[b],y[x]<0){const n=E(v[x]);M(n,t)&&(t=n,e=x)}else h[u]=y[x],m[u++]=v[x];if(-1===e||t<=0)return null;y[T]<0&&C(E(v[T]),S(t,i))&&(e=T);var N=v[e];for(h[u]=r,m[u++]=N,y[e]=r,l[s]=e,c[s++]=1,b=g;b<a;b++)x=w[b],y[x]<0&&(l[s]=x,c[s++]=A(v[x],N)),v[x]=0}for(f[a]=s,d[a]=u,b=0;b<s;b++)l[b]=y[l[b]];return c.splice(s,c.length-s),l.splice(s,l.length-s),m.splice(u,m.length-u),h.splice(u,h.length-u),{L:p,U:g,pinv:y}}}),Uf=s("slu",["typed","abs","add","multiply","transpose","divideScalar","subtract","larger","largerEq","SparseMatrix"],e=>{let{typed:t,abs:r,add:n,multiply:i,transpose:a,divideScalar:o,subtract:s,larger:u,largerEq:c,SparseMatrix:l}=e;const f=kf({add:n,multiply:i,transpose:a}),p=jf({abs:r,divideScalar:o,multiply:i,subtract:s,larger:u,largerEq:c,SparseMatrix:l});return t("slu",{"SparseMatrix, number, number":function(e,t,r){if(!v(t)||t<0||3<t)throw new Error("Symbolic Ordering and Analysis order must be an integer number in the interval [0, 3]");if(r<0||1<r)throw new Error("Partial pivoting threshold must be a number from 0 to 1");t=f(t,e,!1),e=p(e,t,r);return{L:e.L,U:e.U,p:e.pinv,q:t.q,toString:function(){return"L: "+this.L.toString()+"\nU: "+this.U.toString()+"\np: "+this.p.toString()+(this.q?"\nq: "+this.q.toString():"")+"\n"}}}})});function Lf(e,t){let r;const n=t.length,i=[];if(e)for(r=0;r<n;r++)i[e[r]]=t[r];else for(r=0;r<n;r++)i[r]=t[r];return i}const $f="lusolve",Hf=s($f,["typed","matrix","lup","slu","usolve","lsolve","DenseMatrix"],e=>{let{typed:t,matrix:r,lup:n,slu:i,usolve:s,lsolve:u,DenseMatrix:a}=e;const c=iu({DenseMatrix:a});return t($f,{"Array, Array | Matrix":function(e,t){e=r(e);e=n(e);return o(e.L,e.U,e.p,null,t).valueOf()},"DenseMatrix, Array | Matrix":function(e,t){e=n(e);return o(e.L,e.U,e.p,null,t)},"SparseMatrix, Array | Matrix":function(e,t){e=n(e);return o(e.L,e.U,e.p,null,t)},"SparseMatrix, Array | Matrix, number, number":function(e,t,r,n){e=i(e,r,n);return o(e.L,e.U,e.p,e.q,t)},"Object, Array | Matrix":function(e,t){return o(e.L,e.U,e.p,e.q,t)}});function l(e){if(_(e))return e;if(g(e))return r(e);throw new TypeError("Invalid Matrix LU decomposition")}function o(e,t,r,n,i){e=l(e),t=l(t),r&&((i=c(e,i,!0))._data=Lf(r,i._data));const a=u(e,i),o=s(t,a);return n&&(o._data=Lf(n,o._data)),o}}),Gf="polynomialRoot",Zf=s(Gf,["typed","isZero","equalScalar","add","subtract","multiply","divide","sqrt","unaryMinus","cbrt","typeOf","im","re"],e=>{let{typed:t,isZero:h,equalScalar:d,add:g,subtract:y,multiply:x,divide:b,sqrt:v,unaryMinus:w,cbrt:N,typeOf:E,im:A,re:S}=e;return t(Gf,{"number|Complex, ...number|Complex":(e,t)=>{const r=[e,...t];for(;0<r.length&&h(r[r.length-1]);)r.pop();if(r.length<2)throw new RangeError(`Polynomial [${e}, ${t}] must have a non-zero non-constant coefficient`);switch(r.length){case 2:return[w(b(r[0],r[1]))];case 3:{const[e,t,h]=r,g=x(2,h),N=x(t,t),E=x(4,h,e);if(d(N,E))return[b(w(t),g)];const A=v(y(N,E));return[b(y(A,t),g),b(y(w(A),t),g)]}case 4:{const[e,t,h,i]=r,a=w(x(3,i)),o=x(h,h),s=x(3,i,t),u=g(x(2,h,h,h),x(27,i,i,e)),c=x(9,i,h,t);if(d(o,s)&&d(u,c))return[b(h,a)];const l=y(o,s),f=y(u,c),p=g(x(18,i,h,t,e),x(h,h,t,t)),m=g(x(4,h,h,h,e),x(4,i,t,t,t),x(27,i,i,e,e));return d(p,m)?[b(y(x(4,i,h,t),g(x(9,i,i,e),x(h,h,h))),x(i,l)),b(y(x(9,i,e),x(h,t)),x(2,l))]:(n=d(o,s)?f:b(g(f,v(y(x(f,f),x(4,l,l,l)))),2),N(n,!0).toArray().map(e=>b(g(h,e,b(l,e)),a)).map(e=>"Complex"===E(e)&&d(S(e),S(e)+A(e))?S(e):e));var n}default:throw new RangeError("only implemented for cubic or lower-order polynomials, not "+r)}}})}),Vf=(kh(9463),s("Help",["evaluate"],e=>{let o=e["evaluate"];function n(e){if(!(this instanceof n))throw new SyntaxError("Constructor must be called with the new operator");if(!e)throw new Error('Argument "doc" missing');this.doc=e}return n.prototype.type="Help",n.prototype.isHelp=!0,n.prototype.toString=function(){const r=this.doc||{};let n="\n";if(r.name&&(n+="Name: "+r.name+"\n\n"),r.category&&(n+="Category: "+r.category+"\n\n"),r.description&&(n+="Description:\n    "+r.description+"\n\n"),r.syntax&&(n+="Syntax:\n    "+r.syntax.join("\n    ")+"\n\n"),r.examples){n+="Examples:\n";let t=!1;var e=o("config()"),i={config:e=>(t=!0,o("config(newConfig)",{newConfig:e}))};for(let t=0;t<r.examples.length;t++){var a=r.examples[t];let e;n+="    "+a+"\n";try{e=o(a,i)}catch(r){e=r}void 0===e||H(e)||(n+="        "+S(e,{precision:14})+"\n")}n+="\n",t&&o("config(originalConfig)",{originalConfig:e})}return r.mayThrow&&r.mayThrow.length&&(n+="Throws: "+r.mayThrow.join(", ")+"\n\n"),r.seealso&&r.seealso.length&&(n+="See also: "+r.seealso.join(", ")+"\n"),n},n.prototype.toJSON=function(){const e=ee(this.doc);return e.mathjs="Help",e},n.fromJSON=function(t){const r={};return Object.keys(t).filter(e=>"mathjs"!==e).forEach(e=>{r[e]=t[e]}),new n(r)},n.prototype.valueOf=n.prototype.toString,n},{isClass:!0})),Wf=s("Chain",["?on","math","typed"],e=>{let{on:t,math:r,typed:n}=e;function i(e){if(!(this instanceof i))throw new SyntaxError("Constructor must be called with the new operator");be(e)?this.value=e.value:this.value=e}function a(e,t){$e(i.prototype,e,function(){var e=t();if("function"==typeof e)return o(e)})}function o(r){return function(){if(0===arguments.length)return new i(r(this.value));const t=[this.value];for(let e=0;e<arguments.length;e++)t[e+1]=arguments[e];if(n.isTypedFunction(r)){const e=n.resolve(r,t);if(1===e.params.length)throw new Error("chain function "+r.name+" cannot match rest parameter between chain value and additional arguments.");return new i(e.implementation.apply(r,t))}return new i(r.apply(r,t))}}i.prototype.type="Chain",i.prototype.isChain=!0,i.prototype.done=function(){return this.value},i.prototype.valueOf=function(){return this.value},i.prototype.toString=function(){return S(this.value)},i.prototype.toJSON=function(){return{mathjs:"Chain",value:this.value}},i.fromJSON=function(e){return new i(e.value)};const s={expression:!0,docs:!0,type:!0,classes:!0,json:!0,error:!0,isChain:!0};return(i.createProxy=function(e,t){if("string"==typeof e)"function"==typeof t&&(i.prototype[e]=o(t));else for(const t in e)ue(e,t)&&void 0===s[t]&&a(t,()=>e[t])})(r),t&&t("import",function(e,t,r){r||a(e,t)}),i},{isClass:!0}),Yf={name:"e",category:"Constants",syntax:["e"],description:"Euler's number, the base of the natural logarithm. Approximately equal to 2.71828",examples:["e","e ^ 2","exp(2)","log(e)"],seealso:["exp"]},Jf={name:"pi",category:"Constants",syntax:["pi"],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",examples:["pi","sin(pi/2)"],seealso:["tau"]},Xf={bignumber:{name:"bignumber",category:"Construction",syntax:["bignumber(x)"],description:"Create a big number from a number or string.",examples:["0.1 + 0.2","bignumber(0.1) + bignumber(0.2)",'bignumber("7.2")','bignumber("7.2e500")',"bignumber([0.1, 0.2, 0.3])"],seealso:["boolean","bigint","complex","fraction","index","matrix","string","unit"]},bigint:{name:"bigint",category:"Construction",syntax:["bigint(x)"],description:"Create a bigint, an integer with an arbitrary number of digits, from a number or string.",examples:["123123123123123123 # a large number will lose digits",'bigint("123123123123123123")','bignumber(["1", "3", "5"])'],seealso:["boolean","bignumber","number","complex","fraction","index","matrix","string","unit"]},boolean:{name:"boolean",category:"Construction",syntax:["x","boolean(x)"],description:"Convert a string or number into a boolean.",examples:["boolean(0)","boolean(1)","boolean(3)",'boolean("true")','boolean("false")',"boolean([1, 0, 1, 1])"],seealso:["bignumber","complex","index","matrix","number","string","unit"]},complex:{name:"complex",category:"Construction",syntax:["complex()","complex(re, im)","complex(string)"],description:"Create a complex number.",examples:["complex()","complex(2, 3)",'complex("7 - 2i")'],seealso:["bignumber","boolean","index","matrix","number","string","unit"]},createUnit:{name:"createUnit",category:"Construction",syntax:["createUnit(definitions)","createUnit(name, definition)"],description:"Create a user-defined unit and register it with the Unit type.",examples:['createUnit("foo")','createUnit("knot", {definition: "0.514444444 m/s", aliases: ["knots", "kt", "kts"]})','createUnit("mph", "1 mile/hour")'],seealso:["unit","splitUnit"]},fraction:{name:"fraction",category:"Construction",syntax:["fraction(num)","fraction(matrix)","fraction(num,den)","fraction({n: num, d: den})"],description:"Create a fraction from a number or from integer numerator and denominator.",examples:["fraction(0.125)","fraction(1, 3) + fraction(2, 5)","fraction({n: 333, d: 53})","fraction([sqrt(9), sqrt(10), sqrt(11)])"],seealso:["bignumber","boolean","complex","index","matrix","string","unit"]},index:{name:"index",category:"Construction",syntax:["[start]","[start:end]","[start:step:end]","[start1, start 2, ...]","[start1:end1, start2:end2, ...]","[start1:step1:end1, start2:step2:end2, ...]"],description:"Create an index to get or replace a subset of a matrix",examples:["A = [1, 2, 3; 4, 5, 6]","A[1, :]","A[1, 2] = 50","A[1:2, 1:2] = 1","B = [1, 2, 3]","B[B>1 and B<3]"],seealso:["bignumber","boolean","complex","matrix,","number","range","string","unit"]},matrix:{name:"matrix",category:"Construction",syntax:["[]","[a1, b1, ...; a2, b2, ...]","matrix()",'matrix("dense")',"matrix([...])"],description:"Create a matrix.",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")'],seealso:["bignumber","boolean","complex","index","number","string","unit","sparse"]},number:{name:"number",category:"Construction",syntax:["x","number(x)","number(unit, valuelessUnit)"],description:"Create a number or convert a string or boolean into a number.",examples:["2","2e3","4.05","number(2)",'number("7.2")',"number(true)","number([true, false, true, true])",'number(unit("52cm"), "m")'],seealso:["bignumber","bigint","boolean","complex","fraction","index","matrix","string","unit"]},sparse:{name:"sparse",category:"Construction",syntax:["sparse()","sparse([a1, b1, ...; a1, b2, ...])",'sparse([a1, b1, ...; a1, b2, ...], "number")'],description:"Create a sparse matrix.",examples:["sparse()","sparse([3, 4; 5, 6])",'sparse([3, 0; 5, 0], "number")'],seealso:["bignumber","boolean","complex","index","number","string","unit","matrix"]},splitUnit:{name:"splitUnit",category:"Construction",syntax:["splitUnit(unit: Unit, parts: Unit[])"],description:"Split a unit in an array of units whose sum is equal to the original unit.",examples:['splitUnit(1 m, ["feet", "inch"])'],seealso:["unit","createUnit"]},string:{name:"string",category:"Construction",syntax:['"text"',"string(x)"],description:"Create a string or convert a value to a string",examples:['"Hello World!"',"string(4.2)","string(3 + 2i)"],seealso:["bignumber","boolean","complex","index","matrix","number","unit"]},unit:{name:"unit",category:"Construction",syntax:["value unit","unit(value, unit)","unit(string)"],description:"Create a unit.",examples:["5.5 mm","3 inch",'unit(7.1, "kilogram")','unit("23 deg")'],seealso:["bignumber","boolean","complex","index","matrix","number","string"]},e:Yf,E:Yf,false:{name:"false",category:"Constants",syntax:["false"],description:"Boolean value false",examples:["false"],seealso:["true"]},i:{name:"i",category:"Constants",syntax:["i"],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.",examples:["i","i * i","sqrt(-1)"],seealso:[]},Infinity:{name:"Infinity",category:"Constants",syntax:["Infinity"],description:"Infinity, a number which is larger than the maximum number that can be handled by a floating point number.",examples:["Infinity","1 / 0"],seealso:[]},LN2:{name:"LN2",category:"Constants",syntax:["LN2"],description:"Returns the natural logarithm of 2, approximately equal to 0.693",examples:["LN2","log(2)"],seealso:[]},LN10:{name:"LN10",category:"Constants",syntax:["LN10"],description:"Returns the natural logarithm of 10, approximately equal to 2.302",examples:["LN10","log(10)"],seealso:[]},LOG2E:{name:"LOG2E",category:"Constants",syntax:["LOG2E"],description:"Returns the base-2 logarithm of E, approximately equal to 1.442",examples:["LOG2E","log(e, 2)"],seealso:[]},LOG10E:{name:"LOG10E",category:"Constants",syntax:["LOG10E"],description:"Returns the base-10 logarithm of E, approximately equal to 0.434",examples:["LOG10E","log(e, 10)"],seealso:[]},NaN:{name:"NaN",category:"Constants",syntax:["NaN"],description:"Not a number",examples:["NaN","0 / 0"],seealso:[]},null:{name:"null",category:"Constants",syntax:["null"],description:"Value null",examples:["null"],seealso:["true","false"]},pi:Jf,PI:Jf,phi:{name:"phi",category:"Constants",syntax:["phi"],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...",examples:["phi"],seealso:[]},SQRT1_2:{name:"SQRT1_2",category:"Constants",syntax:["SQRT1_2"],description:"Returns the square root of 1/2, approximately equal to 0.707",examples:["SQRT1_2","sqrt(1/2)"],seealso:[]},SQRT2:{name:"SQRT2",category:"Constants",syntax:["SQRT2"],description:"Returns the square root of 2, approximately equal to 1.414",examples:["SQRT2","sqrt(2)"],seealso:[]},tau:{name:"tau",category:"Constants",syntax:["tau"],description:"Tau is the ratio constant of a circle's circumference to radius, equal to 2 * pi, approximately 6.2832.",examples:["tau","2 * pi"],seealso:["pi"]},true:{name:"true",category:"Constants",syntax:["true"],description:"Boolean value true",examples:["true"],seealso:["false"]},version:{name:"version",category:"Constants",syntax:["version"],description:"A string with the version number of math.js",examples:["version"],seealso:[]},speedOfLight:{description:"Speed of light in vacuum",examples:["speedOfLight"]},gravitationConstant:{description:"Newtonian constant of gravitation",examples:["gravitationConstant"]},planckConstant:{description:"Planck constant",examples:["planckConstant"]},reducedPlanckConstant:{description:"Reduced Planck constant",examples:["reducedPlanckConstant"]},magneticConstant:{description:"Magnetic constant (vacuum permeability)",examples:["magneticConstant"]},electricConstant:{description:"Electric constant (vacuum permeability)",examples:["electricConstant"]},vacuumImpedance:{description:"Characteristic impedance of vacuum",examples:["vacuumImpedance"]},coulomb:{description:"Coulomb's constant",examples:["coulomb"]},elementaryCharge:{description:"Elementary charge",examples:["elementaryCharge"]},bohrMagneton:{description:"Borh magneton",examples:["bohrMagneton"]},conductanceQuantum:{description:"Conductance quantum",examples:["conductanceQuantum"]},inverseConductanceQuantum:{description:"Inverse conductance quantum",examples:["inverseConductanceQuantum"]},magneticFluxQuantum:{description:"Magnetic flux quantum",examples:["magneticFluxQuantum"]},nuclearMagneton:{description:"Nuclear magneton",examples:["nuclearMagneton"]},klitzing:{description:"Von Klitzing constant",examples:["klitzing"]},bohrRadius:{description:"Borh radius",examples:["bohrRadius"]},classicalElectronRadius:{description:"Classical electron radius",examples:["classicalElectronRadius"]},electronMass:{description:"Electron mass",examples:["electronMass"]},fermiCoupling:{description:"Fermi coupling constant",examples:["fermiCoupling"]},fineStructure:{description:"Fine-structure constant",examples:["fineStructure"]},hartreeEnergy:{description:"Hartree energy",examples:["hartreeEnergy"]},protonMass:{description:"Proton mass",examples:["protonMass"]},deuteronMass:{description:"Deuteron Mass",examples:["deuteronMass"]},neutronMass:{description:"Neutron mass",examples:["neutronMass"]},quantumOfCirculation:{description:"Quantum of circulation",examples:["quantumOfCirculation"]},rydberg:{description:"Rydberg constant",examples:["rydberg"]},thomsonCrossSection:{description:"Thomson cross section",examples:["thomsonCrossSection"]},weakMixingAngle:{description:"Weak mixing angle",examples:["weakMixingAngle"]},efimovFactor:{description:"Efimov factor",examples:["efimovFactor"]},atomicMass:{description:"Atomic mass constant",examples:["atomicMass"]},avogadro:{description:"Avogadro's number",examples:["avogadro"]},boltzmann:{description:"Boltzmann constant",examples:["boltzmann"]},faraday:{description:"Faraday constant",examples:["faraday"]},firstRadiation:{description:"First radiation constant",examples:["firstRadiation"]},loschmidt:{description:"Loschmidt constant at T=273.15 K and p=101.325 kPa",examples:["loschmidt"]},gasConstant:{description:"Gas constant",examples:["gasConstant"]},molarPlanckConstant:{description:"Molar Planck constant",examples:["molarPlanckConstant"]},molarVolume:{description:"Molar volume of an ideal gas at T=273.15 K and p=101.325 kPa",examples:["molarVolume"]},sackurTetrode:{description:"Sackur-Tetrode constant at T=1 K and p=101.325 kPa",examples:["sackurTetrode"]},secondRadiation:{description:"Second radiation constant",examples:["secondRadiation"]},stefanBoltzmann:{description:"Stefan-Boltzmann constant",examples:["stefanBoltzmann"]},wienDisplacement:{description:"Wien displacement law constant",examples:["wienDisplacement"]},molarMass:{description:"Molar mass constant",examples:["molarMass"]},molarMassC12:{description:"Molar mass constant of carbon-12",examples:["molarMassC12"]},gravity:{description:"Standard acceleration of gravity (standard acceleration of free-fall on Earth)",examples:["gravity"]},planckLength:{description:"Planck length",examples:["planckLength"]},planckMass:{description:"Planck mass",examples:["planckMass"]},planckTime:{description:"Planck time",examples:["planckTime"]},planckCharge:{description:"Planck charge",examples:["planckCharge"]},planckTemperature:{description:"Planck temperature",examples:["planckTemperature"]},derivative:{name:"derivative",category:"Algebra",syntax:["derivative(expr, variable)","derivative(expr, variable, {simplify: boolean})"],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.",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})"],seealso:["simplify","parse","evaluate"]},lsolve:{name:"lsolve",category:"Algebra",syntax:["x=lsolve(L, b)"],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.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lsolve(a, b)"],seealso:["lsolveAll","lup","lusolve","usolve","matrix","sparse"]},lsolveAll:{name:"lsolveAll",category:"Algebra",syntax:["x=lsolveAll(L, b)"],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.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lsolve(a, b)"],seealso:["lsolve","lup","lusolve","usolve","matrix","sparse"]},lup:{name:"lup",category:"Algebra",syntax:["lup(m)"],description:"Calculate the Matrix LU decomposition with partial pivoting. Matrix A is decomposed in three matrices (L, U, P) where P * A = L * U",examples:["lup([[2, 1], [1, 4]])","lup(matrix([[2, 1], [1, 4]]))","lup(sparse([[2, 1], [1, 4]]))"],seealso:["lusolve","lsolve","usolve","matrix","sparse","slu","qr"]},lusolve:{name:"lusolve",category:"Algebra",syntax:["x=lusolve(A, b)","x=lusolve(lu, b)"],description:"Solves the linear system A * x = b where A is an [n x n] matrix and b is a [n] column vector.",examples:["a = [-2, 3; 2, 1]","b = [11, 9]","x = lusolve(a, b)"],seealso:["lup","slu","lsolve","usolve","matrix","sparse"]},leafCount:{name:"leafCount",category:"Algebra",syntax:["leafCount(expr)"],description:"Computes the number of leaves in the parse tree of the given expression",examples:['leafCount("e^(i*pi)-1")','leafCount(parse("{a: 22/7, b: 10^(1/2)}"))'],seealso:["simplify"]},polynomialRoot:{name:"polynomialRoot",category:"Algebra",syntax:["x=polynomialRoot(-6, 3)","x=polynomialRoot(4, -4, 1)","x=polynomialRoot(-8, 12, -6, 1)"],description:"Finds the roots of a univariate polynomial given by its coefficients starting from constant, linear, and so on, increasing in degree.",examples:["a = polynomialRoot(-6, 11, -6, 1)"],seealso:["cbrt","sqrt"]},resolve:{name:"resolve",category:"Algebra",syntax:["resolve(node, scope)"],description:"Recursively substitute variables in an expression tree.",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") })'],seealso:["simplify","evaluate"],mayThrow:["ReferenceError"]},simplify:{name:"simplify",category:"Algebra",syntax:["simplify(expr)","simplify(expr, rules)"],description:"Simplify an expression tree.",examples:['simplify("3 + 2 / 4")','simplify("2x + x")','f = parse("x * (x + 2 + x)")',"simplified = simplify(f)","simplified.evaluate({x: 2})"],seealso:["simplifyCore","derivative","evaluate","parse","rationalize","resolve"]},simplifyConstant:{name:"simplifyConstant",category:"Algebra",syntax:["simplifyConstant(expr)","simplifyConstant(expr, options)"],description:"Replace constant subexpressions of node with their values.",examples:['simplifyConstant("(3-3)*x")','simplifyConstant(parse("z-cos(tau/8)"))'],seealso:["simplify","simplifyCore","evaluate"]},simplifyCore:{name:"simplifyCore",category:"Algebra",syntax:["simplifyCore(node)"],description:"Perform simple one-pass simplifications on an expression tree.",examples:['simplifyCore(parse("0*x"))','simplifyCore(parse("(x+0)*2"))'],seealso:["simplify","simplifyConstant","evaluate"]},symbolicEqual:{name:"symbolicEqual",category:"Algebra",syntax:["symbolicEqual(expr1, expr2)","symbolicEqual(expr1, expr2, options)"],description:"Returns true if the difference of the expressions simplifies to 0",examples:['symbolicEqual("x*y","y*x")','symbolicEqual("abs(x^2)", "x^2")','symbolicEqual("abs(x)", "x", {context: {abs: {trivial: true}}})'],seealso:["simplify","evaluate"]},rationalize:{name:"rationalize",category:"Algebra",syntax:["rationalize(expr)","rationalize(expr, scope)","rationalize(expr, scope, detailed)"],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.",examples:['rationalize("2x/y - y/(x+1)")','rationalize("2x/y - y/(x+1)", true)'],seealso:["simplify"]},slu:{name:"slu",category:"Algebra",syntax:["slu(A, order, threshold)"],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",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)"],seealso:["lusolve","lsolve","usolve","matrix","sparse","lup","qr"]},usolve:{name:"usolve",category:"Algebra",syntax:["x=usolve(U, b)"],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.",examples:["x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])"],seealso:["usolveAll","lup","lusolve","lsolve","matrix","sparse"]},usolveAll:{name:"usolveAll",category:"Algebra",syntax:["x=usolve(U, b)"],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.",examples:["x=usolve(sparse([1, 1, 1, 1; 0, 1, 1, 1; 0, 0, 1, 1; 0, 0, 0, 1]), [1; 2; 3; 4])"],seealso:["usolve","lup","lusolve","lsolve","matrix","sparse"]},qr:{name:"qr",category:"Algebra",syntax:["qr(A)"],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.",examples:["qr([[1, -1,  4], [1,  4, -2], [1,  4,  2], [1,  -1, 0]])"],seealso:["lup","slu","matrix"]},abs:{name:"abs",category:"Arithmetic",syntax:["abs(x)"],description:"Compute the absolute value.",examples:["abs(3.5)","abs(-4.2)"],seealso:["sign"]},add:{name:"add",category:"Operators",syntax:["x + y","add(x, y)"],description:"Add two values.",examples:["a = 2.1 + 3.6","a - 3.6","3 + 2i","3 cm + 2 inch",'"2.3" + "4"'],seealso:["subtract"]},cbrt:{name:"cbrt",category:"Arithmetic",syntax:["cbrt(x)","cbrt(x, allRoots)"],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",examples:["cbrt(64)","cube(4)","cbrt(-8)","cbrt(2 + 3i)","cbrt(8i)","cbrt(8i, true)","cbrt(27 m^3)"],seealso:["square","sqrt","cube","multiply"]},ceil:{name:"ceil",category:"Arithmetic",syntax:["ceil(x)"],description:"Round a value towards plus infinity. If x is complex, both real and imaginary part are rounded towards plus infinity.",examples:["ceil(3.2)","ceil(3.8)","ceil(-4.2)"],seealso:["floor","fix","round"]},cube:{name:"cube",category:"Arithmetic",syntax:["cube(x)"],description:"Compute the cube of a value. The cube of x is x * x * x.",examples:["cube(2)","2^3","2 * 2 * 2"],seealso:["multiply","square","pow"]},divide:{name:"divide",category:"Operators",syntax:["x / y","divide(x, y)"],description:"Divide two values.",examples:["a = 2 / 3","a * 3","4.5 / 2","3 + 4 / 2","(3 + 4) / 2","18 km / 4.5"],seealso:["multiply"]},dotDivide:{name:"dotDivide",category:"Operators",syntax:["x ./ y","dotDivide(x, y)"],description:"Divide two values element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","b = [2, 1, 1; 3, 2, 5]","a ./ b"],seealso:["multiply","dotMultiply","divide"]},dotMultiply:{name:"dotMultiply",category:"Operators",syntax:["x .* y","dotMultiply(x, y)"],description:"Multiply two values element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","b = [2, 1, 1; 3, 2, 5]","a .* b"],seealso:["multiply","divide","dotDivide"]},dotPow:{name:"dotPow",category:"Operators",syntax:["x .^ y","dotPow(x, y)"],description:"Calculates the power of x to y element wise.",examples:["a = [1, 2, 3; 4, 5, 6]","a .^ 2"],seealso:["pow"]},exp:{name:"exp",category:"Arithmetic",syntax:["exp(x)"],description:"Calculate the exponent of a value.",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"],seealso:["expm","expm1","pow","log"]},expm:{name:"expm",category:"Arithmetic",syntax:["exp(x)"],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.",examples:["expm([[0,2],[0,0]])"],seealso:["exp"]},expm1:{name:"expm1",category:"Arithmetic",syntax:["expm1(x)"],description:"Calculate the value of subtracting 1 from the exponential value.",examples:["expm1(2)","pow(e, 2) - 1","log(expm1(2) + 1)"],seealso:["exp","pow","log"]},fix:{name:"fix",category:"Arithmetic",syntax:["fix(x)"],description:"Round a value towards zero. If x is complex, both real and imaginary part are rounded towards zero.",examples:["fix(3.2)","fix(3.8)","fix(-4.2)","fix(-4.8)"],seealso:["ceil","floor","round"]},floor:{name:"floor",category:"Arithmetic",syntax:["floor(x)"],description:"Round a value towards minus infinity.If x is complex, both real and imaginary part are rounded towards minus infinity.",examples:["floor(3.2)","floor(3.8)","floor(-4.2)"],seealso:["ceil","fix","round"]},gcd:{name:"gcd",category:"Arithmetic",syntax:["gcd(a, b)","gcd(a, b, c, ...)"],description:"Compute the greatest common divisor.",examples:["gcd(8, 12)","gcd(-4, 6)","gcd(25, 15, -10)"],seealso:["lcm","xgcd"]},hypot:{name:"hypot",category:"Arithmetic",syntax:["hypot(a, b, c, ...)","hypot([a, b, c, ...])"],description:"Calculate the hypotenusa of a list with values. ",examples:["hypot(3, 4)","sqrt(3^2 + 4^2)","hypot(-2)","hypot([3, 4, 5])"],seealso:["abs","norm"]},lcm:{name:"lcm",category:"Arithmetic",syntax:["lcm(x, y)"],description:"Compute the least common multiple.",examples:["lcm(4, 6)","lcm(6, 21)","lcm(6, 21, 5)"],seealso:["gcd"]},log:{name:"log",category:"Arithmetic",syntax:["log(x)","log(x, base)"],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).",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"],seealso:["exp","log1p","log2","log10"]},log2:{name:"log2",category:"Arithmetic",syntax:["log2(x)"],description:"Calculate the 2-base of a value. This is the same as calculating `log(x, 2)`.",examples:["log2(0.03125)","log2(16)","log2(16) / log2(2)","pow(2, 4)"],seealso:["exp","log1p","log","log10"]},log1p:{name:"log1p",category:"Arithmetic",syntax:["log1p(x)","log1p(x, base)"],description:"Calculate the logarithm of a `value+1`",examples:["log1p(2.5)","exp(log1p(1.4))","pow(10, 4)","log1p(9999, 10)","log1p(9999) / log(10)"],seealso:["exp","log","log2","log10"]},log10:{name:"log10",category:"Arithmetic",syntax:["log10(x)"],description:"Compute the 10-base logarithm of a value.",examples:["log10(0.00001)","log10(10000)","10 ^ 4","log(10000) / log(10)","log(10000, 10)"],seealso:["exp","log"]},mod:{name:"mod",category:"Operators",syntax:["x % y","x mod y","mod(x, y)"],description:"Calculates the modulus, the remainder of an integer division.",examples:["7 % 3","11 % 2","10 mod 4","isOdd(x) = x % 2","isOdd(2)","isOdd(3)"],seealso:["divide"]},multiply:{name:"multiply",category:"Operators",syntax:["x * y","multiply(x, y)"],description:"multiply two values.",examples:["a = 2.1 * 3.4","a / 3.4","2 * 3 + 4","2 * (3 + 4)","3 * 2.1 km"],seealso:["divide"]},norm:{name:"norm",category:"Arithmetic",syntax:["norm(x)","norm(x, p)"],description:"Calculate the norm of a number, vector or matrix.",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")']},nthRoot:{name:"nthRoot",category:"Arithmetic",syntax:["nthRoot(a)","nthRoot(a, root)"],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".',examples:["4 ^ 3","nthRoot(64, 3)","nthRoot(9, 2)","sqrt(9)"],seealso:["nthRoots","pow","sqrt"]},nthRoots:{name:"nthRoots",category:"Arithmetic",syntax:["nthRoots(A)","nthRoots(A, root)"],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.',examples:["nthRoots(1)","nthRoots(1, 3)"],seealso:["sqrt","pow","nthRoot"]},pow:{name:"pow",category:"Operators",syntax:["x ^ y","pow(x, y)"],description:"Calculates the power of x to y, x^y.",examples:["2^3","2*2*2","1 + e ^ (pi * i)","pow([[1, 2], [4, 3]], 2)","pow([[1, 2], [4, 3]], -1)"],seealso:["multiply","nthRoot","nthRoots","sqrt"]},round:{name:"round",category:"Arithmetic",syntax:["round(x)","round(x, n)","round(unit, valuelessUnit)","round(unit, n, valuelessUnit)"],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.",examples:["round(3.2)","round(3.8)","round(-4.2)","round(-4.8)","round(pi, 3)","round(123.45678, 2)","round(3.241cm, 2, cm)","round([3.2, 3.8, -4.7])"],seealso:["ceil","floor","fix"]},sign:{name:"sign",category:"Arithmetic",syntax:["sign(x)"],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.",examples:["sign(3.5)","sign(-4.2)","sign(0)"],seealso:["abs"]},sqrt:{name:"sqrt",category:"Arithmetic",syntax:["sqrt(x)"],description:"Compute the square root value. If x = y * y, then y is the square root of x.",examples:["sqrt(25)","5 * 5","sqrt(-1)"],seealso:["square","sqrtm","multiply","nthRoot","nthRoots","pow"]},sqrtm:{name:"sqrtm",category:"Arithmetic",syntax:["sqrtm(x)"],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`.",examples:["sqrtm([[33, 24], [48, 57]])"],seealso:["sqrt","abs","square","multiply"]},square:{name:"square",category:"Arithmetic",syntax:["square(x)"],description:"Compute the square of a value. The square of x is x * x.",examples:["square(3)","sqrt(9)","3^2","3 * 3"],seealso:["multiply","pow","sqrt","cube"]},subtract:{name:"subtract",category:"Operators",syntax:["x - y","subtract(x, y)"],description:"subtract two values.",examples:["a = 5.3 - 2","a + 2","2/3 - 1/6","2 * 3 - 3","2.1 km - 500m"],seealso:["add"]},unaryMinus:{name:"unaryMinus",category:"Operators",syntax:["-x","unaryMinus(x)"],description:"Inverse the sign of a value. Converts booleans and strings to numbers.",examples:["-4.5","-(-5.6)",'-"22"'],seealso:["add","subtract","unaryPlus"]},unaryPlus:{name:"unaryPlus",category:"Operators",syntax:["+x","unaryPlus(x)"],description:"Converts booleans and strings to numbers.",examples:["+true",'+"2"'],seealso:["add","subtract","unaryMinus"]},xgcd:{name:"xgcd",category:"Arithmetic",syntax:["xgcd(a, b)"],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.",examples:["xgcd(8, 12)","gcd(8, 12)","xgcd(36163, 21199)"],seealso:["gcd","lcm"]},invmod:{name:"invmod",category:"Arithmetic",syntax:["invmod(a, b)"],description:"Calculate the (modular) multiplicative inverse of a modulo b. Solution to the equation ax ≣ 1 (mod b)",examples:["invmod(8, 12)","invmod(7, 13)","invmod(15151, 15122)"],seealso:["gcd","xgcd"]},bitAnd:{name:"bitAnd",category:"Bitwise",syntax:["x & y","bitAnd(x, y)"],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",examples:["5 & 3","bitAnd(53, 131)","[1, 12, 31] & 42"],seealso:["bitNot","bitOr","bitXor","leftShift","rightArithShift","rightLogShift"]},bitNot:{name:"bitNot",category:"Bitwise",syntax:["~x","bitNot(x)"],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.",examples:["~1","~2","bitNot([2, -3, 4])"],seealso:["bitAnd","bitOr","bitXor","leftShift","rightArithShift","rightLogShift"]},bitOr:{name:"bitOr",category:"Bitwise",syntax:["x | y","bitOr(x, y)"],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.",examples:["5 | 3","bitOr([1, 2, 3], 4)"],seealso:["bitAnd","bitNot","bitXor","leftShift","rightArithShift","rightLogShift"]},bitXor:{name:"bitXor",category:"Bitwise",syntax:["bitXor(x, y)"],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.",examples:["bitOr(1, 2)","bitXor([2, 3, 4], 4)"],seealso:["bitAnd","bitNot","bitOr","leftShift","rightArithShift","rightLogShift"]},leftShift:{name:"leftShift",category:"Bitwise",syntax:["x << y","leftShift(x, y)"],description:"Bitwise left logical shift of a value x by y number of bits.",examples:["4 << 1","8 >> 1"],seealso:["bitAnd","bitNot","bitOr","bitXor","rightArithShift","rightLogShift"]},rightArithShift:{name:"rightArithShift",category:"Bitwise",syntax:["x >> y","rightArithShift(x, y)"],description:"Bitwise right arithmetic shift of a value x by y number of bits.",examples:["8 >> 1","4 << 1","-12 >> 2"],seealso:["bitAnd","bitNot","bitOr","bitXor","leftShift","rightLogShift"]},rightLogShift:{name:"rightLogShift",category:"Bitwise",syntax:["x >>> y","rightLogShift(x, y)"],description:"Bitwise right logical shift of a value x by y number of bits.",examples:["8 >>> 1","4 << 1","-12 >>> 2"],seealso:["bitAnd","bitNot","bitOr","bitXor","leftShift","rightArithShift"]},bellNumbers:{name:"bellNumbers",category:"Combinatorics",syntax:["bellNumbers(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.",examples:["bellNumbers(3)","bellNumbers(8)"],seealso:["stirlingS2"]},catalan:{name:"catalan",category:"Combinatorics",syntax:["catalan(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.",examples:["catalan(3)","catalan(8)"],seealso:["bellNumbers"]},composition:{name:"composition",category:"Combinatorics",syntax:["composition(n, k)"],description:"The composition counts of n into k parts. composition only takes integer arguments. The following condition must be enforced: k <= n.",examples:["composition(5, 3)"],seealso:["combinations"]},stirlingS2:{name:"stirlingS2",category:"Combinatorics",syntax:["stirlingS2(n, k)"],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.",examples:["stirlingS2(5, 3)"],seealso:["bellNumbers"]},config:{name:"config",category:"Core",syntax:["config()","config(options)"],description:"Get configuration or change configuration.",examples:["config()","1/3 + 1/4",'config({number: "Fraction"})',"1/3 + 1/4"],seealso:[]},import:{name:"import",category:"Core",syntax:["import(functions)","import(functions, options)"],description:"Import functions or constants from an object.",examples:["import({myFn: f(x)=x^2, myConstant: 32 })","myFn(2)","myConstant"],seealso:[]},typed:{name:"typed",category:"Core",syntax:["typed(signatures)","typed(name, signatures)"],description:"Create a typed function.",examples:['double = typed({ "number": f(x)=x+x, "string": f(x)=concat(x,x) })',"double(2)",'double("hello")'],seealso:[]},arg:{name:"arg",category:"Complex",syntax:["arg(x)"],description:"Compute the argument of a complex value. If x = a+bi, the argument is computed as atan2(b, a).",examples:["arg(2 + 2i)","atan2(3, 2)","arg(2 + 3i)"],seealso:["re","im","conj","abs"]},conj:{name:"conj",category:"Complex",syntax:["conj(x)"],description:"Compute the complex conjugate of a complex value. If x = a+bi, the complex conjugate is a-bi.",examples:["conj(2 + 3i)","conj(2 - 3i)","conj(-5.2i)"],seealso:["re","im","abs","arg"]},re:{name:"re",category:"Complex",syntax:["re(x)"],description:"Get the real part of a complex number.",examples:["re(2 + 3i)","im(2 + 3i)","re(-5.2i)","re(2.4)"],seealso:["im","conj","abs","arg"]},im:{name:"im",category:"Complex",syntax:["im(x)"],description:"Get the imaginary part of a complex number.",examples:["im(2 + 3i)","re(2 + 3i)","im(-5.2i)","im(2.4)"],seealso:["re","conj","abs","arg"]},evaluate:{name:"evaluate",category:"Expression",syntax:["evaluate(expression)","evaluate(expression, scope)","evaluate([expr1, expr2, expr3, ...])","evaluate([expr1, expr2, expr3, ...], scope)"],description:"Evaluate an expression or an array with expressions.",examples:['evaluate("2 + 3")','evaluate("sqrt(16)")','evaluate("2 inch to cm")','evaluate("sin(x * pi)", { "x": 1/2 })','evaluate(["width=2", "height=4","width*height"])'],seealso:[]},help:{name:"help",category:"Expression",syntax:["help(object)","help(string)"],description:"Display documentation on a function or data type.",examples:["help(sqrt)",'help("complex")'],seealso:[]},distance:{name:"distance",category:"Geometry",syntax:["distance([x1, y1], [x2, y2])","distance([[x1, y1], [x2, y2]])"],description:"Calculates the Euclidean distance between two points.",examples:["distance([0,0], [4,4])","distance([[0,0], [4,4]])"],seealso:[]},intersect:{name:"intersect",category:"Geometry",syntax:["intersect(expr1, expr2, expr3, expr4)","intersect(expr1, expr2, expr3)"],description:"Computes the intersection point of lines and/or planes.",examples:["intersect([0, 0], [10, 10], [10, 0], [0, 10])","intersect([1, 0, 1],  [4, -2, 2], [1, 1, 1, 6])"],seealso:[]},and:{name:"and",category:"Logical",syntax:["x and y","and(x, y)"],description:"Logical and. Test whether two values are both defined with a nonzero/nonempty value.",examples:["true and false","true and true","2 and 4"],seealso:["not","or","xor"]},not:{name:"not",category:"Logical",syntax:["not x","not(x)"],description:"Logical not. Flips the boolean value of given argument.",examples:["not true","not false","not 2","not 0"],seealso:["and","or","xor"]},or:{name:"or",category:"Logical",syntax:["x or y","or(x, y)"],description:"Logical or. Test if at least one value is defined with a nonzero/nonempty value.",examples:["true or false","false or false","0 or 4"],seealso:["not","and","xor"]},xor:{name:"xor",category:"Logical",syntax:["x xor y","xor(x, y)"],description:"Logical exclusive or, xor. Test whether one and only one value is defined with a nonzero/nonempty value.",examples:["true xor false","false xor false","true xor true","0 xor 4"],seealso:["not","and","or"]},concat:{name:"concat",category:"Matrix",syntax:["concat(A, B, C, ...)","concat(A, B, C, ..., dim)"],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.",examples:["A = [1, 2; 5, 6]","B = [3, 4; 7, 8]","concat(A, B)","concat(A, B, 1)","concat(A, B, 2)"],seealso:["det","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},count:{name:"count",category:"Matrix",syntax:["count(x)"],description:"Count the number of elements of a matrix, array or string.",examples:["a = [1, 2; 3, 4; 5, 6]","count(a)","size(a)",'count("hello world")'],seealso:["size"]},cross:{name:"cross",category:"Matrix",syntax:["cross(A, B)"],description:"Calculate the cross product for two vectors in three dimensional space.",examples:["cross([1, 1, 0],  [0, 1, 1])","cross([3, -3, 1], [4, 9, 2])","cross([2, 3, 4],  [5, 6, 7])"],seealso:["multiply","dot"]},column:{name:"column",category:"Matrix",syntax:["column(x, index)"],description:"Return a column from a matrix or array.",examples:["A = [[1, 2], [3, 4]]","column(A, 1)","column(A, 2)"],seealso:["row","matrixFromColumns"]},ctranspose:{name:"ctranspose",category:"Matrix",syntax:["x'","ctranspose(x)"],description:"Complex Conjugate and Transpose a matrix",examples:["a = [1, 2, 3; 4, 5, 6]","a'","ctranspose(a)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","zeros"]},det:{name:"det",category:"Matrix",syntax:["det(x)"],description:"Calculate the determinant of a matrix",examples:["det([1, 2; 3, 4])","det([-2, 2, 3; -1, 1, 3; 2, 0, -1])"],seealso:["concat","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},diag:{name:"diag",category:"Matrix",syntax:["diag(x)","diag(x, k)"],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.",examples:["diag(1:3)","diag(1:3, 1)","a = [1, 2, 3; 4, 5, 6; 7, 8, 9]","diag(a)"],seealso:["concat","det","identity","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},diff:{name:"diff",category:"Matrix",syntax:["diff(arr)","diff(arr, dim)"],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"],examples:["A = [1, 2, 4, 7, 0]","diff(A)","diff(A, 1)","B = [[1, 2], [3, 4]]","diff(B)","diff(B, 1)","diff(B, 2)","diff(B, bignumber(2))","diff([[1, 2], matrix([3, 4])], 2)"],seealso:["subtract","partitionSelect"]},dot:{name:"dot",category:"Matrix",syntax:["dot(A, B)","A * B"],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",examples:["dot([2, 4, 1], [2, 2, 3])","[2, 4, 1] * [2, 2, 3]"],seealso:["multiply","cross"]},getMatrixDataType:{name:"getMatrixDataType",category:"Matrix",syntax:["getMatrixDataType(x)"],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".',examples:["getMatrixDataType([1, 2, 3])","getMatrixDataType([[5 cm], [2 inch]])",'getMatrixDataType([1, "text"])',"getMatrixDataType([1, bignumber(4)])"],seealso:["matrix","sparse","typeOf"]},identity:{name:"identity",category:"Matrix",syntax:["identity(n)","identity(m, n)","identity([m, n])"],description:"Returns the identity matrix with size m-by-n. The matrix has ones on the diagonal and zeros elsewhere.",examples:["identity(3)","identity(3, 5)","a = [1, 2, 3; 4, 5, 6]","identity(size(a))"],seealso:["concat","det","diag","inv","ones","range","size","squeeze","subset","trace","transpose","zeros"]},filter:{name:"filter",category:"Matrix",syntax:["filter(x, test)"],description:"Filter items in a matrix.",examples:["isPositive(x) = x > 0","filter([6, -2, -1, 4, 3], isPositive)","filter([6, -2, 0, 1, 0], x != 0)"],seealso:["sort","map","forEach"]},flatten:{name:"flatten",category:"Matrix",syntax:["flatten(x)"],description:"Flatten a multi dimensional matrix into a single dimensional matrix.",examples:["a = [1, 2, 3; 4, 5, 6]","size(a)","b = flatten(a)","size(b)"],seealso:["concat","resize","size","squeeze"]},forEach:{name:"forEach",category:"Matrix",syntax:["forEach(x, callback)"],description:"Iterates over all elements of a matrix/array, and executes the given callback function.",examples:["numberOfPets = {}","addPet(n) = numberOfPets[n] = (numberOfPets[n] ? numberOfPets[n]:0 ) + 1;",'forEach(["Dog","Cat","Cat"], addPet)',"numberOfPets"],seealso:["map","sort","filter"]},inv:{name:"inv",category:"Matrix",syntax:["inv(x)"],description:"Calculate the inverse of a matrix",examples:["inv([1, 2; 3, 4])","inv(4)","1 / 4"],seealso:["concat","det","diag","identity","ones","range","size","squeeze","subset","trace","transpose","zeros"]},pinv:{name:"pinv",category:"Matrix",syntax:["pinv(x)"],description:"Calculate the Moore–Penrose inverse of a matrix",examples:["pinv([1, 2; 3, 4])","pinv([[1, 0], [0, 1], [0, 1]])","pinv(4)"],seealso:["inv"]},eigs:{name:"eigs",category:"Matrix",syntax:["eigs(x)"],description:"Calculate the eigenvalues and optionally eigenvectors of a square matrix",examples:["eigs([[5, 2.3], [2.3, 1]])","eigs([[1, 2, 3], [4, 5, 6], [7, 8, 9]], { precision: 1e-6, eigenvectors: false })"],seealso:["inv"]},kron:{name:"kron",category:"Matrix",syntax:["kron(x, y)"],description:"Calculates the kronecker product of 2 matrices or vectors.",examples:["kron([[1, 0], [0, 1]], [[1, 2], [3, 4]])","kron([1,1], [2,3,4])"],seealso:["multiply","dot","cross"]},matrixFromFunction:{name:"matrixFromFunction",category:"Matrix",syntax:["matrixFromFunction(size, fn)","matrixFromFunction(size, fn, format)","matrixFromFunction(size, fn, format, datatype)","matrixFromFunction(size, format, fn)","matrixFromFunction(size, format, datatype, fn)"],description:"Create a matrix by evaluating a generating function at each index.",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)"],seealso:["matrix","matrixFromRows","matrixFromColumns","zeros"]},matrixFromRows:{name:"matrixFromRows",category:"Matrix",syntax:["matrixFromRows(...arr)","matrixFromRows(row1, row2)","matrixFromRows(row1, row2, row3)"],description:"Create a dense matrix from vectors as individual rows.",examples:["matrixFromRows([1, 2, 3], [[4],[5],[6]])"],seealso:["matrix","matrixFromColumns","matrixFromFunction","zeros"]},matrixFromColumns:{name:"matrixFromColumns",category:"Matrix",syntax:["matrixFromColumns(...arr)","matrixFromColumns(row1, row2)","matrixFromColumns(row1, row2, row3)"],description:"Create a dense matrix from vectors as individual columns.",examples:["matrixFromColumns([1, 2, 3], [[4],[5],[6]])"],seealso:["matrix","matrixFromRows","matrixFromFunction","zeros"]},map:{name:"map",category:"Matrix",syntax:["map(x, callback)"],description:"Create a new matrix or array with the results of the callback function executed on each entry of the matrix/array.",examples:["map([1, 2, 3], square)"],seealso:["filter","forEach"]},ones:{name:"ones",category:"Matrix",syntax:["ones(m)","ones(m, n)","ones(m, n, p, ...)","ones([m])","ones([m, n])","ones([m, n, p, ...])"],description:"Create a matrix containing ones.",examples:["ones(3)","ones(3, 5)","ones([2,3]) * 4.5","a = [1, 2, 3; 4, 5, 6]","ones(size(a))"],seealso:["concat","det","diag","identity","inv","range","size","squeeze","subset","trace","transpose","zeros"]},partitionSelect:{name:"partitionSelect",category:"Matrix",syntax:["partitionSelect(x, k)","partitionSelect(x, k, compare)"],description:"Partition-based selection of an array or 1D matrix. Will find the kth smallest value, and mutates the input array. Uses Quickselect.",examples:["partitionSelect([5, 10, 1], 2)",'partitionSelect(["C", "B", "A", "D"], 1, compareText)',"arr = [5, 2, 1]","partitionSelect(arr, 0) # returns 1, arr is now: [1, 2, 5]","arr","partitionSelect(arr, 1, 'desc') # returns 2, arr is now: [5, 2, 1]","arr"],seealso:["sort"]},range:{name:"range",category:"Type",syntax:["start:end","start:step:end","range(start, end)","range(start, end, step)","range(string)"],description:"Create a range. Lower bound of the range is included, upper bound is excluded.",examples:["1:5","3:-1:-3","range(3, 7)","range(0, 12, 2)",'range("4:10")',"range(1m, 1m, 3m)","a = [1, 2, 3, 4; 5, 6, 7, 8]","a[1:2, 1:2]"],seealso:["concat","det","diag","identity","inv","ones","size","squeeze","subset","trace","transpose","zeros"]},resize:{name:"resize",category:"Matrix",syntax:["resize(x, size)","resize(x, size, defaultValue)"],description:"Resize a matrix.",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], "!")'],seealso:["size","subset","squeeze","reshape"]},reshape:{name:"reshape",category:"Matrix",syntax:["reshape(x, sizes)"],description:"Reshape a multi dimensional array to fit the specified dimensions.",examples:["reshape([1, 2, 3, 4, 5, 6], [2, 3])","reshape([[1, 2], [3, 4]], [1, 4])","reshape([[1, 2], [3, 4]], [4])","reshape([1, 2, 3, 4], [-1, 2])"],seealso:["size","squeeze","resize"]},rotate:{name:"rotate",category:"Matrix",syntax:["rotate(w, theta)","rotate(w, theta, v)"],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.",examples:["rotate([1, 0], 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]))'],seealso:["matrix","rotationMatrix"]},rotationMatrix:{name:"rotationMatrix",category:"Matrix",syntax:["rotationMatrix(theta)","rotationMatrix(theta, v)","rotationMatrix(theta, v, format)"],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.",examples:["rotationMatrix(pi / 2)",'rotationMatrix(unit("45deg"), [0, 0, 1])','rotationMatrix(1, matrix([0, 0, 1]), "sparse")'],seealso:["cos","sin"]},row:{name:"row",category:"Matrix",syntax:["row(x, index)"],description:"Return a row from a matrix or array.",examples:["A = [[1, 2], [3, 4]]","row(A, 1)","row(A, 2)"],seealso:["column","matrixFromRows"]},size:{name:"size",category:"Matrix",syntax:["size(x)"],description:"Calculate the size of a matrix.",examples:["size(2.3)",'size("hello world")',"a = [1, 2; 3, 4; 5, 6]","size(a)","size(1:6)"],seealso:["concat","count","det","diag","identity","inv","ones","range","squeeze","subset","trace","transpose","zeros"]},sort:{name:"sort",category:"Matrix",syntax:["sort(x)","sort(x, compare)"],description:'Sort the items in a matrix. Compare can be a string "asc", "desc", "natural", or a custom sort function.',examples:["sort([5, 10, 1])",'sort(["C", "B", "A", "D"], "natural")',"sortByLength(a, b) = size(a)[1] - size(b)[1]",'sort(["Langdon", "Tom", "Sara"], sortByLength)','sort(["10", "1", "2"], "natural")'],seealso:["map","filter","forEach"]},squeeze:{name:"squeeze",category:"Matrix",syntax:["squeeze(x)"],description:"Remove inner and outer singleton dimensions from a matrix.",examples:["a = zeros(3,2,1)","size(squeeze(a))","b = zeros(1,1,3)","size(squeeze(b))"],seealso:["concat","det","diag","identity","inv","ones","range","size","subset","trace","transpose","zeros"]},subset:{name:"subset",category:"Matrix",syntax:["value(index)","value(index) = replacement","subset(value, [index])","subset(value, [index], replacement)"],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.",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"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","trace","transpose","zeros"]},trace:{name:"trace",category:"Matrix",syntax:["trace(A)"],description:"Calculate the trace of a matrix: the sum of the elements on the main diagonal of a square matrix.",examples:["A = [1, 2, 3; -1, 2, 3; 2, 0, 3]","trace(A)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","transpose","zeros"]},transpose:{name:"transpose",category:"Matrix",syntax:["x'","transpose(x)"],description:"Transpose a matrix",examples:["a = [1, 2, 3; 4, 5, 6]","a'","transpose(a)"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","zeros"]},zeros:{name:"zeros",category:"Matrix",syntax:["zeros(m)","zeros(m, n)","zeros(m, n, p, ...)","zeros([m])","zeros([m, n])","zeros([m, n, p, ...])"],description:"Create a matrix containing zeros.",examples:["zeros(3)","zeros(3, 5)","a = [1, 2, 3; 4, 5, 6]","zeros(size(a))"],seealso:["concat","det","diag","identity","inv","ones","range","size","squeeze","subset","trace","transpose"]},fft:{name:"fft",category:"Matrix",syntax:["fft(x)"],description:"Calculate N-dimensional fourier transform",examples:["fft([[1, 0], [1, 0]])"],seealso:["ifft"]},ifft:{name:"ifft",category:"Matrix",syntax:["ifft(x)"],description:"Calculate N-dimensional inverse fourier transform",examples:["ifft([[2, 2], [0, 0]])"],seealso:["fft"]},sylvester:{name:"sylvester",category:"Algebra",syntax:["sylvester(A,B,C)"],description:"Solves the real-valued Sylvester equation AX+XB=C for X",examples:["sylvester([[-1, -2], [1, 1]], [[-2, 1], [-1, 2]], [[-3, 2], [3, 0]])","A = [[-1, -2], [1, 1]]; B = [[2, -1], [1, -2]]; C = [[-3, 2], [3, 0]]","sylvester(A, B, C)"],seealso:["schur","lyap"]},schur:{name:"schur",category:"Algebra",syntax:["schur(A)"],description:"Performs a real Schur decomposition of the real matrix A = UTU'",examples:["schur([[1, 0], [-4, 3]])","A = [[1, 0], [-4, 3]]","schur(A)"],seealso:["lyap","sylvester"]},lyap:{name:"lyap",category:"Algebra",syntax:["lyap(A,Q)"],description:"Solves the Continuous-time Lyapunov equation AP+PA'+Q=0 for P",examples:["lyap([[-2, 0], [1, -4]], [[3, 1], [1, 3]])","A = [[-2, 0], [1, -4]]","Q = [[3, 1], [1, 3]]","lyap(A,Q)"],seealso:["schur","sylvester"]},solveODE:{name:"solveODE",category:"Numeric",syntax:["solveODE(func, tspan, y0)","solveODE(func, tspan, y0, options)"],description:"Numerical Integration of Ordinary Differential Equations.",examples:["f(t,y) = y","tspan = [0, 4]","solveODE(f, tspan, 1)","solveODE(f, tspan, [1, 2])",'solveODE(f, tspan, 1, { method:"RK23", maxStep:0.1 })'],seealso:["derivative","simplifyCore"]},combinations:{name:"combinations",category:"Probability",syntax:["combinations(n, k)"],description:"Compute the number of combinations of n items taken k at a time",examples:["combinations(7, 5)"],seealso:["combinationsWithRep","permutations","factorial"]},combinationsWithRep:{name:"combinationsWithRep",category:"Probability",syntax:["combinationsWithRep(n, k)"],description:"Compute the number of combinations of n items taken k at a time with replacements.",examples:["combinationsWithRep(7, 5)"],seealso:["combinations","permutations","factorial"]},factorial:{name:"factorial",category:"Probability",syntax:["n!","factorial(n)"],description:"Compute the factorial of a value",examples:["5!","5 * 4 * 3 * 2 * 1","3!"],seealso:["combinations","combinationsWithRep","permutations","gamma"]},gamma:{name:"gamma",category:"Probability",syntax:["gamma(n)"],description:"Compute the gamma function. For small values, the Lanczos approximation is used, and for large values the extended Stirling approximation.",examples:["gamma(4)","3!","gamma(1/2)","sqrt(pi)"],seealso:["factorial"]},kldivergence:{name:"kldivergence",category:"Probability",syntax:["kldivergence(x, y)"],description:"Calculate the Kullback-Leibler (KL) divergence  between two distributions.",examples:["kldivergence([0.7,0.5,0.4], [0.2,0.9,0.5])"],seealso:[]},lgamma:{name:"lgamma",category:"Probability",syntax:["lgamma(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.",examples:["lgamma(4)","lgamma(1/2)","lgamma(i)","lgamma(complex(1.1, 2))"],seealso:["gamma"]},multinomial:{name:"multinomial",category:"Probability",syntax:["multinomial(A)"],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.",examples:["multinomial([1, 2, 1])"],seealso:["combinations","factorial"]},permutations:{name:"permutations",category:"Probability",syntax:["permutations(n)","permutations(n, k)"],description:"Compute the number of permutations of n items taken k at a time",examples:["permutations(5)","permutations(5, 3)"],seealso:["combinations","combinationsWithRep","factorial"]},pickRandom:{name:"pickRandom",category:"Probability",syntax:["pickRandom(array)","pickRandom(array, number)","pickRandom(array, weights)","pickRandom(array, number, weights)","pickRandom(array, weights, number)"],description:"Pick a random entry from a given array.",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)"],seealso:["random","randomInt"]},random:{name:"random",category:"Probability",syntax:["random()","random(max)","random(min, max)","random(size)","random(size, max)","random(size, min, max)"],description:"Return a random number.",examples:["random()","random(10, 20)","random([2, 3])"],seealso:["pickRandom","randomInt"]},randomInt:{name:"randomInt",category:"Probability",syntax:["randomInt(max)","randomInt(min, max)","randomInt(size)","randomInt(size, max)","randomInt(size, min, max)"],description:"Return a random integer number",examples:["randomInt(10, 20)","randomInt([2, 3], 10)"],seealso:["pickRandom","random"]},compare:{name:"compare",category:"Relational",syntax:["compare(x, y)"],description:"Compare two values. Returns 1 when x > y, -1 when x < y, and 0 when x == y.",examples:["compare(2, 3)","compare(3, 2)","compare(2, 2)","compare(5cm, 40mm)","compare(2, [1, 2, 3])"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compareNatural","compareText"]},compareNatural:{name:"compareNatural",category:"Relational",syntax:["compareNatural(x, y)"],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.",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})"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compare","compareText"]},compareText:{name:"compareText",category:"Relational",syntax:["compareText(x, y)"],description:"Compare two strings lexically. Comparison is case sensitive. Returns 1 when x > y, -1 when x < y, and 0 when x == y.",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"])'],seealso:["compare","compareNatural"]},deepEqual:{name:"deepEqual",category:"Relational",syntax:["deepEqual(x, y)"],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.",examples:["deepEqual([1,3,4], [1,3,4])","deepEqual([1,3,4], [1,3])"],seealso:["equal","unequal","smaller","larger","smallerEq","largerEq","compare"]},equal:{name:"equal",category:"Relational",syntax:["x == y","equal(x, y)"],description:"Check equality of two values. Returns true if the values are equal, and false if not.",examples:["2+2 == 3","2+2 == 4","a = 3.2","b = 6-2.8","a == b","50cm == 0.5m"],seealso:["unequal","smaller","larger","smallerEq","largerEq","compare","deepEqual","equalText"]},equalText:{name:"equalText",category:"Relational",syntax:["equalText(x, y)"],description:"Check equality of two strings. Comparison is case sensitive. Returns true if the values are equal, and false if not.",examples:['equalText("Hello", "Hello")','equalText("a", "A")','equal("2e3", "2000")','equalText("2e3", "2000")','equalText("B", ["A", "B", "C"])'],seealso:["compare","compareNatural","compareText","equal"]},larger:{name:"larger",category:"Relational",syntax:["x > y","larger(x, y)"],description:"Check if value x is larger than y. Returns true if x is larger than y, and false if not.",examples:["2 > 3","5 > 2*2","a = 3.3","b = 6-2.8","(a > b)","(b < a)","5 cm > 2 inch"],seealso:["equal","unequal","smaller","smallerEq","largerEq","compare"]},largerEq:{name:"largerEq",category:"Relational",syntax:["x >= y","largerEq(x, y)"],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.",examples:["2 >= 1+1","2 > 1+1","a = 3.2","b = 6-2.8","(a >= b)"],seealso:["equal","unequal","smallerEq","smaller","compare"]},smaller:{name:"smaller",category:"Relational",syntax:["x < y","smaller(x, y)"],description:"Check if value x is smaller than value y. Returns true if x is smaller than y, and false if not.",examples:["2 < 3","5 < 2*2","a = 3.3","b = 6-2.8","(a < b)","5 cm < 2 inch"],seealso:["equal","unequal","larger","smallerEq","largerEq","compare"]},smallerEq:{name:"smallerEq",category:"Relational",syntax:["x <= y","smallerEq(x, y)"],description:"Check if value x is smaller or equal to value y. Returns true if x is smaller than y, and false if not.",examples:["2 <= 1+1","2 < 1+1","a = 3.2","b = 6-2.8","(a <= b)"],seealso:["equal","unequal","larger","smaller","largerEq","compare"]},unequal:{name:"unequal",category:"Relational",syntax:["x != y","unequal(x, y)"],description:"Check unequality of two values. Returns true if the values are unequal, and false if they are equal.",examples:["2+2 != 3","2+2 != 4","a = 3.2","b = 6-2.8","a != b","50cm != 0.5m","5 cm != 2 inch"],seealso:["equal","smaller","larger","smallerEq","largerEq","compare","deepEqual"]},setCartesian:{name:"setCartesian",category:"Set",syntax:["setCartesian(set1, set2)"],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.",examples:["setCartesian([1, 2], [3, 4])"],seealso:["setUnion","setIntersect","setDifference","setPowerset"]},setDifference:{name:"setDifference",category:"Set",syntax:["setDifference(set1, set2)"],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.",examples:["setDifference([1, 2, 3, 4], [3, 4, 5, 6])","setDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setIntersect","setSymDifference"]},setDistinct:{name:"setDistinct",category:"Set",syntax:["setDistinct(set)"],description:"Collect the distinct elements of a multiset. A multi-dimension array will be converted to a single-dimension array before the operation.",examples:["setDistinct([1, 1, 1, 2, 2, 3])"],seealso:["setMultiplicity"]},setIntersect:{name:"setIntersect",category:"Set",syntax:["setIntersect(set1, set2)"],description:"Create the intersection of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setIntersect([1, 2, 3, 4], [3, 4, 5, 6])","setIntersect([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setDifference"]},setIsSubset:{name:"setIsSubset",category:"Set",syntax:["setIsSubset(set1, set2)"],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.",examples:["setIsSubset([1, 2], [3, 4, 5, 6])","setIsSubset([3, 4], [3, 4, 5, 6])"],seealso:["setUnion","setIntersect","setDifference"]},setMultiplicity:{name:"setMultiplicity",category:"Set",syntax:["setMultiplicity(element, set)"],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.",examples:["setMultiplicity(1, [1, 2, 2, 4])","setMultiplicity(2, [1, 2, 2, 4])"],seealso:["setDistinct","setSize"]},setPowerset:{name:"setPowerset",category:"Set",syntax:["setPowerset(set)"],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.",examples:["setPowerset([1, 2, 3])"],seealso:["setCartesian"]},setSize:{name:"setSize",category:"Set",syntax:["setSize(set)","setSize(set, unique)"],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.',examples:["setSize([1, 2, 2, 4])","setSize([1, 2, 2, 4], true)"],seealso:["setUnion","setIntersect","setDifference"]},setSymDifference:{name:"setSymDifference",category:"Set",syntax:["setSymDifference(set1, set2)"],description:"Create the symmetric difference of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setSymDifference([1, 2, 3, 4], [3, 4, 5, 6])","setSymDifference([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setUnion","setIntersect","setDifference"]},setUnion:{name:"setUnion",category:"Set",syntax:["setUnion(set1, set2)"],description:"Create the union of two (multi)sets. Multi-dimension arrays will be converted to single-dimension arrays before the operation.",examples:["setUnion([1, 2, 3, 4], [3, 4, 5, 6])","setUnion([[1, 2], [3, 4]], [[3, 4], [5, 6]])"],seealso:["setIntersect","setDifference"]},zpk2tf:{name:"zpk2tf",category:"Signal",syntax:["zpk2tf(z, p, k)"],description:"Compute the transfer function of a zero-pole-gain model.",examples:["zpk2tf([1, 2], [-1, -2], 1)","zpk2tf([1, 2], [-1, -2])","zpk2tf([1 - 3i, 2 + 2i], [-1, -2])"],seealso:[]},freqz:{name:"freqz",category:"Signal",syntax:["freqz(b, a)","freqz(b, a, w)"],description:"Calculates the frequency response of a filter given its numerator and denominator coefficients.",examples:["freqz([1, 2], [1, 2, 3])","freqz([1, 2], [1, 2, 3], [0, 1])","freqz([1, 2], [1, 2, 3], 512)"],seealso:[]},erf:{name:"erf",category:"Special",syntax:["erf(x)"],description:"Compute the erf function of a value using a rational Chebyshev approximations for different intervals of x",examples:["erf(0.2)","erf(-0.5)","erf(4)"],seealso:[]},zeta:{name:"zeta",category:"Special",syntax:["zeta(s)"],description:"Compute the Riemann Zeta Function using an infinite series and Riemanns Functional Equation for the entire complex plane",examples:["zeta(0.2)","zeta(-0.5)","zeta(4)"],seealso:[]},cumsum:{name:"cumsum",category:"Statistics",syntax:["cumsum(a, b, c, ...)","cumsum(A)"],description:"Compute the cumulative sum of all values.",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)"],seealso:["max","mean","median","min","prod","std","sum","variance"]},mad:{name:"mad",category:"Statistics",syntax:["mad(a, b, c, ...)","mad(A)"],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.",examples:["mad(10, 20, 30)","mad([1, 2, 3])"],seealso:["mean","median","std","abs"]},max:{name:"max",category:"Statistics",syntax:["max(a, b, c, ...)","max(A)","max(A, dimension)"],description:"Compute the maximum value of a list of values.",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)"],seealso:["mean","median","min","prod","std","sum","variance"]},mean:{name:"mean",category:"Statistics",syntax:["mean(a, b, c, ...)","mean(A)","mean(A, dimension)"],description:"Compute the arithmetic mean of a list of values.",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])"],seealso:["max","median","min","prod","std","sum","variance"]},median:{name:"median",category:"Statistics",syntax:["median(a, b, c, ...)","median(A)"],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.",examples:["median(5, 2, 7)","median([3, -1, 5, 7])"],seealso:["max","mean","min","prod","std","sum","variance","quantileSeq"]},min:{name:"min",category:"Statistics",syntax:["min(a, b, c, ...)","min(A)","min(A, dimension)"],description:"Compute the minimum value of a list of values.",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)"],seealso:["max","mean","median","prod","std","sum","variance"]},mode:{name:"mode",category:"Statistics",syntax:["mode(a, b, c, ...)","mode(A)","mode(A, a, b, B, c, ...)"],description:"Computes the mode of all values as an array. In case mode being more than one, multiple values are returned in an array.",examples:["mode(2, 1, 4, 3, 1)","mode([1, 2.7, 3.2, 4, 2.7])","mode(1, 4, 6, 1, 6)"],seealso:["max","mean","min","median","prod","std","sum","variance"]},prod:{name:"prod",category:"Statistics",syntax:["prod(a, b, c, ...)","prod(A)"],description:"Compute the product of all values.",examples:["prod(2, 3, 4)","prod([2, 3, 4])","prod([2, 5; 4, 3])"],seealso:["max","mean","min","median","min","std","sum","variance"]},quantileSeq:{name:"quantileSeq",category:"Statistics",syntax:["quantileSeq(A, prob[, sorted])","quantileSeq(A, [prob1, prob2, ...][, sorted])","quantileSeq(A, N[, sorted])"],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.",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)"],seealso:["mean","median","min","max","prod","std","sum","variance"]},std:{name:"std",category:"Statistics",syntax:["std(a, b, c, ...)","std(A)","std(A, dimension)","std(A, normalization)","std(A, dimension, normalization)"],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".',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])"],seealso:["max","mean","min","median","prod","sum","variance"]},sum:{name:"sum",category:"Statistics",syntax:["sum(a, b, c, ...)","sum(A)","sum(A, dimension)"],description:"Compute the sum of all values.",examples:["sum(2, 3, 4, 1)","sum([2, 3, 4, 1])","sum([2, 5; 4, 3])"],seealso:["max","mean","median","min","prod","std","sum","variance"]},variance:{name:"variance",category:"Statistics",syntax:["variance(a, b, c, ...)","variance(A)","variance(A, dimension)","variance(A, normalization)","variance(A, dimension, normalization)"],description:'Compute the variance of all values. Optional parameter normalization can be "unbiased" (default), "uncorrected", or "biased".',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])"],seealso:["max","mean","min","median","min","prod","std","sum"]},corr:{name:"corr",category:"Statistics",syntax:["corr(A,B)"],description:"Compute the correlation coefficient of a two list with values, For matrices, the matrix correlation coefficient is calculated.",examples:["corr([2, 4, 6, 8],[1, 2, 3, 6])","corr(matrix([[1, 2.2, 3, 4.8, 5], [1, 2, 3, 4, 5]]), matrix([[4, 5.3, 6.6, 7, 8], [1, 2, 3, 4, 5]]))"],seealso:["max","mean","min","median","min","prod","std","sum"]},acos:{name:"acos",category:"Trigonometry",syntax:["acos(x)"],description:"Compute the inverse cosine of a value in radians.",examples:["acos(0.5)","acos(cos(2.3))"],seealso:["cos","atan","asin"]},acosh:{name:"acosh",category:"Trigonometry",syntax:["acosh(x)"],description:"Calculate the hyperbolic arccos of a value, defined as `acosh(x) = ln(sqrt(x^2 - 1) + x)`.",examples:["acosh(1.5)"],seealso:["cosh","asinh","atanh"]},acot:{name:"acot",category:"Trigonometry",syntax:["acot(x)"],description:"Calculate the inverse cotangent of a value.",examples:["acot(0.5)","acot(cot(0.5))","acot(2)"],seealso:["cot","atan"]},acoth:{name:"acoth",category:"Trigonometry",syntax:["acoth(x)"],description:"Calculate the hyperbolic arccotangent of a value, defined as `acoth(x) = (ln((x+1)/x) + ln(x/(x-1))) / 2`.",examples:["acoth(2)","acoth(0.5)"],seealso:["acsch","asech"]},acsc:{name:"acsc",category:"Trigonometry",syntax:["acsc(x)"],description:"Calculate the inverse cotangent of a value.",examples:["acsc(2)","acsc(csc(0.5))","acsc(0.5)"],seealso:["csc","asin","asec"]},acsch:{name:"acsch",category:"Trigonometry",syntax:["acsch(x)"],description:"Calculate the hyperbolic arccosecant of a value, defined as `acsch(x) = ln(1/x + sqrt(1/x^2 + 1))`.",examples:["acsch(0.5)"],seealso:["asech","acoth"]},asec:{name:"asec",category:"Trigonometry",syntax:["asec(x)"],description:"Calculate the inverse secant of a value.",examples:["asec(0.5)","asec(sec(0.5))","asec(2)"],seealso:["acos","acot","acsc"]},asech:{name:"asech",category:"Trigonometry",syntax:["asech(x)"],description:"Calculate the inverse secant of a value.",examples:["asech(0.5)"],seealso:["acsch","acoth"]},asin:{name:"asin",category:"Trigonometry",syntax:["asin(x)"],description:"Compute the inverse sine of a value in radians.",examples:["asin(0.5)","asin(sin(0.5))"],seealso:["sin","acos","atan"]},asinh:{name:"asinh",category:"Trigonometry",syntax:["asinh(x)"],description:"Calculate the hyperbolic arcsine of a value, defined as `asinh(x) = ln(x + sqrt(x^2 + 1))`.",examples:["asinh(0.5)"],seealso:["acosh","atanh"]},atan:{name:"atan",category:"Trigonometry",syntax:["atan(x)"],description:"Compute the inverse tangent of a value in radians.",examples:["atan(0.5)","atan(tan(0.5))"],seealso:["tan","acos","asin"]},atanh:{name:"atanh",category:"Trigonometry",syntax:["atanh(x)"],description:"Calculate the hyperbolic arctangent of a value, defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`.",examples:["atanh(0.5)"],seealso:["acosh","asinh"]},atan2:{name:"atan2",category:"Trigonometry",syntax:["atan2(y, x)"],description:"Computes the principal value of the arc tangent of y/x in radians.",examples:["atan2(2, 2) / pi","angle = 60 deg in rad","x = cos(angle)","y = sin(angle)","atan2(y, x)"],seealso:["sin","cos","tan"]},cos:{name:"cos",category:"Trigonometry",syntax:["cos(x)"],description:"Compute the cosine of x in radians.",examples:["cos(2)","cos(pi / 4) ^ 2","cos(180 deg)","cos(60 deg)","sin(0.2)^2 + cos(0.2)^2"],seealso:["acos","sin","tan"]},cosh:{name:"cosh",category:"Trigonometry",syntax:["cosh(x)"],description:"Compute the hyperbolic cosine of x in radians.",examples:["cosh(0.5)"],seealso:["sinh","tanh","coth"]},cot:{name:"cot",category:"Trigonometry",syntax:["cot(x)"],description:"Compute the cotangent of x in radians. Defined as 1/tan(x)",examples:["cot(2)","1 / tan(2)"],seealso:["sec","csc","tan"]},coth:{name:"coth",category:"Trigonometry",syntax:["coth(x)"],description:"Compute the hyperbolic cotangent of x in radians.",examples:["coth(2)","1 / tanh(2)"],seealso:["sech","csch","tanh"]},csc:{name:"csc",category:"Trigonometry",syntax:["csc(x)"],description:"Compute the cosecant of x in radians. Defined as 1/sin(x)",examples:["csc(2)","1 / sin(2)"],seealso:["sec","cot","sin"]},csch:{name:"csch",category:"Trigonometry",syntax:["csch(x)"],description:"Compute the hyperbolic cosecant of x in radians. Defined as 1/sinh(x)",examples:["csch(2)","1 / sinh(2)"],seealso:["sech","coth","sinh"]},sec:{name:"sec",category:"Trigonometry",syntax:["sec(x)"],description:"Compute the secant of x in radians. Defined as 1/cos(x)",examples:["sec(2)","1 / cos(2)"],seealso:["cot","csc","cos"]},sech:{name:"sech",category:"Trigonometry",syntax:["sech(x)"],description:"Compute the hyperbolic secant of x in radians. Defined as 1/cosh(x)",examples:["sech(2)","1 / cosh(2)"],seealso:["coth","csch","cosh"]},sin:{name:"sin",category:"Trigonometry",syntax:["sin(x)"],description:"Compute the sine of x in radians.",examples:["sin(2)","sin(pi / 4) ^ 2","sin(90 deg)","sin(30 deg)","sin(0.2)^2 + cos(0.2)^2"],seealso:["asin","cos","tan"]},sinh:{name:"sinh",category:"Trigonometry",syntax:["sinh(x)"],description:"Compute the hyperbolic sine of x in radians.",examples:["sinh(0.5)"],seealso:["cosh","tanh"]},tan:{name:"tan",category:"Trigonometry",syntax:["tan(x)"],description:"Compute the tangent of x in radians.",examples:["tan(0.5)","sin(0.5) / cos(0.5)","tan(pi / 4)","tan(45 deg)"],seealso:["atan","sin","cos"]},tanh:{name:"tanh",category:"Trigonometry",syntax:["tanh(x)"],description:"Compute the hyperbolic tangent of x in radians.",examples:["tanh(0.5)","sinh(0.5) / cosh(0.5)"],seealso:["sinh","cosh"]},to:{name:"to",category:"Units",syntax:["x to unit","to(x, unit)"],description:"Change the unit of a value.",examples:["5 inch to cm","3.2kg to g","16 bytes in bits"],seealso:[]},clone:{name:"clone",category:"Utils",syntax:["clone(x)"],description:"Clone a variable. Creates a copy of primitive variables,and a deep copy of matrices",examples:["clone(3.5)","clone(2 - 4i)","clone(45 deg)","clone([1, 2; 3, 4])",'clone("hello world")'],seealso:[]},format:{name:"format",category:"Utils",syntax:["format(value)","format(value, precision)"],description:"Format a value of any type as string.",examples:["format(2.3)","format(3 - 4i)","format([])","format(pi, 3)"],seealso:["print"]},bin:{name:"bin",category:"Utils",syntax:["bin(value)"],description:"Format a number as binary",examples:["bin(2)"],seealso:["oct","hex"]},oct:{name:"oct",category:"Utils",syntax:["oct(value)"],description:"Format a number as octal",examples:["oct(56)"],seealso:["bin","hex"]},hex:{name:"hex",category:"Utils",syntax:["hex(value)"],description:"Format a number as hexadecimal",examples:["hex(240)"],seealso:["bin","oct"]},isNaN:{name:"isNaN",category:"Utils",syntax:["isNaN(x)"],description:"Test whether a value is NaN (not a number)",examples:["isNaN(2)","isNaN(0 / 0)","isNaN(NaN)","isNaN(Infinity)"],seealso:["isNegative","isNumeric","isPositive","isZero"]},isInteger:{name:"isInteger",category:"Utils",syntax:["isInteger(x)"],description:"Test whether a value is an integer number.",examples:["isInteger(2)","isInteger(3.5)","isInteger([3, 0.5, -2])"],seealso:["isNegative","isNumeric","isPositive","isZero"]},isNegative:{name:"isNegative",category:"Utils",syntax:["isNegative(x)"],description:"Test whether a value is negative: smaller than zero.",examples:["isNegative(2)","isNegative(0)","isNegative(-4)","isNegative([3, 0.5, -2])"],seealso:["isInteger","isNumeric","isPositive","isZero"]},isNumeric:{name:"isNumeric",category:"Utils",syntax:["isNumeric(x)"],description:"Test whether a value is a numeric value. Returns true when the input is a number, BigNumber, Fraction, or boolean.",examples:["isNumeric(2)",'isNumeric("2")','hasNumericValue("2")',"isNumeric(0)","isNumeric(bignumber(500))","isNumeric(fraction(0.125))","isNumeric(2 + 3i)",'isNumeric([2.3, "foo", false])'],seealso:["isInteger","isZero","isNegative","isPositive","isNaN","hasNumericValue"]},hasNumericValue:{name:"hasNumericValue",category:"Utils",syntax:["hasNumericValue(x)"],description:"Test whether a value is an numeric value. In case of a string, true is returned if the string contains a numeric value.",examples:["hasNumericValue(2)",'hasNumericValue("2")','isNumeric("2")',"hasNumericValue(0)","hasNumericValue(bignumber(500))","hasNumericValue(fraction(0.125))","hasNumericValue(2 + 3i)",'hasNumericValue([2.3, "foo", false])'],seealso:["isInteger","isZero","isNegative","isPositive","isNaN","isNumeric"]},isPositive:{name:"isPositive",category:"Utils",syntax:["isPositive(x)"],description:"Test whether a value is positive: larger than zero.",examples:["isPositive(2)","isPositive(0)","isPositive(-4)","isPositive([3, 0.5, -2])"],seealso:["isInteger","isNumeric","isNegative","isZero"]},isPrime:{name:"isPrime",category:"Utils",syntax:["isPrime(x)"],description:"Test whether a value is prime: has no divisors other than itself and one.",examples:["isPrime(3)","isPrime(-2)","isPrime([2, 17, 100])"],seealso:["isInteger","isNumeric","isNegative","isZero"]},isZero:{name:"isZero",category:"Utils",syntax:["isZero(x)"],description:"Test whether a value is zero.",examples:["isZero(2)","isZero(0)","isZero(-4)","isZero([3, 0, -2, 0])"],seealso:["isInteger","isNumeric","isNegative","isPositive"]},print:{name:"print",category:"Utils",syntax:["print(template, values)","print(template, values, precision)"],description:"Interpolate values into a string template.",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: $1, $2, $3", [6, 9, 4])'],seealso:["format"]},typeOf:{name:"typeOf",category:"Utils",syntax:["typeOf(x)"],description:"Get the type of a variable.",examples:["typeOf(3.5)","typeOf(2 - 4i)","typeOf(45 deg)",'typeOf("hello world")'],seealso:["getMatrixDataType"]},numeric:{name:"numeric",category:"Utils",syntax:["numeric(x)"],description:"Convert a numeric input to a specific numeric type: number, BigNumber, bigint, or Fraction.",examples:['numeric("4")','numeric("4", "number")','numeric("4", "bigint")','numeric("4", "BigNumber")','numeric("4", "Fraction")','numeric(4, "Fraction")','numeric(fraction(2, 5), "number")'],seealso:["number","bigint","fraction","bignumber","string","format"]}},Qf=s("help",["typed","mathWithTransform","Help"],e=>{let{typed:t,mathWithTransform:i,Help:a}=e;return t("help",{any:function(e){let t,r=e;if("string"!=typeof e)for(t in i)if(ue(i,t)&&e===i[t]){r=t;break}var n=Ze(Xf,r);if(n)return new a(n);{const e="function"==typeof r?r.name:r;throw new Error('No documentation found on "'+e+'"')}}})}),Kf=s("chain",["typed","Chain"],e=>{let{typed:t,Chain:r}=e;return t("chain",{"":function(){return new r},any:function(e){return new r(e)}})}),ep=s("det",["typed","matrix","subtractScalar","multiply","divideScalar","isZero","unaryMinus"],e=>{let{typed:t,matrix:c,subtractScalar:l,multiply:f,divideScalar:p,isZero:m,unaryMinus:h}=e;return t("det",{any:ee,"Array | Matrix":function(e){var t=_(e)?e.size():Array.isArray(e)?(e=c(e)).size():[];switch(t.length){case 0:return ee(e);case 1:if(1===t[0])return ee(e.valueOf()[0]);if(0===t[0])return 1;throw new RangeError("Matrix must be square (size: "+S(t)+")");case 2:{const c=t[0],n=t[1];if(c===n){var i=e.clone().valueOf();var a=c;if(1===a)return ee(i[0][0]);if(2===a)return l(f(i[0][0],i[1][1]),f(i[1][0],i[0][1]));{let n=!1;const u=new Array(a).fill(0).map((e,t)=>t);for(let r=0;r<a;r++){let t=u[r];if(m(i[t][r])){let e;for(e=r+1;e<a;e++)if(!m(i[u[e]][r])){t=u[e],u[e]=u[r],u[r]=t,n=!n;break}if(e===a)return i[t][r]}var o=i[t][r],s=0===r?1:i[u[r-1]][r-1];for(let e=r+1;e<a;e++){const m=u[e];for(let e=r+1;e<a;e++)i[m][e]=p(l(f(i[m][e],o),f(i[m][r],i[t][e])),s)}}var r=i[u[a-1]][a-1];return n?h(r):r}return}if(0===n)return 1;throw new RangeError("Matrix must be square (size: "+S(t)+")")}default:throw new RangeError("Matrix must be two dimensional (size: "+S(t)+")")}}})}),tp=s("inv",["typed","matrix","divideScalar","addScalar","multiply","unaryMinus","det","identity","abs"],e=>{let{typed:t,matrix:n,divideScalar:p,addScalar:m,multiply:h,unaryMinus:d,det:g,identity:y,abs:x}=e;return t("inv",{"Array | Matrix":function(e){var t=_(e)?e.size():T(e);switch(t.length){case 1:if(1===t[0])return _(e)?n([p(1,e.valueOf()[0])]):[p(1,e[0])];throw new RangeError("Matrix must be square (size: "+S(t)+")");case 2:{const p=t[0],r=t[1];if(p===r)return _(e)?n(i(e.valueOf(),p,r),e.storage()):i(e,p,r);throw new RangeError("Matrix must be square (size: "+S(t)+")")}default:throw new RangeError("Matrix must be two dimensional (size: "+S(t)+")")}},any:function(e){return p(1,e)}});function i(e,n,i){let a,o,s,u,c;if(1===n){if(0===(u=e[0][0]))throw Error("Cannot calculate inverse, determinant is zero");return[[p(1,u)]]}if(2===n){const n=g(e);if(0===n)throw Error("Cannot calculate inverse, determinant is zero");return[[p(e[1][1],n),p(d(e[0][1]),n)],[p(d(e[1][0]),n),p(e[0][0],n)]]}{const g=e.concat();for(a=0;a<n;a++)g[a]=g[a].concat();const u=y(n).valueOf();for(let r=0;r<i;r++){let e=x(g[r][r]),t=r;for(a=r+1;a<n;)x(g[a][r])>e&&(e=x(g[a][r]),t=a),a++;if(0===e)throw Error("Cannot calculate inverse, determinant is zero");(a=t)!==r&&(c=g[r],g[r]=g[a],g[a]=c,c=u[r],u[r]=u[a],u[a]=c);var l=g[r],f=u[r];for(a=0;a<n;a++){const n=g[a],y=u[a];if(a!==r){if(0!==n[r]){for(s=p(d(n[r]),l[r]),o=r;o<i;o++)n[o]=m(n[o],h(s,l[o]));for(o=0;o<i;o++)y[o]=m(y[o],h(s,f[o]))}}else{for(s=l[r],o=r;o<i;o++)n[o]=p(n[o],s);for(o=0;o<i;o++)y[o]=p(y[o],s)}}}return u}}}),rp=s("pinv",["typed","matrix","inv","deepEqual","equal","dotDivide","dot","ctranspose","divideScalar","multiply","add","Complex"],e=>{let{typed:t,matrix:i,inv:a,deepEqual:r,equal:n,dotDivide:u,dot:o,ctranspose:s,divideScalar:c,multiply:l,add:f,Complex:p}=e;return t("pinv",{"Array | Matrix":function(e){var t=_(e)?e.size():T(e);switch(t.length){case 1:return d(e)?s(e):1===t[0]?a(e):u(s(e),o(e,e));case 2:if(d(e))return s(e);var r=t[0],n=t[1];if(r===n)try{return a(e)}catch(e){if(!(e instanceof Error&&e.message.match(/Cannot calculate inverse, determinant is zero/)))throw e}return _(e)?i(m(e.valueOf(),r,n),e.storage()):m(e,r,n);default:throw new RangeError("Matrix must be two dimensional (size: "+S(t)+")")}},any:function(e){return n(e,0)?ee(e):c(1,e)}});function m(e,t,i){var{C:e,F:t}=function(e,r){const n=function(i,a){const o=ee(e);let s=0;for(let n=0;n<i;n++){if(a<=s)return o;let e=n;for(;h(o[e][s]);)if(i===++e&&(e=n,a===++s))return o;[o[e],o[n]]=[o[n],o[e]];let r=o[n][s];for(let e=0;e<a;e++)o[n][e]=u(o[n][e],r);for(let t=0;t<i;t++)if(t!==n){r=o[t][s];for(let e=0;e<a;e++)o[t][e]=f(o[t][e],l(-1,l(r,o[n][e])))}s++}return o}(r,i);return{C:e.map((e,t)=>e.filter((e,t)=>t<r&&!h(o(n[t],n[t])))),F:n.filter((e,t)=>!h(o(n[t],n[t])))}}(e,t),e=l(a(l(s(e),e)),s(e)),t=l(s(t),a(l(t,s(t))));return l(t,e)}function h(e){return n(f(e,p(1,1)),f(0,p(1,1)))}function d(e){return r(f(e,p(1,1)),f(l(e,0),p(1,1)))}}),np=s("eigs",["config","typed","matrix","addScalar","equal","subtract","abs","atan","cos","sin","multiplyScalar","divideScalar","inv","bignumber","multiply","add","larger","column","flatten","number","complex","sqrt","diag","size","reshape","qr","usolve","usolveAll","im","re","smaller","matrixFromColumns","dot"],e=>{let{config:s,typed:t,matrix:i,addScalar:r,subtract:p,equal:n,abs:m,atan:a,cos:o,sin:u,multiplyScalar:h,divideScalar:y,inv:x,bignumber:P,multiply:j,add:c,larger:q,column:l,flatten:U,number:f,complex:L,sqrt:R,diag:$,size:H,reshape:G,qr:Z,usolve:V,usolveAll:W,im:d,re:g,smaller:Y,matrixFromColumns:J,dot:X}=e;const w=function(){let{config:A,addScalar:S,subtract:M,abs:C,atan:T,cos:D,sin:F,multiplyScalar:B,inv:O,bignumber:_,multiply:z,add:I}={config:s,addScalar:r,subtract:p,column:l,flatten:U,equal:n,abs:m,atan:a,cos:o,sin:u,multiplyScalar:h,inv:x,bignumber:P,complex:L,multiply:j,add:c};function k(r){var n=r.length;let i=0,a=[0,1];for(let t=0;t<n;t++)for(let e=t+1;e<n;e++)Math.abs(i)<Math.abs(r[t][e])&&(i=Math.abs(r[t][e]),a=[t,e]);return[a,i]}function q(r){var n=r.length;let i=0,a=[0,1];for(let t=0;t<n;t++)for(let e=t+1;e<n;e++)C(i)<C(r[t][e])&&(i=C(r[t][e]),a=[t,e]);return[a,i]}function R(i,a,e){const o=i.length,s=Array(o);let u;if(e){u=Array(o);for(let e=0;e<o;e++)u[e]=Array(o)}for(let n=0;n<o;n++){let t=0,r=i[0];for(let e=0;e<i.length;e++)C(i[e])<C(r)&&(t=e,r=i[t]);if(s[n]=i.splice(t,1)[0],e)for(let e=0;e<o;e++)u[n][e]=a[e][t],a[e].splice(t,1)}if(!e)return{values:s};var t=u.map((e,t)=>({value:s[t],vector:e}));return{values:s,eigenvectors:t}}return function(n,e){var i,a,o,s,u,c,l=2<arguments.length&&void 0!==arguments[2]?arguments[2]:A.relTol,t=3<arguments.length?arguments[3]:void 0,f=4<arguments.length?arguments[4]:void 0;if("number"===t){var p=n,m=l,h=f;const x=p.length,b=Math.abs(m/x);let e,t;if(h){t=new Array(x);for(let e=0;e<x;e++)t[e]=Array(x).fill(0),t[e][e]=1}let r=k(p);for(;Math.abs(r[1])>=Math.abs(b);){const m=r[0][0],x=r[0][1];i=p[m][m],a=p[x][x],o=p[m][x],p=function(t,e,r,n){const i=t.length,a=Math.cos(e),o=Math.sin(e),s=a*a,u=o*o,c=Array(i).fill(0),l=Array(i).fill(0),f=s*t[r][r]-2*a*o*t[r][n]+u*t[n][n],p=u*t[r][r]+2*a*o*t[r][n]+s*t[n][n];for(let e=0;e<i;e++)c[e]=a*t[r][e]-o*t[n][e],l[e]=o*t[r][e]+a*t[n][e];t[r][r]=f,t[n][n]=p,t[r][n]=0;for(let e=t[n][r]=0;e<i;e++)e!==r&&e!==n&&(t[r][e]=c[e],t[e][r]=c[e],t[n][e]=l[e],t[e][n]=l[e]);return t}(p,e=Math.abs(a-i)<=A.relTol?Math.PI/4:.5*Math.atan(2*o/(a-i)),m,x),h&&(t=function(t,e,r,n){const i=t.length,a=Math.cos(e),o=Math.sin(e),s=Array(i).fill(0),u=Array(i).fill(0);for(let e=0;e<i;e++)s[e]=a*t[e][r]-o*t[e][n],u[e]=o*t[e][r]+a*t[e][n];for(let e=0;e<i;e++)t[e][r]=s[e],t[e][n]=u[e];return t}(t,e,m,x)),r=k(p)}const v=Array(x).fill(0);for(let e=0;e<x;e++)v[e]=p[e][e];return R(ee(v),t,h)}if("BigNumber"!==t)throw TypeError("Unsupported data type: "+t);{var d=n,g=l,y=f;const w=d.length,N=C(g/w);let e,t;if(y){t=new Array(w);for(let e=0;e<w;e++)t[e]=Array(w).fill(0),t[e][e]=1}let r=q(d);for(;C(r[1])>=C(N);){const g=r[0][0],w=r[0][1];s=d[g][g],u=d[w][w],c=d[g][w],u=M(u,s),d=function(t,e,r,n){const i=t.length,a=_(D(e)),o=_(F(e)),s=B(a,a),u=B(o,o),c=Array(i).fill(_(0)),l=Array(i).fill(_(0)),f=z(_(2),a,o,t[r][n]),p=S(M(B(s,t[r][r]),f),B(u,t[n][n])),m=I(B(u,t[r][r]),f,B(s,t[n][n]));for(let e=0;e<i;e++)c[e]=M(B(a,t[r][e]),B(o,t[n][e])),l[e]=S(B(o,t[r][e]),B(a,t[n][e]));t[r][r]=p,t[n][n]=m,t[r][n]=_(0),t[n][r]=_(0);for(let e=0;e<i;e++)e!==r&&e!==n&&(t[r][e]=c[e],t[e][r]=c[e],t[n][e]=l[e],t[e][n]=l[e]);return t}(d,e=C(u)<=A.relTol?_(-1).acos().div(4):B(.5,T(z(2,c,O(u)))),g,w),y&&(t=function(t,e,r,n){const i=t.length,a=D(e),o=F(e),s=Array(i).fill(_(0)),u=Array(i).fill(_(0));for(let e=0;e<i;e++)s[e]=M(B(a,t[e][r]),B(o,t[e][n])),u[e]=S(B(o,t[e][r]),B(a,t[e][n]));for(let e=0;e<i;e++)t[e][r]=s[e],t[e][n]=u[e];return t}(t,e,g,w)),r=q(d)}const E=Array(w).fill(0);for(let e=0;e<w;e++)E[e]=d[e][e];return R(ee(E),t,y)}}}(),N=function(){let{addScalar:v,subtract:w,flatten:b,multiply:N,multiplyScalar:E,divideScalar:d,sqrt:A,abs:S,bignumber:M,diag:C,size:i,reshape:a,inv:T,qr:D,usolve:u,usolveAll:F,equal:B,complex:O,larger:g,smaller:_,dot:o}={config:s,addScalar:r,subtract:p,multiply:j,multiplyScalar:h,flatten:U,divideScalar:y,sqrt:R,abs:m,bignumber:P,diag:$,size:H,reshape:G,qr:Z,inv:x,usolve:V,usolveAll:W,equal:n,complex:L,larger:q,smaller:Y,matrixFromColumns:J,dot:X};function z(e,t,r,n,i,a,o,s){var u="BigNumber"===s,s="Complex"===s,c=u?M(0):s?O(0):0,u=u?M(1):s?O(1):1;if(_(S(r),o))return[[u,c],[c,u]];if(g(S(w(i,a)),o))return[[w(i,n),w(a,n)],[r,r]];s=w(e,i),a=w(n,i);return _(S(t),o)&&_(S(a),o)?[[s,u],[r,c]]:[[t,c],[a,u]]}function I(t,r){for(let e=0;e<t.length;e++)t[e].push(...Array(r-t[e].length).fill(0));for(let e=t.length;e<r;e++)t.push(Array(r).fill(0)),t[e][e]=1}function k(e,t,r,n,i){var a="BigNumber"===i?M(1e3):1e3;let o,s=0;for(;s<5;++s){o=function(e,t,r){var n="BigNumber"===r,i="Complex"===r;let a=Array(e).fill(0).map(e=>2*Math.random()-1);return n&&(a=a.map(e=>M(e))),f(a=c(a=i?a.map(e=>O(e)):a,t),r)}(t,r,i);try{o=u(e,o)}catch(e){continue}if(g(l(o),a))break}if(5<=s)return null;for(s=0;;){const t=u(e,o);if(_(l(c(o,[t])),n))break;if(10<=++s)return null;o=f(t)}return o}function c(e,t){var r,n=i(e);for(r of t)r=a(r,n),e=w(e,N(d(o(r,e),o(r,r)),r));return e}function l(e){return S(A(o(e,e)))}function f(e,t){var r="Complex"===t,t="BigNumber"===t?M(1):r?O(1):1;return N(d(t,l(e)),e)}return function(e,t,r,n){var i=!(4<arguments.length&&void 0!==arguments[4])||arguments[4],a=function(a,o,s){const u="BigNumber"===n,c="Complex"===n,e=u?M(0):0,t=u?M(1):c?O(1):1,l=u?M(1):1,f=u?M(10):2,p=E(f,f);let m,h=(s&&(m=Array(o).fill(t)),!1);for(;!h;){h=!0;for(let i=0;i<o;i++){let r=e,n=e;for(let e=0;e<o;e++)i!==e&&(r=v(r,S(a[e][i])),n=v(n,S(a[i][e])));if(!B(r,0)&&!B(n,0)){let t=l,e=r;const u=d(n,f),c=E(n,f);for(;_(e,u);)e=E(e,p),t=E(t,f);for(;g(e,c);)e=d(e,p),t=d(t,f);if(_(d(v(e,n),t),E(v(r,n),.95))){h=!1;const v=d(1,t);for(let e=0;e<o;e++)i!==e&&(a[i][e]=E(a[i][e],v),a[e][i]=E(a[e][i],t));s&&(m[i]=E(m[i],v))}}}}return s?C(m):null}(e,t,i),o=e,s=t,u=r,c=i,l=a,f="BigNumber"===n,p="Complex"===n,m=f?M(0):p?O(0):0;f&&(u=M(u));for(let n=0;n<s-2;n++){let t=0,r=m;for(let e=n+1;e<s;e++){const w=o[e][n];_(S(r),S(w))&&(r=w,t=e)}if(!_(S(r),u)){if(t!==n+1){const v=o[t];o[t]=o[n+1],o[n+1]=v;for(let e=0;e<s;e++){const w=o[e][t];o[e][t]=o[e][n+1],o[e][n+1]=w}if(c){const o=l[t];l[t]=l[n+1],l[n+1]=o}}for(let t=n+2;t<s;t++){const S=d(o[t][n],r);if(0!==S){for(let e=0;e<s;e++)o[t][e]=w(o[t][e],E(S,o[n+1][e]));for(let e=0;e<s;e++)o[e][n+1]=v(o[e][n+1],E(S,o[e][t]));if(c)for(let e=0;e<s;e++)l[t][e]=w(l[t][e],E(S,l[n+1][e]))}}}}var{values:p,C:f}=function(t,e,r,n,i){const a="BigNumber"===n,o="Complex"===n,s=a?M(1):o?O(1):1;a&&(r=M(r));let u=ee(t);const c=[];let l=e;const f=[];let p=i?C(Array(e).fill(s)):void 0,m=i?C(Array(l).fill(s)):void 0,h=0;for(;h<=100;){h+=1;const t=u[l-1][l-1];for(let e=0;e<l;e++)u[e][e]=w(u[e][e],t);const{Q:M,R:a}=D(u);u=N(a,M);for(let e=0;e<l;e++)u[e][e]=v(u[e][e],t);if(i&&(m=N(m,M)),1===l||_(S(u[l-1][l-2]),r)){h=0,c.push(u[l-1][l-1]),i&&(f.unshift([[1]]),I(m,e),p=N(p,m),1<l&&(m=C(Array(l-1).fill(s)))),--l,u.pop();for(let e=0;e<l;e++)u[e].pop()}else if(2===l||_(S(u[l-2][l-3]),r)){h=0;d=u[l-2][l-2],g=u[l-2][l-1],y=u[l-1][l-2],x=u[l-1][l-1],b=void 0,b=v(d,x),d=w(E(d,x),E(g,y)),x=E(b,.5),g=E(A(w(E(b,b),E(4,d))),.5);const t=[v(x,g),w(x,g)];c.push(...t),i&&(f.unshift(z(u[l-2][l-2],u[l-2][l-1],u[l-1][l-2],u[l-1][l-1],t[0],t[1],r,n)),I(m,e),p=N(p,m),2<l&&(m=C(Array(l-2).fill(s)))),l-=2,u.pop(),u.pop();for(let e=0;e<l;e++)u[e].pop(),u[e].pop()}if(0===l)break}var d,g,y,x,b;if(c.sort((e,t)=>+w(S(e),S(t))),100<h){const t=Error("The eigenvalues failed to converge. Only found these eigenvalues: "+c.join(", "));throw t.values=c,t.vectors=[],t}t=i?N(p,function(r,n){const i=[];for(let e=0;e<n;e++)i[e]=Array(n).fill(0);let a=0;for(const n of r){const r=n.length;for(let t=0;t<r;t++)for(let e=0;e<r;e++)i[a+t][a+e]=n[t][e];a+=r}return i}(f,e)):void 0;return{values:c,C:t}}(e,t,r,n,i);if(i){const v=function(r,n,i,a,o,s,u){const c=T(i),l=N(c,r,i),e="BigNumber"===u,t="Complex"===u,f=e?M(0):t?O(0):0,p=e?M(1):t?O(1):1,m=[],h=[];for(const r of o){const n=function(t,r,n){for(let e=0;e<t.length;e++)if(n(t[e],r))return e;return-1}(m,r,B);-1===n?(m.push(r),h.push(1)):h[n]+=1}const d=[],g=m.length,y=Array(n).fill(f),x=C(Array(n).fill(p));for(let t=0;t<g;t++){const o=m[t],M=w(l,N(o,x));let e=F(M,y);for(e.shift();e.length<h[t];){const r=k(M,n,e,s,u);if(null===r)break;e.push(r)}const c=N(T(a),i);e=e.map(e=>N(c,e)),d.push(...e.map(e=>({value:o,vector:b(e)})))}return d}(e,t,f,a,p,r,n);return{values:p,eigenvectors:v}}return{values:p}}}();return t("eigs",{Array:function(e){return b(i(e))},"Array, number|BigNumber":function(e,t){return b(i(e),{precision:t})},"Array, Object":(e,t)=>b(i(e),t),Matrix:function(e){return b(e,{matricize:!0})},"Matrix, number|BigNumber":function(e,t){return b(e,{precision:t,matricize:!0})},"Matrix, Object":function(e,t){var r={matricize:!0};return an(r,t),b(e,r)}});function b(e,t){t=1<arguments.length&&void 0!==t?t:{};const r=!("eigenvectors"in t)||t.eigenvectors,n=function(e,t,r){const n=e.toArray(),i=e.size();if(2!==i.length||i[0]!==i[1])throw new RangeError(`Matrix must be square (size: ${S(i)})`);var a=i[0];if(function(r,n,i){for(let t=0;t<n;t++)for(let e=0;e<n;e++)if(q(P(m(d(r[t][e]))),i))return;return 1}(n,a,t)&&(function(r,n){for(let t=0;t<n;t++)for(let e=0;e<n;e++)r[t][e]=g(r[t][e])}(n,a),function(r,n,i){for(let t=0;t<n;t++)for(let e=t;e<n;e++)if(q(P(m(p(r[t][e],r[e][t]))),i))return;return 1}(n,a,t))){const i=v(e,n,a);return w(n,a,t,i,r)}e=v(e,n,a);return N(n,a,t,e,r)}(e,null!=(e=t.precision)?e:s.relTol,r);return t.matricize&&(n.values=i(n.values),r&&(n.eigenvectors=n.eigenvectors.map(e=>{var{value:e,vector:t}=e;return{value:e,vector:i(t)}}))),r&&Object.defineProperty(n,"vectors",{enumerable:!1,get:()=>{throw new Error("eigs(M).vectors replaced with eigs(M).eigenvectors")}}),n}function v(e,r,n){e=e.datatype();if("number"===e||"BigNumber"===e||"Complex"===e)return e;let i=!1,a=!1,o=!1;for(let t=0;t<n;t++)for(let e=0;e<n;e++){const n=r[t][e];if(E(n)||I(n))i=!0;else if(Q(n))a=!0;else{if(!te(n))throw TypeError("Unsupported type in Matrix: "+K(n));o=!0}}if(a&&o&&console.warn("Complex BigNumbers not supported, this operation will lose precission."),o){for(let t=0;t<n;t++)for(let e=0;e<n;e++)r[t][e]=L(r[t][e]);return"Complex"}if(a){for(let t=0;t<n;t++)for(let e=0;e<n;e++)r[t][e]=P(r[t][e]);return"BigNumber"}if(i){for(let t=0;t<n;t++)for(let e=0;e<n;e++)r[t][e]=f(r[t][e]);return"number"}throw TypeError("Matrix contains unsupported types only.")}}),ip=s("expm",["typed","abs","add","identity","inv","multiply"],e=>{let{typed:t,abs:p,add:m,identity:h,inv:d,multiply:g}=e;return t("expm",{Matrix:function(e){var t=e.size();if(2!==t.length||t[0]!==t[1])throw new RangeError("Matrix must be square (size: "+S(t)+")");var t=t[0],r=function(r){for(let t=0;t<30;t++)for(let e=0;e<=t;e++){var n=t-e;if(function(e,t,r){let n=1;for(let e=2;e<=t;e++)n*=e;let i=n;for(let e=t+1;e<=2*t;e++)i*=e;var a=i*(2*t+1);return 8*Math.pow(e/Math.pow(2,r),2*t)*n*n/(i*a)}(r,e,n)<1e-15)return{q:e,j:n}}throw new Error("Could not find acceptable parameters to compute the matrix exponential (try increasing maxSearchSize in expm.js)")}(function(n){var i=n.size()[0];let e=0;for(let r=0;r<i;r++){let t=0;for(let e=0;e<i;e++)t+=p(n.get([r,e]));e=Math.max(t,e)}return e}(e)),n=r.q,i=r.j,a=g(e,Math.pow(2,-i));let o=h(t),s=h(t),u=1,c=a,l=-1;for(let e=1;e<=n;e++)1<e&&(c=g(c,a),l=-l),u=u*(n-e+1)/((2*n-e+1)*e),o=m(o,g(u,c)),s=m(s,g(u*l,c));let f=g(d(s),o);for(let e=0;e<i;e++)f=g(f,f);return P(e)?e.createSparseMatrix(f):f}})}),ap=s("sqrtm",["typed","abs","add","multiply","map","sqrt","subtract","inv","size","max","identity"],e=>{let{typed:t,abs:o,add:s,multiply:u,map:r,sqrt:n,subtract:c,inv:l,size:f,max:p,identity:m}=e;return t("sqrtm",{"Array | Matrix":function(i){var e=_(i)?i.size():T(i);switch(e.length){case 1:if(1===e[0])return r(i,n);throw new RangeError("Matrix must be square (size: "+S(e)+")");case 2:if(e[0]!==e[1])throw new RangeError("Matrix must be square (size: "+S(e)+")");{var a=i;let e,t=0,r=a,n=m(f(a));do{const a=r;if(r=u(.5,s(a,l(n))),n=u(.5,s(n,l(a))),1e-6<(e=p(o(c(r,a))))&&1e3<++t)throw new Error("computing square root of matrix: iterative method could not converge")}while(1e-6<e);return r;return}default:throw new RangeError("Matrix must be at most two dimensional (size: "+S(e)+")")}}})}),op="sylvester",sp=s(op,["typed","schur","matrixFromColumns","matrix","multiply","range","concat","transpose","index","subset","add","subtract","identity","lusolve","abs"],e=>{let{typed:t,schur:g,matrixFromColumns:y,matrix:x,multiply:b,range:v,concat:w,transpose:N,index:E,subset:A,add:S,subtract:M,identity:C,lusolve:T,abs:D}=e;return t(op,{"Matrix, Matrix, Matrix":n,"Array, Matrix, Matrix":function(e,t,r){return n(x(e),t,r)},"Array, Array, Matrix":function(e,t,r){return n(x(e),x(t),r)},"Array, Matrix, Array":function(e,t,r){return n(x(e),t,x(r))},"Matrix, Array, Matrix":function(e,t,r){return n(e,x(t),r)},"Matrix, Array, Array":function(e,t,r){return n(e,x(t),x(r))},"Matrix, Matrix, Array":function(e,t,r){return n(e,t,x(r))},"Array, Array, Array":function(e,t,r){return n(x(e),x(t),x(r)).toArray()}});function n(e,t,r){const n=t.size()[0],i=e.size()[0],a=g(e),o=a.T,s=a.U,u=g(b(-1,t)),c=u.T,l=u.U,f=b(b(N(s),r),l),p=v(0,i),m=[],h=(e,t)=>w(e,t,1),d=(e,t)=>w(e,t,0);for(let r=0;r<n;r++)if(r<n-1&&1e-5<D(A(c,E(r+1,r)))){let t=d(A(f,E(p,r)),A(f,E(p,r+1)));for(let e=0;e<r;e++)t=S(t,d(b(m[e],A(c,E(e,r))),b(m[e],A(c,E(e,r+1)))));const g=b(C(i),b(-1,A(c,E(r,r)))),y=b(C(i),b(-1,A(c,E(r+1,r)))),x=b(C(i),b(-1,A(c,E(r,r+1)))),w=b(C(i),b(-1,A(c,E(r+1,r+1)))),N=d(h(S(o,g),y),h(x,S(o,w))),M=T(N,t);m[r]=M.subset(E(v(0,i),0)),m[r+1]=M.subset(E(v(i,2*i),0)),r++}else{let t=A(f,E(p,r));for(let e=0;e<r;e++)t=S(t,b(m[e],A(c,E(e,r))));const g=A(c,E(r,r)),y=M(o,b(g,C(i)));m[r]=T(y,t)}e=x(y(...m));return b(s,b(e,N(l)))}}),up=s("schur",["typed","matrix","identity","multiply","qr","norm","subtract"],e=>{let{typed:t,matrix:r,identity:o,multiply:s,qr:u,norm:c,subtract:l}=e;return t("schur",{Array:function(e){const t=n(r(e));return{U:t.U.valueOf(),T:t.T.valueOf()}},Matrix:n});function n(e){const t=e.size()[0];let r,n=e,i=o(t),a=0;do{r=n;const e=u(n),t=e.Q,o=e.R;if(n=s(o,t),i=s(i,t),100<a++)break}while(1e-4<c(l(n,r)));return{U:i,T:n}}}),cp=s("lyap",["typed","matrix","sylvester","multiply","transpose"],e=>{let{typed:t,matrix:r,sylvester:n,multiply:i,transpose:a}=e;return t("lyap",{"Matrix, Matrix":function(e,t){return n(e,a(e),i(-1,t))},"Array, Matrix":function(e,t){return n(r(e),a(r(e)),i(-1,t))},"Matrix, Array":function(e,t){return n(e,a(r(e)),r(i(-1,t)))},"Array, Array":function(e,t){return n(r(e),a(r(e)),r(i(-1,t))).toArray()}})}),lp=s("divide",["typed","matrix","multiply","equalScalar","divideScalar","inv"],e=>{let{typed:t,matrix:r,multiply:n,equalScalar:i,divideScalar:a,inv:o}=e;const s=x({typed:t,equalScalar:i}),u=ua({typed:t});return t("divide",je({"Array | Matrix, Array | Matrix":function(e,t){return n(e,o(t))},"DenseMatrix, any":function(e,t){return u(e,t,a,!1)},"SparseMatrix, any":function(e,t){return s(e,t,a,!1)},"Array, any":function(e,t){return u(r(e),t,a,!1).valueOf()},"any, Array | Matrix":function(e,t){return n(e,o(t))}},a.signatures))}),fp="distance",pp=s(fp,["typed","addScalar","subtractScalar","divideScalar","multiplyScalar","deepEqual","sqrt","abs"],e=>{let{typed:t,addScalar:c,subtractScalar:l,multiplyScalar:f,divideScalar:p,deepEqual:a,sqrt:m,abs:o}=e;return t(fp,{"Array, Array, Array":function(e,t,r){if(2!==e.length||2!==t.length||2!==r.length)throw new TypeError("Invalid Arguments: Try again");if(!s(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(!s(t))throw new TypeError("Array with 2 numbers or BigNumbers expected for second argument");if(!s(r))throw new TypeError("Array with 2 numbers or BigNumbers expected for third argument");if(a(t,r))throw new TypeError("LinePoint1 should not be same with LinePoint2");var n=l(r[1],t[1]),i=l(t[0],r[0]),t=l(f(r[0],t[1]),f(t[0],r[1]));return d(e[0],e[1],n,i,t)},"Object, Object, Object":function(e,t,r){if(2!==Object.keys(e).length||2!==Object.keys(t).length||2!==Object.keys(r).length)throw new TypeError("Invalid Arguments: Try again");if(!s(e))throw new TypeError("Values of pointX and pointY should be numbers or BigNumbers");if(!s(t))throw new TypeError("Values of lineOnePtX and lineOnePtY should be numbers or BigNumbers");if(!s(r))throw new TypeError("Values of lineTwoPtX and lineTwoPtY should be numbers or BigNumbers");if(a(h(t),h(r)))throw new TypeError("LinePoint1 should not be same with LinePoint2");if("pointX"in e&&"pointY"in e&&"lineOnePtX"in t&&"lineOnePtY"in t&&"lineTwoPtX"in r&&"lineTwoPtY"in r){const n=l(r.lineTwoPtY,t.lineOnePtY),i=l(t.lineOnePtX,r.lineTwoPtX),a=l(f(r.lineTwoPtX,t.lineOnePtY),f(t.lineOnePtX,r.lineTwoPtY));return d(e.pointX,e.pointY,n,i,a)}throw new TypeError("Key names do not match")},"Array, Array":function(e,t){if(2===e.length&&3===t.length){if(!s(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(n(t))return d(e[0],e[1],t[0],t[1],t[2]);throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument")}if(3===e.length&&6===t.length){if(!n(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(u(t))return g(e[0],e[1],e[2],t[0],t[1],t[2],t[3],t[4],t[5]);throw new TypeError("Array with 6 numbers or BigNumbers expected for second argument")}if(e.length===t.length&&0<e.length){if(!i(e))throw new TypeError("All values of an array should be numbers or BigNumbers");if(i(t))return y(e,t);throw new TypeError("All values of an array should be numbers or BigNumbers")}throw new TypeError("Invalid Arguments: Try again")},"Object, Object":function(e,t){if(2===Object.keys(e).length&&3===Object.keys(t).length){if(!s(e))throw new TypeError("Values of pointX and pointY should be numbers or BigNumbers");if(!n(t))throw new TypeError("Values of xCoeffLine, yCoeffLine and constant should be numbers or BigNumbers");if("pointX"in e&&"pointY"in e&&"xCoeffLine"in t&&"yCoeffLine"in t&&"constant"in t)return d(e.pointX,e.pointY,t.xCoeffLine,t.yCoeffLine,t.constant);throw new TypeError("Key names do not match")}if(3===Object.keys(e).length&&6===Object.keys(t).length){if(!n(e))throw new TypeError("Values of pointX, pointY and pointZ should be numbers or BigNumbers");if(!u(t))throw new TypeError("Values of x0, y0, z0, a, b and c should be numbers or BigNumbers");if("pointX"in e&&"pointY"in e&&"x0"in t&&"y0"in t&&"z0"in t&&"a"in t&&"b"in t&&"c"in t)return g(e.pointX,e.pointY,e.pointZ,t.x0,t.y0,t.z0,t.a,t.b,t.c);throw new TypeError("Key names do not match")}if(2===Object.keys(e).length&&2===Object.keys(t).length){if(!s(e))throw new TypeError("Values of pointOneX and pointOneY should be numbers or BigNumbers");if(!s(t))throw new TypeError("Values of pointTwoX and pointTwoY should be numbers or BigNumbers");if("pointOneX"in e&&"pointOneY"in e&&"pointTwoX"in t&&"pointTwoY"in t)return y([e.pointOneX,e.pointOneY],[t.pointTwoX,t.pointTwoY]);throw new TypeError("Key names do not match")}if(3!==Object.keys(e).length||3!==Object.keys(t).length)throw new TypeError("Invalid Arguments: Try again");if(!n(e))throw new TypeError("Values of pointOneX, pointOneY and pointOneZ should be numbers or BigNumbers");if(!n(t))throw new TypeError("Values of pointTwoX, pointTwoY and pointTwoZ should be numbers or BigNumbers");if("pointOneX"in e&&"pointOneY"in e&&"pointOneZ"in e&&"pointTwoX"in t&&"pointTwoY"in t&&"pointTwoZ"in t)return y([e.pointOneX,e.pointOneY,e.pointOneZ],[t.pointTwoX,t.pointTwoY,t.pointTwoZ]);throw new TypeError("Key names do not match")},Array:function(e){if(function(e){if(2===e[0].length&&r(e[0][0])&&r(e[0][1])){if(e.some(e=>2!==e.length||!r(e[0])||!r(e[1])))return}else{if(!(3===e[0].length&&r(e[0][0])&&r(e[0][1])&&r(e[0][2])))return;if(e.some(e=>3!==e.length||!r(e[0])||!r(e[1])||!r(e[2])))return}return 1}(e)){var i=e;const a=[];let r=[],n=[];for(let t=0;t<i.length-1;t++)for(let e=t+1;e<i.length;e++)2===i[0].length?(r=[i[t][0],i[t][1]],n=[i[e][0],i[e][1]]):3===i[0].length&&(r=[i[t][0],i[t][1],i[t][2]],n=[i[e][0],i[e][1],i[e][2]]),a.push(y(r,n));return a}throw new TypeError("Incorrect array format entered for pairwise distance calculation")}});function r(e){return"number"==typeof e||Q(e)}function s(e){return r((e=e.constructor!==Array?h(e):e)[0])&&r(e[1])}function n(e){return r((e=e.constructor!==Array?h(e):e)[0])&&r(e[1])&&r(e[2])}function i(e){return(e=Array.isArray(e)?e:h(e)).every(r)}function u(e){return r((e=e.constructor!==Array?h(e):e)[0])&&r(e[1])&&r(e[2])&&r(e[3])&&r(e[4])&&r(e[5])}function h(t){const r=Object.keys(t),n=[];for(let e=0;e<r.length;e++)n.push(t[r[e]]);return n}function d(e,t,r,n,i){e=o(c(c(f(r,e),f(n,t)),i)),t=m(c(f(r,r),f(n,n)));return p(e,t)}function g(e,t,r,n,i,a,o,s,u){a=[l(f(l(i,t),u),f(l(a,r),s)),l(f(l(a,r),o),f(l(n,e),u)),l(f(l(n,e),s),f(l(i,t),o))],a=m(c(c(f(a[0],a[0]),f(a[1],a[1])),f(a[2],a[2]))),r=m(c(c(f(o,o),f(s,s)),f(u,u)));return p(a,r)}function y(t,r){var n=t.length;let i=0,a;for(let e=0;e<n;e++)a=l(t[e],r[e]),i=c(f(a,a),i);return m(i)}}),mp=s("intersect",["typed","config","abs","add","addScalar","matrix","multiply","multiplyScalar","divideScalar","subtract","smaller","equalScalar","flatten","isZero","isNumeric"],e=>{let{typed:t,config:y,abs:x,add:b,addScalar:v,matrix:i,multiply:w,multiplyScalar:N,divideScalar:E,subtract:A,smaller:S,equalScalar:M,flatten:r,isZero:C,isNumeric:m}=e;return t("intersect",{"Array, Array, Array":n,"Array, Array, Array, Array":a,"Matrix, Matrix, Matrix":function(e,t,r){e=n(e.valueOf(),t.valueOf(),r.valueOf());return null===e?null:i(e)},"Matrix, Matrix, Matrix, Matrix":function(e,t,r,n){e=a(e.valueOf(),t.valueOf(),r.valueOf(),n.valueOf());return null===e?null:i(e)}});function n(e,t,r){if(e=T(e),t=T(t),r=T(r),!F(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(!F(t))throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument");if(4===(n=r).length&&m(n[0])&&m(n[1])&&m(n[2])&&m(n[3]))return n=e[0],i=e[1],e=e[2],a=t[0],o=t[1],t=t[2],s=r[0],u=r[1],c=r[2],r=r[3],l=N(n,s),s=N(a,s),f=N(i,u),u=N(o,u),p=N(e,c),c=N(t,c),r=A(A(A(r,l),f),p),s=A(A(A(v(v(s,u),c),l),f),p),u=E(r,s),[v(n,N(u,A(a,n))),v(i,N(u,A(o,i))),v(e,N(u,A(t,e)))];var n,i,a,o,s,u,c,l,f,p;throw new TypeError("Array with 4 numbers expected as third argument")}function a(e,t,r,n){if(e=T(e),t=T(t),r=T(r),n=T(n),2===e.length){if(!D(e))throw new TypeError("Array with 2 numbers or BigNumbers expected for first argument");if(!D(t))throw new TypeError("Array with 2 numbers or BigNumbers expected for second argument");if(!D(r))throw new TypeError("Array with 2 numbers or BigNumbers expected for third argument");if(D(n)){var i=t;var a=n;var o=e,s=r,i=A(o,i),a=A(s,a),u=A(N(i[0],a[1]),N(a[0],i[1]));if(C(u))return null;if(S(x(u),y.relTol))return null;var c=N(a[0],o[1]),l=N(a[1],o[0]),f=N(a[0],s[1]),a=N(a[1],s[0]),s=E(v(A(A(c,l),f),a),u);return b(w(i,s),o);return}throw new TypeError("Array with 2 numbers or BigNumbers expected for fourth argument")}if(3!==e.length)throw new TypeError("Arrays with two or thee dimensional points expected");if(!F(e))throw new TypeError("Array with 3 numbers or BigNumbers expected for first argument");if(!F(t))throw new TypeError("Array with 3 numbers or BigNumbers expected for second argument");if(!F(r))throw new TypeError("Array with 3 numbers or BigNumbers expected for third argument");var p,m,h,d,g;{if(F(n))return c=e[0],l=e[1],f=e[2],a=t[0],u=t[1],i=t[2],s=r[0],o=r[1],e=r[2],t=n[0],r=n[1],n=n[2],p=B(c,s,t,s,l,o,r,o,f,e,n,e),m=B(t,s,a,c,r,o,u,l,n,e,i,f),d=B(c,s,a,c,l,o,u,l,f,e,i,f),h=B(t,s,t,s,r,o,r,o,n,e,n,e),g=B(a,c,a,c,u,l,u,l,i,f,i,f),d=A(N(p,m),N(d,h)),g=A(N(g,h),N(m,m)),C(g)?null:(d=E(d,g),g=E(v(p,N(d,m)),h),p=v(c,N(d,A(a,c))),m=v(l,N(d,A(u,l))),h=v(f,N(d,A(i,f))),a=v(s,N(g,A(t,s))),c=v(o,N(g,A(r,o))),u=v(e,N(g,A(n,e))),M(p,a)&&M(m,c)&&M(h,u)?[p,m,h]:null);throw new TypeError("Array with 3 numbers or BigNumbers expected for fourth argument")}}function T(e){return 1===e.length?e[0]:1<e.length&&Array.isArray(e[0])&&e.every(e=>Array.isArray(e)&&1===e.length)?r(e):e}function D(e){return 2===e.length&&m(e[0])&&m(e[1])}function F(e){return 3===e.length&&m(e[0])&&m(e[1])&&m(e[2])}function B(e,t,r,n,i,a,o,s,u,c,l,f){e=N(A(e,t),A(r,n)),t=N(A(i,a),A(o,s)),r=N(A(u,c),A(l,f));return v(v(e,t),r)}}),hp=s("sum",["typed","config","add","numeric"],e=>{let{typed:t,config:n,add:i,numeric:a}=e;return t("sum",{"Array | Matrix":r,"Array | Matrix, number | BigNumber":function(e,t){try{return $n(e,t,i)}catch(e){throw _s(e,"sum")}},"...":function(e){if(Un(e))throw new TypeError("Scalar values expected in function sum");return r(e)}});function r(e){let r;return Ln(e,function(t){try{r=void 0===r?t:i(r,t)}catch(e){throw _s(e,"sum",t)}}),r="string"==typeof(r=void 0===r?a(0,n.number):r)?a(r,we(r,n)):r}}),dp="cumsum",gp=s(dp,["typed","add","unaryPlus"],e=>{let{typed:t,add:n,unaryPlus:i}=e;return t(dp,{Array:r,Matrix:function(e){return e.create(r(e.valueOf()))},"Array, number | BigNumber":a,"Matrix, number | BigNumber":function(e,t){return e.create(a(e.valueOf(),t))},"...":function(e){if(Un(e))throw new TypeError("All values expected to be scalar in function cumsum");return r(e)}});function r(e){try{return s(e)}catch(e){throw _s(e,dp)}}function s(t){if(0===t.length)return[];const r=[i(t[0])];for(let e=1;e<t.length;++e)r.push(n(r[e-1],t[e]));return r}function a(e,t){var r=T(e);if(t<0||t>=r.length)throw new mn(t,r.length);try{return function e(t,r){let n,i,a;if(r<=0){const o=t[0][0];if(Array.isArray(o)){for(a=jn(t),i=[],n=0;n<a.length;n++)i[n]=e(a[n],r-1);return i}return s(t)}for(i=[],n=0;n<t.length;n++)i[n]=e(t[n],r-1);return i}(e,t)}catch(e){throw _s(e,dp)}}}),yp=s("mean",["typed","add","divide"],e=>{let{typed:t,add:i,divide:a}=e;return t("mean",{"Array | Matrix":r,"Array | Matrix, number | BigNumber":function(e,t){try{var r=$n(e,t,i),n=Array.isArray(e)?T(e):e.size();return a(r,n[t])}catch(e){throw _s(e,"mean")}},"...":function(e){if(Un(e))throw new TypeError("Scalar values expected in function mean");return r(e)}});function r(e){let r,n=0;if(Ln(e,function(t){try{r=void 0===r?t:i(r,t),n++}catch(e){throw _s(e,"mean",t)}}),0===n)throw new Error("Cannot calculate the mean of an empty array");return a(r,n)}}),xp=s("median",["typed","add","divide","compare","partitionSelect"],e=>{let{typed:t,add:r,divide:n,compare:a,partitionSelect:o}=e;function i(r){try{var e=(r=A(r.valueOf())).length;if(0===e)throw new Error("Cannot calculate median of an empty array");if(e%2==0){var n=e/2-1,i=o(r,1+n);let t=r[n];for(let e=0;e<n;++e)0<a(r[e],t)&&(t=r[e]);return u(t,i)}var t=o(r,(e-1)/2);return s(t)}catch(r){throw _s(r,"median")}}const s=t({"number | BigNumber | Complex | Unit":function(e){return e}}),u=t({"number | BigNumber | Complex | Unit, number | BigNumber | Complex | Unit":function(e,t){return n(r(e,t),2)}});return t("median",{"Array | Matrix":i,"Array | Matrix, number | BigNumber":function(e,t){throw new Error("median(A, dim) is not yet supported")},"...":function(e){if(Un(e))throw new TypeError("Scalar values expected in function median");return i(e)}})}),bp=s("mad",["typed","abs","map","median","subtract"],e=>{let{typed:t,abs:r,map:n,median:i,subtract:a}=e;return t("mad",{"Array | Matrix":o,"...":o});function o(e){if(0===(e=A(e.valueOf())).length)throw new Error("Cannot calculate median absolute deviation (mad) of an empty array");try{const t=i(e);return i(n(e,function(e){return r(a(e,t))}))}catch(e){throw e instanceof TypeError&&e.message.includes("median")?new TypeError(e.message.replace("median","mad")):_s(e,"mad")}}}),vp="unbiased",wp="variance",Np=s(wp,["typed","add","subtract","multiply","divide","apply","isNaN"],e=>{let{typed:t,add:a,subtract:o,multiply:s,divide:u,apply:n,isNaN:c}=e;return t(wp,{"Array | Matrix":function(e){return i(e,vp)},"Array | Matrix, string":i,"Array | Matrix, number | BigNumber":function(e,t){return r(e,t,vp)},"Array | Matrix, number | BigNumber, string":r,"...":function(e){return i(e,vp)}});function i(e,t){let r,n=0;if(0===e.length)throw new SyntaxError("Function variance requires one or more parameters (0 provided)");if(Ln(e,function(t){try{r=void 0===r?t:a(r,t),n++}catch(e){throw _s(e,"variance",t)}}),0===n)throw new Error("Cannot calculate variance of an empty array");const i=u(r,n);if(r=void 0,Ln(e,function(e){e=o(e,i);r=void 0===r?s(e,e):a(r,s(e,e))}),c(r))return r;switch(t){case"uncorrected":return u(r,n);case"biased":return u(r,n+1);case"unbiased":{const e=Q(r)?r.mul(0):0;return 1===n?e:u(r,n-1)}default:throw new Error('Unknown normalization "'+t+'". Choose "unbiased" (default), "uncorrected", or "biased".')}}function r(e,t,r){try{if(0===e.length)throw new SyntaxError("Function variance requires one or more parameters (0 provided)");return n(e,t,e=>i(e,r))}catch(e){throw _s(e,"variance")}}}),Ep="quantileSeq",Ap=s(Ep,["typed","?bignumber","add","subtract","divide","multiply","partitionSelect","compare","isInteger","smaller","smallerEq","larger"],e=>{let{typed:t,bignumber:o,add:c,subtract:l,divide:s,multiply:f,partitionSelect:p,compare:m,isInteger:h,smaller:u,smallerEq:d,larger:g}=e;const a=ta({typed:t,isInteger:h});return t(Ep,{"Array | Matrix, number | BigNumber":(e,t)=>y(e,t,!1),"Array | Matrix, number | BigNumber, number":(e,t,r)=>i(e,t,!1,r,y),"Array | Matrix, number | BigNumber, boolean":y,"Array | Matrix, number | BigNumber, boolean, number":(e,t,r,n)=>i(e,t,r,n,y),"Array | Matrix, Array | Matrix":(e,t)=>x(e,t,!1),"Array | Matrix, Array | Matrix, number":(e,t,r)=>i(e,t,!1,r,x),"Array | Matrix, Array | Matrix, boolean":x,"Array | Matrix, Array | Matrix, boolean, number":(e,t,r,n)=>i(e,t,r,n,x)});function i(e,t,r,n,i){return a(e,n,e=>i(e,t,r))}function y(t,r,n){let i;var a=t.valueOf();if(u(r,0))throw new Error("N/prob must be non-negative");if(d(r,1))return E(r)?b(a,r,n):o(b(a,r,n));if(g(r,1)){if(!h(r))throw new Error("N must be a positive integer");if(g(r,4294967295))throw new Error("N must be less than or equal to 2^32-1, as that is the maximum length of an Array");const t=c(r,1);i=[];for(let e=0;u(e,r);e++){const r=s(e+1,t);i.push(b(a,r,n))}return E(r)?i:o(i)}}function x(e,t,r){const n=e.valueOf(),i=t.valueOf(),a=[];for(let e=0;e<i.length;++e)a.push(b(n,i[e],r));return a}function b(e,t,r){var n=A(e),e=n.length;if(0===e)throw new Error("Cannot calculate quantile of an empty sequence");const i=E(t)?t*(e-1):t.times(e-1),a=E(t)?Math.floor(i):i.floor().toNumber(),o=E(t)?i%1:i.minus(a);if(h(i))return r?n[i]:p(n,E(t)?i:i.valueOf());let s,u;if(r)s=n[a],u=n[a+1];else{u=p(n,a+1),s=n[a];for(let e=0;e<a;++e)0<m(n[e],s)&&(s=n[e])}return c(f(s,l(1,o)),f(u,o))}}),Sp=s("std",["typed","map","sqrt","variance"],e=>{let{typed:t,map:r,sqrt:n,variance:i}=e;return t("std",{"Array | Matrix":a,"Array | Matrix, string":a,"Array | Matrix, number | BigNumber":a,"Array | Matrix, number | BigNumber, string":a,"...":function(e){return a(e)}});function a(e,t){if(0===e.length)throw new SyntaxError("Function std requires one or more parameters (0 provided)");try{const e=i.apply(null,arguments);return q(e)?r(e,n):n(e)}catch(e){throw e instanceof TypeError&&e.message.includes(" variance")?new TypeError(e.message.replace(" variance"," std")):e}}}),Mp=s("corr",["typed","matrix","mean","sqrt","sum","add","subtract","multiply","pow","divide"],e=>{let{typed:t,matrix:r,sqrt:s,sum:u,add:c,subtract:l,multiply:f,pow:p,divide:m}=e;return t("corr",{"Array, Array":n,"Matrix, Matrix":function(e,t){e=n(e.toArray(),t.toArray());return Array.isArray(e)?r(e):e}});function n(t,r){const n=[];if(Array.isArray(t[0])&&Array.isArray(r[0])){if(t.length!==r.length)throw new SyntaxError("Dimension mismatch. Array A and B must have the same length.");for(let e=0;e<t.length;e++){if(t[e].length!==r[e].length)throw new SyntaxError("Dimension mismatch. Array A and B must have the same number of elements.");n.push(i(t[e],r[e]))}return n}if(t.length!==r.length)throw new SyntaxError("Dimension mismatch. Array A and B must have the same number of elements.");return i(t,r)}function i(e,n){var t=e.length,r=u(e),i=u(n),a=e.reduce((e,t,r)=>c(e,f(t,n[r])),0),e=u(e.map(e=>p(e,2))),o=u(n.map(e=>p(e,2))),a=l(f(t,a),f(r,i)),e=s(f(l(f(t,e),p(r,2)),l(f(t,o),p(i,2))));return m(a,e)}});function Cp(e,t){if(t<e)return 1;if(t===e)return t;var r=t+e>>1;return Cp(e,r)*Cp(1+r,t)}function Tp(t,r){if(!v(t)||t<0)throw new TypeError("Positive integer value expected in function combinations");if(!v(r)||r<0)throw new TypeError("Positive integer value expected in function combinations");if(t<r)throw new TypeError("k must be less than or equal to n");var n=t-r;let i=1,a=2;var o=r<n?r:n;for(let e=r<n?1+n:r+1;e<=t;++e)for(i*=e;a<=o&&i%a==0;)i/=a,++a;return a<=o&&(i/=Cp(a,o)),i}Tp.signature="number, number";const Dp="combinations",Fp=s(Dp,["typed"],e=>{let t=e["typed"];return t(Dp,{"number, number":Tp,"BigNumber, BigNumber":function(e,t){const r=e.constructor;let n,i;const a=e.minus(t),o=new r(1);if(!Bp(e)||!Bp(t))throw new TypeError("Positive integer value expected in function combinations");if(t.gt(e))throw new TypeError("k must be less than n in function combinations");if(n=o,t.lt(a))for(i=o;i.lte(a);i=i.plus(o))n=n.times(t.plus(i)).dividedBy(i);else for(i=o;i.lte(t);i=i.plus(o))n=n.times(a.plus(i)).dividedBy(i);return n}})});function Bp(e){return e.isInteger()&&e.gte(0)}const Op="combinationsWithRep",_p=s(Op,["typed"],e=>{let t=e["typed"];return t(Op,{"number, number":function(e,t){if(!v(e)||e<0)throw new TypeError("Positive integer value expected in function combinationsWithRep");if(!v(t)||t<0)throw new TypeError("Positive integer value expected in function combinationsWithRep");if(e<1)throw new TypeError("k must be less than or equal to n + k - 1");return t<e-1?Cp(e,e+t-1)/Cp(1,t):Cp(t+1,e+t-1)/Cp(1,e-1)},"BigNumber, BigNumber":function(e,t){let r,n;const i=new e.constructor(1),a=e.minus(i);if(!zp(e)||!zp(t))throw new TypeError("Positive integer value expected in function combinationsWithRep");if(e.lt(i))throw new TypeError("k must be less than or equal to n + k - 1 in function combinationsWithRep");if(r=i,t.lt(a))for(n=i;n.lte(a);n=n.plus(i))r=r.times(t.plus(n)).dividedBy(n);else for(n=i;n.lte(t);n=n.plus(i))r=r.times(a.plus(n)).dividedBy(n);return r}})});function zp(e){return e.isInteger()&&e.gte(0)}function Ip(t){let r;if(v(t))return t<=0?isFinite(t)?1/0:NaN:171<t?1/0:Cp(1,t-1);if(t<.5)return Math.PI/(Math.sin(Math.PI*t)*Ip(1-t));if(171.35<=t)return 1/0;if(85<t){const r=t*t,e=r*t,n=e*t,i=n*t;return Math.sqrt(2*Math.PI/t)*Math.pow(t/Math.E,t)*(1+1/(12*t)+1/(288*r)-139/(51840*e)-571/(2488320*n)+163879/(209018880*i)+5246819/(75246796800*i*t))}--t,r=qp[0];for(let e=1;e<qp.length;++e)r+=qp[e]/(t+e);const e=t+kp+.5;return Math.sqrt(2*Math.PI)*Math.pow(e,t+.5)*Math.exp(-e)*r}const kp=4.7421875,qp=[.9999999999999971,57.15623566586292,-59.59796035547549,14.136097974741746,-.4919138160976202,3399464998481189e-20,4652362892704858e-20,-9837447530487956e-20,.0001580887032249125,-.00021026444172410488,.00021743961811521265,-.0001643181065367639,8441822398385275e-20,-26190838401581408e-21,36899182659531625e-22],Rp=.9189385332046728,Pp=[1.000000000190015,76.18009172947146,-86.50532032941678,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18];function jp(t){if(t<0)return NaN;if(0===t)return 1/0;if(!isFinite(t))return t;if(t<.5)return Math.log(Math.PI/Math.sin(Math.PI*t))-jp(1-t);var e=5+--t+.5;let r=Pp[0];for(let e=6;1<=e;e--)r+=Pp[e]/(t+e);return Rp+(t+.5)*Math.log(e)-e+Math.log(r)}jp.signature=Ip.signature="number";const Up=s("gamma",["typed","config","multiplyScalar","pow","BigNumber","Complex"],e=>{let{typed:t,config:s,BigNumber:u,Complex:c}=e;return t("gamma",{number:Ip,Complex:function e(t){if(0===t.im)return Ip(t.re);if(t.re<.5){const r=new c(1-t.re,-t.im),n=new c(Math.PI*t.re,Math.PI*t.im);return new c(Math.PI).div(n.sin()).div(e(r))}t=new c(t.re-1,t.im);let r=new c(qp[0],0);for(let e=1;e<qp.length;++e){const n=new c(qp[e],0);r=r.add(n.div(t.add(e)))}const n=new c(t.re+kp+.5,t.im),i=Math.sqrt(2*Math.PI),a=n.pow(t.add(.5)),o=n.neg().exp();return r.mul(i).mul(a).mul(o)},BigNumber:function(e){if(e.isInteger())return e.isNegative()||e.isZero()?new u(1/0):function e(t){if(t<8)return new u([1,1,2,6,24,120,720,5040][t]);const r=s.precision+(0|Math.log(t.toNumber())),n=u.clone({precision:r});if(t%2==1)return t.times(e(new u(t-1)));let i=t,a=new n(t),o=t.toNumber();for(;2<i;)i-=2,o+=i,a=a.times(o);return new u(a.toPrecision(u.precision))}(e.minus(1));if(e.isFinite())throw new Error("Integer BigNumber expected");return new u(e.isNegative()?NaN:1/0)}})}),Lp=s("lgamma",["Complex","typed"],e=>{let{Complex:u,typed:t}=e;const c=[-.029550653594771242,.00641025641025641,-.0019175269175269176,.0008417508417508417,-.0005952380952380953,.0007936507936507937,-.002777777777777778,.08333333333333333];return t("lgamma",{number:jp,Complex:function e(t){if(t.isNaN())return new u(NaN,NaN);if(0===t.im)return new u(jp(t.re),0);if(7<=t.re||7<=Math.abs(t.im))return a(t);if(t.re<=.1){r=6.283185307179586;const a=(!0^(0<(n=t.im)||!(n<0)&&1/n==1/0)?-r:r)*Math.floor(.5*t.re+.25),o=t.mul(Math.PI).sin().log(),i=e(new u(1-t.re,-t.im));return new u(1.1447298858494002,a).sub(o).sub(i)}return 0<=t.im?o(t):o(t.conjugate()).conjugate();var r,n},BigNumber:function(){throw new Error("mathjs doesn't yet provide an implementation of the algorithm lgamma for BigNumber")}});function a(e){const t=e.sub(.5).mul(e.log()).sub(e).add(Rp),r=new u(1,0).div(e),n=r.div(e);let i=c[0],a=c[1];var o=2*n.re,s=n.re*n.re+n.im*n.im;for(let e=2;e<8;e++){const u=a;a=-s*i+c[e],i=o*i+u}e=r.mul(n.mul(i).add(a));return t.add(e)}function o(e){let t=0,r=0,n=e;for(e=e.add(1);e.re<=7;){const u=(n=n.mul(e)).im<0?1:0;0!=u&&0===r&&t++,r=u,e=e.add(1)}return a(e).sub(n.log()).sub(new u(0,2*t*Math.PI*1))}}),$p="factorial",Hp=s($p,["typed","gamma"],e=>{let{typed:t,gamma:r}=e;return t($p,{number:function(e){if(e<0)throw new Error("Value must be non-negative");return r(e+1)},BigNumber:function(e){if(e.isNegative())throw new Error("Value must be non-negative");return r(e.plus(1))},"Array | Matrix":t.referToSelf(t=>e=>ce(e,t))})}),Gp="kldivergence",Zp=s(Gp,["typed","matrix","divide","sum","multiply","map","dotDivide","log","isNumeric"],e=>{let{typed:t,matrix:r,divide:i,sum:a,multiply:o,map:s,dotDivide:u,log:c,isNumeric:l}=e;return t(Gp,{"Array, Array":function(e,t){return n(r(e),r(t))},"Matrix, Array":function(e,t){return n(e,r(t))},"Array, Matrix":function(e,t){return n(r(e),t)},"Matrix, Matrix":n});function n(e,t){var r=t.size().length,n=e.size().length;if(1<r)throw new Error("first object must be one dimensional");if(1<n)throw new Error("second object must be one dimensional");if(r!==n)throw new Error("Length of two vectors must be equal");if(0===a(e))throw new Error("Sum of elements in first object must be non zero");if(0===a(t))throw new Error("Sum of elements in second object must be non zero");r=i(e,a(e)),n=i(t,a(t)),e=a(o(r,s(u(r,n),e=>c(e))));return l(e)?e:Number.NaN}}),Vp="multinomial",Wp=s(Vp,["typed","add","divide","multiply","factorial","isInteger","isPositive"],e=>{let{typed:t,add:n,divide:i,multiply:a,factorial:o,isInteger:s,isPositive:u}=e;return t(Vp,{"Array | Matrix":function(e){let t=0,r=1;return Ln(e,function(e){if(!s(e)||!u(e))throw new TypeError("Positive integer value expected in function multinomial");t=n(t,e),r=a(r,o(e))}),i(o(t),r)}})}),Yp="permutations",Jp=s(Yp,["typed","factorial"],e=>{let{typed:t,factorial:r}=e;return t(Yp,{"number | BigNumber":r,"number, number":function(e,t){if(!v(e)||e<0)throw new TypeError("Positive integer value expected in function permutations");if(!v(t)||t<0)throw new TypeError("Positive integer value expected in function permutations");if(e<t)throw new TypeError("second argument k must be less than or equal to first argument n");return Cp(e-t+1,e)},"BigNumber, BigNumber":function(e,t){let r,n;if(!Xp(e)||!Xp(t))throw new TypeError("Positive integer value expected in function permutations");if(t.gt(e))throw new TypeError("second argument k must be less than or equal to first argument n");for(r=e.mul(0).add(1),n=e.minus(t).plus(1);n.lte(e);n=n.plus(1))r=r.times(n);return r}})});function Xp(e){return e.isInteger()&&e.gte(0)}var Qp=kh(7391);const Kp=Qp(Date.now());function em(e){let t;return t=null===(e=e)?Kp:Qp(String(e)),function(){return t()}}const tm="pickRandom",rm=s(tm,["typed","config","?on"],e=>{let{typed:t,config:r,on:n}=e,l=em(r.randomSeed);return n&&n("config",function(e,t){e.randomSeed!==t.randomSeed&&(l=em(e.randomSeed))}),t(tm,{"Array | Matrix":function(e){return i(e,{})},"Array | Matrix, Object":i,"Array | Matrix, number":function(e,t){return i(e,{number:t})},"Array | Matrix, Array | Matrix":function(e,t){return i(e,{weights:t})},"Array | Matrix, Array | Matrix, number":function(e,t,r){return i(e,{number:r,weights:t})},"Array | Matrix, number, Array | Matrix":function(e,t,r){return i(e,{number:t,weights:r})}});function i(n,e){let{number:t,weights:i,elementWise:r=!0}=e;e=void 0===t;e&&(t=1);const a=_(n)?n.create:_(i)?i.create:null;n=n.valueOf(),i=i&&i.valueOf(),!0===r&&(n=A(n),i=A(i));let o=0;if(void 0!==i){if(i.length!==n.length)throw new Error("Weights must have the same length as possibles");for(let e=0,t=i.length;e<t;e++){if(!E(i[e])||i[e]<0)throw new Error("Weights must be an array of positive numbers");o+=i[e]}}const s=n.length,u=[];let c;for(;u.length<t;){if(void 0===i)c=n[Math.floor(l()*s)];else{let r=l()*o;for(let e=0,t=n.length;e<t;e++)if((r-=i[e])<0){c=n[e];break}}u.push(c)}return e?u[0]:a?a(u):u}});function nm(r,n){const i=[];if(1<(r=r.slice(0)).length)for(let e=0,t=r.shift();e<t;e++)i.push(nm(r,n));else for(let e=0,t=r.shift();e<t;e++)i.push(n());return i}const im=s("random",["typed","config","?on"],e=>{let{typed:t,config:r,on:n}=e,i=em(r.randomSeed);return n&&n("config",function(e,t){e.randomSeed!==t.randomSeed&&(i=em(e.randomSeed))}),t("random",{"":()=>o(0,1),number:e=>o(0,e),"number, number":(e,t)=>o(e,t),"Array | Matrix":e=>a(e,0,1),"Array | Matrix, number":(e,t)=>a(e,0,t),"Array | Matrix, number, number":(e,t,r)=>a(e,t,r)});function a(e,t,r){var n=nm(e.valueOf(),()=>o(t,r));return _(e)?e.create(n):n}function o(e,t){return e+i()*(t-e)}}),am="randomInt",om=s(am,["typed","config","?on"],e=>{let{typed:t,config:r,on:n}=e,i=em(r.randomSeed);return n&&n("config",function(e,t){e.randomSeed!==t.randomSeed&&(i=em(e.randomSeed))}),t(am,{"":()=>o(0,1),number:e=>o(0,e),"number, number":(e,t)=>o(e,t),"Array | Matrix":e=>a(e,0,1),"Array | Matrix, number":(e,t)=>a(e,0,t),"Array | Matrix, number, number":(e,t,r)=>a(e,t,r)});function a(e,t,r){var n=nm(e.valueOf(),()=>o(t,r));return _(e)?e.create(n):n}function o(e,t){return Math.floor(e+i()*(t-e))}}),sm="stirlingS2",um=s(sm,["typed","addScalar","subtractScalar","multiplyScalar","divideScalar","pow","factorial","combinations","isNegative","isInteger","number","?bignumber","larger"],e=>{let{typed:t,addScalar:s,multiplyScalar:u,isNegative:c,isInteger:l,number:f,bignumber:p,larger:m}=e;const h=[],d=[];return t(sm,{"number | BigNumber, number | BigNumber":function(e,r){if(!l(e)||c(e)||!l(r)||c(r))throw new TypeError("Non-negative integer value expected in function stirlingS2");if(m(r,e))throw new TypeError("k must be less than or equal to n in function stirlingS2");const t=!(E(e)&&E(r)),n=t?d:h,i=t?p:f,a=f(e),o=f(r);if(n[a]&&n[a].length>o)return n[a][o];for(let t=0;t<=a;++t)if(n[t]||(n[t]=[i(0===t?1:0)]),0!==t){const E=n[t],r=n[t-1];for(let e=E.length;e<=t&&e<=o;++e)E[e]=e===t?1:s(u(i(e),r[e]),r[e-1])}return n[a][o]}})}),cm="bellNumbers",lm=s(cm,["typed","addScalar","isNegative","isInteger","stirlingS2"],e=>{let{typed:t,addScalar:n,isNegative:i,isInteger:a,stirlingS2:o}=e;return t(cm,{"number | BigNumber":function(t){if(!a(t)||i(t))throw new TypeError("Non-negative integer value expected in function bellNumbers");let r=0;for(let e=0;e<=t;e++)r=n(r,o(t,e));return r}})}),fm="catalan",pm=s(fm,["typed","addScalar","divideScalar","multiplyScalar","combinations","isNegative","isInteger"],e=>{let{typed:t,addScalar:r,divideScalar:n,multiplyScalar:i,combinations:a,isNegative:o,isInteger:s}=e;return t(fm,{"number | BigNumber":function(e){if(!s(e)||o(e))throw new TypeError("Non-negative integer value expected in function catalan");return n(a(i(e,2),e),r(e,1))}})}),mm="composition",hm=s(mm,["typed","addScalar","combinations","isNegative","isPositive","isInteger","larger"],e=>{let{typed:t,addScalar:r,combinations:n,isPositive:i,isInteger:a,larger:o}=e;return t(mm,{"number | BigNumber, number | BigNumber":function(e,t){if(!(a(e)&&i(e)&&a(t)&&i(t)))throw new TypeError("Positive integer value expected in function composition");if(o(t,e))throw new TypeError("k must be less than or equal to n in function composition");return n(r(e,-1),r(t,-1))}})}),dm="leafCount",gm=s(dm,["parse","typed"],e=>{let t=e["typed"];return t(dm,{Node:function t(e){let r=0;return e.forEach(e=>{r+=t(e)}),r||1}})});function ym(e){return ae(e)||oe(e)&&e.isUnary()&&ae(e.args[0])}function xm(e){return!!ae(e)||!(!me(e)&&!oe(e)||!e.args.every(xm))||!(!ge(e)||!xm(e.content))}const bm=s("simplifyUtil",["FunctionNode","OperatorNode","SymbolNode"],e=>{let{FunctionNode:r,OperatorNode:n,SymbolNode:i}=e;const a="defaultF",o={add:{trivial:!0,total:!0,commutative:!0,associative:!0},unaryPlus:{trivial:!0,total:!0,commutative:!0,associative:!0},subtract:{trivial:!1,total:!0,commutative:!1,associative:!1},multiply:{trivial:!0,total:!0,commutative:!0,associative:!0},divide:{trivial:!1,total:!0,commutative:!1,associative:!1},paren:{trivial:!0,total:!0,commutative:!0,associative:!1},defaultF:{trivial:!1,total:!0,commutative:!1,associative:!1}};function t(e,t){let r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:o,n=a;if("string"==typeof e?n=e:oe(e)?n=e.fn.toString():me(e)?n=e.name:ge(e)&&(n="paren"),ue(r,n)){const e=r[n];if(ue(e,t))return e[t];if(ue(o,n))return o[n][t]}if(ue(r,a)){const e=r[a];return(ue(e,t)?e:o[a])[t]}if(ue(o,n)){const e=o[n];if(ue(e,t))return e[t]}return o[a][t]}function s(e){return t(e,"associative",1<arguments.length&&void 0!==arguments[1]?arguments[1]:o)}function u(e,t){let n;function i(t){for(let e=0;e<t.args.length;e++){var r=t.args[e];oe(r)&&n===r.op?i(r):a.push(r)}}const a=[];return s(e,t)?(n=e.op,i(e),a):e.args}function c(t){return oe(t)?function(e){try{return new n(t.op,t.fn,e,t.implicit)}catch(e){return console.error(e),[]}}:function(e){return new r(new i(t.name),e)}}return{createMakeNodeFunction:c,hasProperty:t,isCommutative:function(e){return t(e,"commutative",1<arguments.length&&void 0!==arguments[1]?arguments[1]:o)},isAssociative:s,mergeContext:function(e,t){const r={...e};for(const n in t)ue(e,n)?r[n]={...t[n],...e[n]}:r[n]=t[n];return r},flatten:function t(r,n){if(!r.args||0===r.args.length)return r;r.args=u(r,n);for(let e=0;e<r.args.length;e++)t(r.args[e],n)},allChildren:u,unflattenr:function t(r,n){if(r.args&&0!==r.args.length){const i=c(r),a=r.args.length;for(let e=0;e<a;e++)t(r.args[e],n);if(2<a&&s(r,n)){let e=r.args.pop();for(;0<r.args.length;)e=i([r.args.pop(),e]);r.args=e.args}}},unflattenl:function t(r,n){if(r.args&&0!==r.args.length){const i=c(r),a=r.args.length;for(let e=0;e<a;e++)t(r.args[e],n);if(2<a&&s(r,n)){let e=r.args.shift();for(;0<r.args.length;)e=i([e,r.args.shift()]);r.args=e.args}}},defaultContext:o,realContext:{divide:{total:!1},log:{total:!1}},positiveContext:{subtract:{total:!1},abs:{trivial:!0},log:{total:!0}}}}),vm=s("simplify",["config","typed","parse","add","subtract","multiply","divide","pow","isZero","equal","resolve","simplifyConstant","simplifyCore","?fraction","?bignumber","mathWithTransform","matrix","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","SymbolNode"],e=>{let{typed:t,parse:c,equal:u,resolve:r,simplifyConstant:n,simplifyCore:i,AccessorNode:s,ArrayNode:l,ConstantNode:f,FunctionNode:p,IndexNode:m,ObjectNode:h,OperatorNode:d,ParenthesisNode:g,SymbolNode:y}=e;const{hasProperty:x,isCommutative:b,isAssociative:v,mergeContext:w,flatten:N,unflattenr:E,unflattenl:A,createMakeNodeFunction:S,defaultContext:a,realContext:o,positiveContext:M}=bm({FunctionNode:p,OperatorNode:d,SymbolNode:y}),C=(t.addConversion({from:"Object",to:"Map",convert:nt}),t("simplify",{Node:O,"Node, Map":(e,t)=>O(e,!1,t),"Node, Map, Object":(e,t,r)=>O(e,!1,t,r),"Node, Array":O,"Node, Array, Map":O,"Node, Array, Map, Object":O}));function T(e){return e.transform(function(e,t,r){return ge(e)?T(e.content):e})}t.removeConversion({from:"Object",to:"Map",convert:nt}),C.defaultContext=a,C.realContext=o,C.positiveContext=M;const D={true:!0,false:!0,e:!0,i:!0,Infinity:!0,LN2:!0,LN10:!0,LOG2E:!0,LOG10E:!0,NaN:!0,phi:!0,pi:!0,SQRT1_2:!0,SQRT2:!0,tau:!0};C.rules=[i,{l:"log(e)",r:"1"},{s:"n-n1 -> n+-n1",assuming:{subtract:{total:!0}}},{s:"n-n -> 0",assuming:{subtract:{total:!1}}},{s:"-(cl*v) -> v * (-cl)",assuming:{multiply:{commutative:!0},subtract:{total:!0}}},{s:"-(cl*v) -> (-cl) * v",assuming:{multiply:{commutative:!1},subtract:{total:!0}}},{s:"-(v*cl) -> v * (-cl)",assuming:{multiply:{commutative:!1},subtract:{total:!0}}},{l:"-(n1/n2)",r:"-n1/n2"},{l:"-v",r:"v * (-1)"},{l:"(n1 + n2)*(-1)",r:"n1*(-1) + n2*(-1)",repeat:!0},{l:"n/n1^n2",r:"n*n1^-n2"},{l:"n/n1",r:"n*n1^-1"},{s:"(n1*n2)^n3 -> n1^n3 * n2^n3",assuming:{multiply:{commutative:!0}}},{s:"(n1*n2)^(-1) -> n2^(-1) * n1^(-1)",assuming:{multiply:{commutative:!1}}},{s:"(n ^ n1) ^ n2 -> n ^ (n1 * n2)",assuming:{divide:{total:!0}}},{l:" vd   * ( vd   * n1 + n2)",r:"vd^2       * n1 +  vd   * n2"},{s:" vd   * (vd^n4 * n1 + n2)   ->  vd^(1+n4)  * n1 +  vd   * n2",assuming:{divide:{total:!0}}},{s:"vd^n3 * ( vd   * n1 + n2)   ->  vd^(n3+1)  * n1 + vd^n3 * n2",assuming:{divide:{total:!0}}},{s:"vd^n3 * (vd^n4 * n1 + n2)   ->  vd^(n3+n4) * n1 + vd^n3 * n2",assuming:{divide:{total:!0}}},{l:"n*n",r:"n^2"},{s:"n * n^n1 -> n^(n1+1)",assuming:{divide:{total:!0}}},{s:"n^n1 * n^n2 -> n^(n1+n2)",assuming:{divide:{total:!0}}},n,{s:"n+n -> 2*n",assuming:{add:{total:!0}}},{l:"n+-n",r:"0"},{l:"vd*n + vd",r:"vd*(n+1)"},{l:"n3*n1 + n3*n2",r:"n3*(n1+n2)"},{l:"n3^(-n4)*n1 +   n3  * n2",r:"n3^(-n4)*(n1 + n3^(n4+1) *n2)"},{l:"n3^(-n4)*n1 + n3^n5 * n2",r:"n3^(-n4)*(n1 + n3^(n4+n5)*n2)"},{s:"n*vd + vd -> (n+1)*vd",assuming:{multiply:{commutative:!1}}},{s:"vd + n*vd -> (1+n)*vd",assuming:{multiply:{commutative:!1}}},{s:"n1*n3 + n2*n3 -> (n1+n2)*n3",assuming:{multiply:{commutative:!1}}},{s:"n^n1 * n -> n^(n1+1)",assuming:{divide:{total:!0},multiply:{commutative:!1}}},{s:"n1*n3^(-n4) + n2 * n3    -> (n1 + n2*n3^(n4 +  1))*n3^(-n4)",assuming:{multiply:{commutative:!1}}},{s:"n1*n3^(-n4) + n2 * n3^n5 -> (n1 + n2*n3^(n4 + n5))*n3^(-n4)",assuming:{multiply:{commutative:!1}}},{l:"n*cd + cd",r:"(n+1)*cd"},{s:"cd*n + cd -> cd*(n+1)",assuming:{multiply:{commutative:!1}}},{s:"cd + cd*n -> cd*(1+n)",assuming:{multiply:{commutative:!1}}},n,{s:"(-n)*n1 -> -(n*n1)",assuming:{subtract:{total:!0}}},{s:"n1*(-n) -> -(n1*n)",assuming:{subtract:{total:!0},multiply:{commutative:!1}}},{s:"ce+ve -> ve+ce",assuming:{add:{commutative:!0}},imposeContext:{add:{commutative:!1}}},{s:"vd*cd -> cd*vd",assuming:{multiply:{commutative:!0}},imposeContext:{multiply:{commutative:!1}}},{l:"n+-n1",r:"n-n1"},{l:"n+-(n1)",r:"n-(n1)"},{s:"n*(n1^-1) -> n/n1",assuming:{multiply:{commutative:!0}}},{s:"n*n1^-n2 -> n/n1^n2",assuming:{multiply:{commutative:!0}}},{s:"n^-1 -> 1/n",assuming:{multiply:{commutative:!0}}},{l:"n^1",r:"n"},{s:"n*(n1/n2) -> (n*n1)/n2",assuming:{multiply:{associative:!0}}},{s:"n-(n1+n2) -> n-n1-n2",assuming:{addition:{associative:!0,commutative:!0}}},{l:"1*n",r:"n",imposeContext:{multiply:{commutative:!0}}},{s:"n1/(n2/n3) -> (n1*n3)/n2",assuming:{multiply:{associative:!0}}},{l:"n1/(-n2)",r:"-n1/n2"}];let F=0;function B(){return new y("_p"+F++)}function O(e,n){var t=2<arguments.length&&void 0!==arguments[2]?arguments[2]:rt(),i=3<arguments.length&&void 0!==arguments[3]?arguments[3]:{},a=i.consoleDebug;n=function(n,i){const a=[];for(let r=0;r<n.length;r++){let e,t=n[r];var o=typeof t;switch(o){case"string":t={s:t};case"object":e=function(t,r){const n={};if(t.s){const r=t.s.split("->");if(2!==r.length)throw SyntaxError("Could not parse rule: "+t.s);n.l=r[0],n.r=r[1]}else n.l=t.l,n.r=t.r;n.l=T(c(n.l)),n.r=T(c(n.r));for(const r of["imposeContext","repeat","assuming"])r in t&&(n[r]=t[r]);if(t.evaluate&&(n.evaluate=c(t.evaluate)),v(n.l,r)){const t=!b(n.l,r);let e;t&&(e=B());const i=S(n.l),a=B();n.expanded={},n.expanded.l=i([n.l,a]),N(n.expanded.l,r),E(n.expanded.l,r),n.expanded.r=i([n.r,a]),t&&(n.expandedNC1={},n.expandedNC1.l=i([e,n.l]),n.expandedNC1.r=i([e,n.r]),n.expandedNC2={},n.expandedNC2.l=i([e,n.expanded.l]),n.expandedNC2.r=i([e,n.expanded.r]))}return n}(t,i);break;case"function":e=t;break;default:throw TypeError("Unsupported type of rule: "+o)}a.push(e)}return a}(n||C.rules,i.context);let o=r(e,t);const s={};let u=(o=T(o)).toString({parenthesis:"all"});for(;!s[u];){s[u]=!0,F=0;let r=u;a&&console.log("Working on: ",u);for(let t=0;t<n.length;t++){let e="";if("function"==typeof n[t]?(o=n[t](o,i),a&&(e=n[t].name)):(N(o,i.context),o=z(o,n[t],i.context),a&&(e=n[t].l.toString()+" -> "+n[t].r.toString())),a){const n=o.toString({parenthesis:"all"});n!==r&&(console.log("Applying",e,"produced",n),r=n)}A(o,i.context)}u=o.toString({parenthesis:"all"})}return o}function _(t,r,n){let i=t;if(t)for(let e=0;e<t.length;++e){var a=z(t[e],r,n);a!==t[e]&&((i=i===t?t.slice():i)[e]=a)}return i}function z(e,r,n){if(r.assuming)for(const t in r.assuming)for(const i in r.assuming[t])if(x(t,i,n)!==r.assuming[t][i])return e;const t=w(r.imposeContext,n);let i=e;if(i instanceof d||i instanceof p){const e=_(i.args,r,n);e!==i.args&&((i=i.clone()).args=e)}else if(i instanceof g){if(i.content){const e=z(i.content,r,n);e!==i.content&&(i=new g(e))}}else if(i instanceof l){const e=_(i.items,r,n);e!==i.items&&(i=new l(e))}else if(i instanceof s){let e=i.object,t=(i.object&&(e=z(i.object,r,n)),i.index);i.index&&(t=z(i.index,r,n)),e===i.object&&t===i.index||(i=new s(e,t))}else if(i instanceof m){const e=_(i.dimensions,r,n);e!==i.dimensions&&(i=new m(e))}else if(i instanceof h){let e=!1;const t={};for(const a in i.properties)t[a]=z(i.properties[a],r,n),t[a]!==i.properties[a]&&(e=!0);e&&(i=new h(t))}let a=r.r,o=I(r.l,i,t)[0];if(!o&&r.expanded&&(a=r.expanded.r,o=I(r.expanded.l,i,t)[0]),!o&&r.expandedNC1&&(a=r.expandedNC1.r,(o=I(r.expandedNC1.l,i,t)[0])||(a=r.expandedNC2.r,o=I(r.expandedNC2.l,i,t)[0])),o){const e=i.implicit;i=a.clone(),e&&"implicit"in a&&(i.implicit=!0),i=i.transform(function(e){return e.isSymbolNode&&ue(o.placeholders,e.name)?o.placeholders[e.name].clone():e})}return i=r.repeat&&i!==e?z(i,r,n):i}function k(e,t){const r={placeholders:{}};if(!e.placeholders&&!t.placeholders)return r;if(!e.placeholders)return t;if(!t.placeholders)return e;for(const n in e.placeholders)if(ue(e.placeholders,n)&&(r.placeholders[n]=e.placeholders[n],ue(t.placeholders,n)&&!function t(r,n){if(r instanceof f&&n instanceof f){if(!u(r.value,n.value))return!1}else if(r instanceof y&&n instanceof y){if(r.name!==n.name)return!1}else{if(!(r instanceof d&&n instanceof d||r instanceof p&&n instanceof p))return!1;if(r instanceof d){if(r.op!==n.op||r.fn!==n.fn)return!1}else if(r instanceof p&&r.name!==n.name)return!1;if(r.args.length!==n.args.length)return!1;for(let e=0;e<r.args.length;e++)if(!t(r.args[e],n.args[e]))return!1}return!0}(e.placeholders[n],t.placeholders[n])))return null;for(const e in t.placeholders)ue(t.placeholders,e)&&(r.placeholders[e]=t.placeholders[e]);return r}function q(r,n){const i=[];if(0===r.length||0===n.length)return i;var a;for(let t=0;t<r.length;t++)for(let e=0;e<n.length;e++)(a=k(r[t],n[e]))&&i.push(a);return i}function I(r,n,i,a){let e=[{placeholders:{}}];if(r instanceof d&&n instanceof d||r instanceof p&&n instanceof p){if(r instanceof d){if(r.op!==n.op||r.fn!==n.fn)return[]}else if(r instanceof p&&r.name!==n.name)return[];if(!(1===n.args.length&&1===r.args.length||!v(n,i)&&n.args.length===r.args.length||a)){if(2<=n.args.length&&2===r.args.length){const a=function(r,e){const n=[];let i,a;const o=S(r);if(b(r,e))for(let e=0;e<r.args.length;e++)(a=r.args.slice(0)).splice(e,1),i=1===a.length?a[0]:o(a),n.push(o([r.args[e],i]));else for(let t=1;t<r.args.length;t++){let e=r.args[0];1<t&&(e=o(r.args.slice(0,t))),a=r.args.slice(t),i=1===a.length?a[0]:o(a),n.push(o([e,i]))}return n}(n,i);let t=[];for(let e=0;e<a.length;e++){var o=I(r,a[e],i,!0);t=t.concat(o)}return t}if(2<r.args.length)throw Error("Unexpected non-binary associative function: "+r.toString());return[]}{let t=[];for(let e=0;e<r.args.length;e++){var s=I(r.args[e],n.args[e],i);if(0===s.length)break;t.push(s)}if(t.length!==r.args.length){if(!b(n,i)||1===r.args.length)return[];if(2<r.args.length)throw new Error("permuting >2 commutative non-associative rule arguments not yet implemented");const e=I(r.args[0],n.args[1],i);if(0===e.length)return[];a=I(r.args[1],n.args[0],i);if(0===a.length)return[];t=[e,a]}e=function(e){if(0===e.length)return e;const t=e.reduce(q),r=[],n={};for(let e=0;e<t.length;e++){var i=JSON.stringify(t[e]);n[i]||(n[i]=!0,r.push(t[e]))}return r}(t)}}else if(r instanceof y){if(0===r.name.length)throw new Error("Symbol in rule has 0 length...!?");if(D[r.name]){if(r.name!==n.name)return[]}else switch("a"<=r.name[1]&&r.name[1]<="z"?r.name.substring(0,2):r.name[0]){case"n":case"_p":e[0].placeholders[r.name]=n;break;case"c":case"cl":if(!ae(n))return[];e[0].placeholders[r.name]=n;break;case"v":if(ae(n))return[];e[0].placeholders[r.name]=n;break;case"vl":if(!se(n))return[];e[0].placeholders[r.name]=n;break;case"cd":if(!ym(n))return[];e[0].placeholders[r.name]=n;break;case"vd":if(ym(n))return[];e[0].placeholders[r.name]=n;break;case"ce":if(!xm(n))return[];e[0].placeholders[r.name]=n;break;case"ve":if(xm(n))return[];e[0].placeholders[r.name]=n;break;default:throw new Error("Invalid symbol in rule: "+r.name)}}else{if(!(r instanceof f))return[];if(!u(r.value,n.value))return[]}return e}return C}),wm=s("simplifyConstant",["typed","config","mathWithTransform","matrix","?fraction","?bignumber","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","SymbolNode"],e=>{let{typed:t,config:n,mathWithTransform:h,matrix:d,fraction:i,bignumber:a,AccessorNode:g,ArrayNode:y,ConstantNode:x,FunctionNode:b,IndexNode:v,ObjectNode:w,OperatorNode:r,SymbolNode:o}=e;const{isCommutative:N,isAssociative:E,allChildren:A,createMakeNodeFunction:S}=bm({FunctionNode:b,OperatorNode:r,SymbolNode:o}),M=t("simplifyConstant",{Node:e=>T(B(e,{})),"Node, Object":function(e,t){return T(B(e,t))}});function s(e){return I(e)?e.valueOf():e instanceof Array?e.map(s):_(e)?d(s(e.valueOf())):e}function C(t,r,n){try{return h[t].apply(null,r)}catch(e){return r=r.map(s),D(h[t].apply(null,r),n)}}const u=t({Fraction:function(e){var t=e.s*e.n,t=t<0?new r("-","unaryMinus",[new x(-t)]):new x(t);return 1===e.d?t:new r("/","divide",[t,new x(e.d)])},number:function(e){return e<0?l(new x(-e)):new x(e)},BigNumber:function(e){return e<0?l(new x(-e)):new x(e)},bigint:function(e){return e<0n?l(new x(-e)):new x(e)},Complex:function(e){throw new Error("Cannot convert Complex number to Node")},string:function(e){return new x(e)},Matrix:function(e){return new y(e.valueOf().map(e=>u(e)))}});function T(e){return O(e)?e:u(e)}function c(e,t){if(t&&!1!==t.exactFractions&&isFinite(e)&&i){const r=i(e),n=t&&"number"==typeof t.fractionsLimit?t.fractionsLimit:1/0;if(r.valueOf()===e&&r.n<n&&r.d<n)return r}return e}const D=t({"string, Object":function(e,t){var r=we(e,n);return"BigNumber"===r?(void 0===a&&Qo(),a(e)):"bigint"===r?BigInt(e):"Fraction"===r?(void 0===i&&Ko(),i(e)):c(parseFloat(e),t)},"Fraction, Object":function(e,t){return e},"BigNumber, Object":function(e,t){return e},"number, Object":c,"bigint, Object":function(e,t){return e},"Complex, Object":function(e,t){return 0!==e.im?e:c(e.re,t)},"Matrix, Object":function(e,t){return d(c(e.valueOf()))},"Array, Object":function(e,t){return e.map(c)}});function l(e){return new r("-","unaryMinus",[e])}function F(r,e,n,i){var t=e.shift(),e=e.reduce((t,e)=>{if(!O(e)){const n=t.pop();if(O(n))return[n,e];try{return t.push(C(r,[n,e],i)),t}catch(e){t.push(n)}}t.push(T(t.pop()));t=1===t.length?t[0]:n(t);return[n([t,T(e)])]},[t]);return 1===e.length?e[0]:n([e[0],u(e[1])])}function B(r,n){switch(r.type){case"SymbolNode":return r;case"ConstantNode":switch(typeof r.value){case"number":case"bigint":return D(r.value,n);case"string":return r.value;default:if(!isNaN(r.value))return D(r.value,n)}return r;case"FunctionNode":if(h[r.name]&&h[r.name].rawArgs)return r;if(!["add","multiply"].includes(r.name)){const o=r.args.map(e=>B(e,n));if(!o.some(O))try{return C(r.name,o,n)}catch(r){}if("size"===r.name&&1===o.length&&X(o[0])){const r=[];let e=o[0];for(;X(e);)r.push(e.items.length),e=e.items[0];return d(r)}return new b(r.name,o.map(T))}case"OperatorNode":{var i=r.fn.toString();let t,e;const s=S(r);if(oe(r)&&r.isUnary())t=[B(r.args[0],n)],e=O(t[0])?s(t):C(i,t,n);else if(E(r,n.context))if(t=(t=A(r,n.context)).map(e=>B(e,n)),N(i,n.context)){const r=[],u=[];for(let e=0;e<t.length;e++)(O(t[e])?u:r).push(t[e]);e=1<r.length?(e=F(i,r,s,n),u.unshift(e),F(i,u,s,n)):F(i,t,s,n)}else e=F(i,t,s,n);else t=r.args.map(e=>B(e,n)),e=F(i,t,s,n);return e}case"ParenthesisNode":return B(r.content,n);case"AccessorNode":var e=B(r.object,n),t=B(r.index,n),a=n;if(!he(t))return new g(T(e),T(t));if(X(e)||_(e)){const c=Array.from(t.dimensions);for(;0<c.length;)if(ae(c[0])&&"string"!=typeof c[0].value){const t=D(c.shift().value,a);X(e)?e=e.items[t-1]:(e=e.valueOf()[t-1])instanceof Array&&(e=d(e))}else{if(!(1<c.length&&ae(c[1])&&"string"!=typeof c[1].value))break;{const t=D(c[1].value,a),l=[],f=X(e)?e.items:e.valueOf();for(const a of f)if(X(a))l.push(a.items[t-1]);else{if(!_(e))break;l.push(a[t-1])}if(l.length!==f.length)break;e=X(e)?new y(l):d(l),c.splice(1,1)}}return c.length===t.dimensions.length?new g(T(e),t):0<c.length?(t=new v(c),new g(T(e),t)):e}if(de(e)&&1===t.dimensions.length&&ae(t.dimensions[0])){const a=t.dimensions[0].value;return a in e.properties?e.properties[a]:new x}return new g(T(e),t);case"ArrayNode":{const p=r.items.map(e=>B(e,n));return p.some(O)?new y(p.map(T)):d(p)}case"IndexNode":return new v(r.dimensions.map(e=>M(e,n)));case"ObjectNode":{const m={};for(const h in r.properties)m[h]=M(r.properties[h],n);return new w(m)}default:throw new Error("Unimplemented node type in simplifyConstant: "+r.type)}}return M}),Nm="simplifyCore",Em=s(Nm,["typed","parse","equal","isZero","add","subtract","multiply","divide","pow","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","ParenthesisNode","SymbolNode"],e=>{let{typed:t,equal:a,isZero:o,AccessorNode:s,ArrayNode:u,ConstantNode:r,FunctionNode:c,IndexNode:l,ObjectNode:f,OperatorNode:p,SymbolNode:n}=e;const m=new r(0),h=new r(1),d=new r(!0),g=new r(!1);function y(e){return oe(e)&&["and","not","or"].includes(e.op)}const{hasProperty:x,isCommutative:b}=bm({FunctionNode:c,OperatorNode:p,SymbolNode:n});function v(n){let i=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};const t=i?i.context:void 0;if(x(n,"trivial",t)){if(me(n)&&1===n.args.length)return v(n.args[0],i);let t=!1,r=0;if(n.forEach(e=>{1===++r&&(t=v(e,i))}),1===r)return t}let r=n;if(me(r)){const n=function(e){var t="OperatorNode:"+e;for(const e of Ul)if(t in e)return e[t].op;return null}(r.name);if(!n)return new c(v(r.fn),r.args.map(e=>v(e,i)));if(2<r.args.length&&x(r,"associative",t))for(;2<r.args.length;){const i=r.args.pop(),t=r.args.pop();r.args.push(new p(n,r.name,[i,t]))}r=new p(n,r.name,r.args)}if(oe(r)&&r.isUnary()){const n=v(r.args[0],i);if("~"===r.op&&oe(n)&&n.isUnary()&&"~"===n.op)return n.args[0];if("not"===r.op&&oe(n)&&n.isUnary()&&"not"===n.op&&y(n.args[0]))return n.args[0];let e=!0;if("-"===r.op&&oe(n)&&(n.isBinary()&&"subtract"===n.fn&&(r=new p("-","subtract",[n.args[1],n.args[0]]),e=!1),n.isUnary()&&"-"===n.op))return n.args[0];if(e)return new p(r.op,r.fn,[n])}if(oe(r)&&r.isBinary()){const n=v(r.args[0],i);let e=v(r.args[1],i);if("+"===r.op){if(ae(n)&&o(n.value))return e;if(ae(e)&&o(e.value))return n;oe(e)&&e.isUnary()&&"-"===e.op&&(e=e.args[0],r=new p("-","subtract",[n,e]))}if("-"===r.op)return oe(e)&&e.isUnary()&&"-"===e.op?v(new p("+","add",[n,e.args[0]]),i):ae(n)&&o(n.value)?v(new p("-","unaryMinus",[e])):ae(e)&&o(e.value)?n:new p(r.op,r.fn,[n,e]);if("*"===r.op){if(ae(n)){if(o(n.value))return m;if(a(n.value,1))return e}if(ae(e)){if(o(e.value))return m;if(a(e.value,1))return n;if(b(r,t))return new p(r.op,r.fn,[e,n],r.implicit)}return new p(r.op,r.fn,[n,e],r.implicit)}if("/"===r.op)return ae(n)&&o(n.value)?m:ae(e)&&a(e.value,1)?n:new p(r.op,r.fn,[n,e]);if("^"===r.op&&ae(e)){if(o(e.value))return h;if(a(e.value,1))return n}if("and"===r.op){if(ae(n)){if(!n.value)return g;if(y(e))return e;if(ae(e))return e.value?d:g}if(ae(e)){if(!e.value)return g;if(y(n))return n}}if("or"===r.op){if(ae(n)){if(n.value)return d;if(y(e))return e}if(ae(e)){if(e.value)return d;if(y(n))return n}}return new p(r.op,r.fn,[n,e])}if(oe(r))return new p(r.op,r.fn,r.args.map(e=>v(e,i)));if(X(r))return new u(r.items.map(e=>v(e,i)));if(le(r))return new s(v(r.object,i),v(r.index,i));if(he(r))return new l(r.dimensions.map(e=>v(e,i)));if(de(r)){const n={};for(const t in r.properties)n[t]=v(r.properties[t],i);return new f(n)}return r}return t(Nm,{Node:v,"Node,Object":v})}),Am=s("resolve",["typed","parse","ConstantNode","FunctionNode","OperatorNode","ParenthesisNode"],e=>{let{typed:t,parse:n,ConstantNode:i,FunctionNode:a,OperatorNode:o,ParenthesisNode:s}=e;function u(e,t){let r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:new Set;if(!t)return e;if(se(e)){if(r.has(e.name)){const e=Array.from(r).join(", ");throw new ReferenceError(`recursive loop of variable definitions among {${e}}`)}const a=t.get(e.name);if(O(a)){const n=new Set(r);return n.add(e.name),u(a,t,n)}return"number"==typeof a?n(String(a)):void 0!==a?new i(a):e}if(oe(e)){const n=e.args.map(function(e){return u(e,t,r)});return new o(e.op,e.fn,n,e.implicit)}if(ge(e))return new s(u(e.content,t,r));if(me(e)){const n=e.args.map(function(e){return u(e,t,r)});return new a(e.name,n)}return e.map(e=>u(e,t,r))}return t("resolve",{Node:u,"Node, Map | null | undefined":u,"Node, Object":(e,t)=>u(e,nt(t)),"Array | Matrix":t.referToSelf(t=>e=>e.map(e=>t(e))),"Array | Matrix, null | undefined":t.referToSelf(t=>e=>e.map(e=>t(e))),"Array, Object":t.referTo("Array,Map",r=>(e,t)=>r(e,nt(t))),"Matrix, Object":t.referTo("Matrix,Map",r=>(e,t)=>r(e,nt(t))),"Array | Matrix, Map":t.referToSelf(r=>(e,t)=>e.map(e=>r(e,t)))})}),Sm="symbolicEqual",Mm=s(Sm,["parse","simplify","typed","OperatorNode"],e=>{let{simplify:n,typed:t,OperatorNode:i}=e;function r(e,t){var r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:{},e=new i("-","subtract",[e,t]),t=n(e,{},r);return ae(t)&&!t.value}return t(Sm,{"Node, Node":r,"Node, Node, Object":r})}),Cm="derivative",Tm=s(Cm,["typed","config","parse","simplify","equal","isZero","numeric","ConstantNode","FunctionNode","OperatorNode","ParenthesisNode","SymbolNode"],e=>{let{typed:t,config:r,parse:n,simplify:i,equal:c,isZero:l,numeric:a,ConstantNode:o,FunctionNode:f,OperatorNode:p,ParenthesisNode:s,SymbolNode:m}=e;function u(e,t){var r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:{simplify:!0},n={},t=(g(n,e,t.name),y(e,n));return r.simplify?i(t):t}t.addConversion({from:"identifier",to:"SymbolNode",convert:n});const h=t(Cm,{"Node, SymbolNode":u,"Node, SymbolNode, Object":u}),d=(t.removeConversion({from:"identifier",to:"SymbolNode",convert:n}),h._simplify=!0,h.toTex=function(e){return d.apply(null,e.args)},t("_derivTex",{"Node, SymbolNode":function(e,t){return ae(e)&&"string"===K(e.value)?d(n(e.value).toString(),t.toString(),1):d(e.toTex(),t.toString(),1)},"Node, ConstantNode":function(e,t){if("string"===K(t.value))return d(e,n(t.value));throw new Error("The second parameter to 'derivative' is a non-string constant")},"Node, SymbolNode, ConstantNode":function(e,t,r){return d(e.toString(),t.name,r.value)},"string, string, number":function(e,t,r){return(1===r?"{d\\over d"+t+"}":"{d^{"+r+"}\\over d"+t+"^{"+r+"}}")+`\\left[${e}\\right]`}})),g=t("constTag",{"Object, ConstantNode, string":function(e,t){return e[t]=!0},"Object, SymbolNode, string":function(e,t,r){return t.name!==r&&(e[t]=!0)},"Object, ParenthesisNode, string":function(e,t,r){return g(e,t.content,r)},"Object, FunctionAssignmentNode, string":function(e,t,r){return t.params.includes(r)?g(e,t.expr,r):e[t]=!0},"Object, FunctionNode | OperatorNode, string":function(r,n,i){if(0<n.args.length){let t=g(r,n.args[0],i);for(let e=1;e<n.args.length;++e)t=g(r,n.args[e],i)&&t;if(t)return r[n]=!0}return!1}}),y=t("_derivative",{"ConstantNode, Object":function(e){return x(0)},"SymbolNode, Object":function(e,t){return void 0!==t[e]?x(0):x(1)},"ParenthesisNode, Object":function(e,t){return new s(y(e.content,t))},"FunctionAssignmentNode, Object":function(e,t){return void 0!==t[e]?x(0):y(e.expr,t)},"FunctionNode, Object":function(e,t){if(void 0!==t[e])return x(0);const r=e.args[0];let n,i,a,o,s=!1,u=!1;switch(e.name){case"cbrt":s=!0,i=new p("*","multiply",[x(3),new p("^","pow",[r,new p("/","divide",[x(2),x(3)])])]);break;case"sqrt":case"nthRoot":if(1===e.args.length)s=!0,i=new p("*","multiply",[x(2),new f("sqrt",[r])]);else if(2===e.args.length)return t[n=new p("/","divide",[x(1),e.args[1]])]=t[e.args[1]],y(new p("^","pow",[r,n]),t);break;case"log10":n=x(10);case"log":if(n||1!==e.args.length){if(1===e.args.length&&n||2===e.args.length&&void 0!==t[e.args[1]])i=new p("*","multiply",[r.clone(),new f("log",[n||e.args[1]])]),s=!0;else if(2===e.args.length)return y(new p("/","divide",[new f("log",[r]),new f("log",[e.args[1]])]),t)}else i=r.clone(),s=!0;break;case"pow":if(2===e.args.length)return t[n]=t[e.args[1]],y(new p("^","pow",[r,e.args[1]]),t);break;case"exp":i=new f("exp",[r.clone()]);break;case"sin":i=new f("cos",[r.clone()]);break;case"cos":i=new p("-","unaryMinus",[new f("sin",[r.clone()])]);break;case"tan":i=new p("^","pow",[new f("sec",[r.clone()]),x(2)]);break;case"sec":i=new p("*","multiply",[e,new f("tan",[r.clone()])]);break;case"csc":u=!0,i=new p("*","multiply",[e,new f("cot",[r.clone()])]);break;case"cot":u=!0,i=new p("^","pow",[new f("csc",[r.clone()]),x(2)]);break;case"asin":s=!0,i=new f("sqrt",[new p("-","subtract",[x(1),new p("^","pow",[r.clone(),x(2)])])]);break;case"acos":s=!0,u=!0,i=new f("sqrt",[new p("-","subtract",[x(1),new p("^","pow",[r.clone(),x(2)])])]);break;case"atan":s=!0,i=new p("+","add",[new p("^","pow",[r.clone(),x(2)]),x(1)]);break;case"asec":s=!0,i=new p("*","multiply",[new f("abs",[r.clone()]),new f("sqrt",[new p("-","subtract",[new p("^","pow",[r.clone(),x(2)]),x(1)])])]);break;case"acsc":s=!0,u=!0,i=new p("*","multiply",[new f("abs",[r.clone()]),new f("sqrt",[new p("-","subtract",[new p("^","pow",[r.clone(),x(2)]),x(1)])])]);break;case"acot":s=!0,u=!0,i=new p("+","add",[new p("^","pow",[r.clone(),x(2)]),x(1)]);break;case"sinh":i=new f("cosh",[r.clone()]);break;case"cosh":i=new f("sinh",[r.clone()]);break;case"tanh":i=new p("^","pow",[new f("sech",[r.clone()]),x(2)]);break;case"sech":u=!0,i=new p("*","multiply",[e,new f("tanh",[r.clone()])]);break;case"csch":u=!0,i=new p("*","multiply",[e,new f("coth",[r.clone()])]);break;case"coth":u=!0,i=new p("^","pow",[new f("csch",[r.clone()]),x(2)]);break;case"asinh":s=!0,i=new f("sqrt",[new p("+","add",[new p("^","pow",[r.clone(),x(2)]),x(1)])]);break;case"acosh":s=!0,i=new f("sqrt",[new p("-","subtract",[new p("^","pow",[r.clone(),x(2)]),x(1)])]);break;case"atanh":s=!0,i=new p("-","subtract",[x(1),new p("^","pow",[r.clone(),x(2)])]);break;case"asech":s=!0,u=!0,i=new p("*","multiply",[r.clone(),new f("sqrt",[new p("-","subtract",[x(1),new p("^","pow",[r.clone(),x(2)])])])]);break;case"acsch":s=!0,u=!0,i=new p("*","multiply",[new f("abs",[r.clone()]),new f("sqrt",[new p("+","add",[new p("^","pow",[r.clone(),x(2)]),x(1)])])]);break;case"acoth":s=!0,u=!0,i=new p("-","subtract",[x(1),new p("^","pow",[r.clone(),x(2)])]);break;case"abs":i=new p("/","divide",[new f(new m("abs"),[r.clone()]),r.clone()]);break;default:throw new Error('Cannot process function "'+e.name+'" in derivative: the function is not supported, undefined, or the number of arguments passed to it are not supported')}o=s?(a="/","divide"):(a="*","multiply");let c=y(r,t);return u&&(c=new p("-","unaryMinus",[c])),new p(a,o,[c,i])},"OperatorNode, Object":function(e,r){if(void 0!==r[e])return x(0);if("+"===e.op)return new p(e.op,e.fn,e.args.map(function(e){return y(e,r)}));if("-"===e.op){if(e.isUnary())return new p(e.op,e.fn,[y(e.args[0],r)]);if(e.isBinary())return new p(e.op,e.fn,[y(e.args[0],r),y(e.args[1],r)])}if("*"===e.op){const t=e.args.filter(function(e){return void 0!==r[e]});if(0<t.length){const n=e.args.filter(function(e){return void 0===r[e]}),i=1===n.length?n[0]:new p("*","multiply",n),c=t.concat(y(i,r));return new p("*","multiply",c)}return new p("+","add",e.args.map(function(t){return new p("*","multiply",e.args.map(function(e){return e===t?y(e,r):e.clone()}))}))}if("/"===e.op&&e.isBinary()){const a=e.args[0],o=e.args[1];return void 0!==r[o]?new p("/","divide",[y(a,r),o]):void 0!==r[a]?new p("*","multiply",[new p("-","unaryMinus",[a]),new p("/","divide",[y(o,r),new p("^","pow",[o.clone(),x(2)])])]):new p("/","divide",[new p("-","subtract",[new p("*","multiply",[y(a,r),o.clone()]),new p("*","multiply",[a.clone(),y(o,r)])]),new p("^","pow",[o.clone(),x(2)])])}if("^"===e.op&&e.isBinary()){const s=e.args[0],u=e.args[1];if(void 0!==r[s])return ae(s)&&(l(s.value)||c(s.value,1))?x(0):new p("*","multiply",[e,new p("*","multiply",[new f("log",[s.clone()]),y(u.clone(),r)])]);if(void 0===r[u])return new p("*","multiply",[new p("^","pow",[s.clone(),u.clone()]),new p("+","add",[new p("*","multiply",[y(s,r),new p("/","divide",[u.clone(),s.clone()])]),new p("*","multiply",[y(u,r),new f("log",[s.clone()])])])]);{if(ae(u)){if(l(u.value))return x(0);if(c(u.value,1))return y(s,r)}const e=new p("^","pow",[s.clone(),new p("-","subtract",[u,x(1)])]);return new p("*","multiply",[u.clone(),new p("*","multiply",[y(s,r),e])])}}throw new Error('Cannot process operator "'+e.op+'" in derivative: the operator is not supported, undefined, or the number of arguments passed to it are not supported')}});function x(e,t){return new o(a(e,t||we(String(e),r)))}return h}),Dm="rationalize",Fm=s(Dm,["config","typed","equal","isZero","add","subtract","multiply","divide","pow","parse","simplifyConstant","simplifyCore","simplify","?bignumber","?fraction","mathWithTransform","matrix","AccessorNode","ArrayNode","ConstantNode","FunctionNode","IndexNode","ObjectNode","OperatorNode","SymbolNode","ParenthesisNode"],e=>{let{typed:t,simplifyConstant:c,simplifyCore:l,simplify:f,ConstantNode:p,OperatorNode:m,SymbolNode:h}=e;function r(a){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},t=2<arguments.length&&void 0!==arguments[2]&&arguments[2],o=function(){const e=[l,{l:"n+n",r:"2*n"},{l:"n+-n",r:"0"},c,{l:"n*(n1^-1)",r:"n/n1"},{l:"n*n1^-n2",r:"n/n1^n2"},{l:"n1^-1",r:"1/n1"},{l:"n*(n1/n2)",r:"(n*n1)/n2"},{l:"1*n",r:"n"}],t=[{l:"(-n1)/(-n2)",r:"n1/n2"},{l:"(-n1)*(-n2)",r:"n1*n2"},{l:"n1--n2",r:"n1+n2"},{l:"n1-n2",r:"n1+(-n2)"},{l:"(n1+n2)*n3",r:"(n1*n3 + n2*n3)"},{l:"n1*(n2+n3)",r:"(n1*n2+n1*n3)"},{l:"c1*n + c2*n",r:"(c1+c2)*n"},{l:"c1*n + n",r:"(c1+1)*n"},{l:"c1*n - c2*n",r:"(c1-c2)*n"},{l:"c1*n - n",r:"(c1-1)*n"},{l:"v/c",r:"(1/c)*v"},{l:"v/-c",r:"-(1/c)*v"},{l:"-v*-c",r:"c*v"},{l:"-v*c",r:"-c*v"},{l:"v*-c",r:"-c*v"},{l:"v*c",r:"c*v"},{l:"-(-n1*n2)",r:"(n1*n2)"},{l:"-(n1*n2)",r:"(-n1*n2)"},{l:"-(-n1+n2)",r:"(n1-n2)"},{l:"-(n1+n2)",r:"(-n1-n2)"},{l:"(n1^n2)^n3",r:"(n1^(n2*n3))"},{l:"-(-n1/n2)",r:"(n1/n2)"},{l:"-(n1/n2)",r:"(-n1/n2)"}],r=[{l:"(n1/(n2/n3))",r:"((n1*n3)/n2)"},{l:"(n1/n2/n3)",r:"(n1/(n2*n3))"}],n={};return n.firstRules=e.concat(t,r),n.distrDivRules=[{l:"(n1/n2 + n3/n4)",r:"((n1*n4 + n3*n2)/(n2*n4))"},{l:"(n1/n2 + n3)",r:"((n1 + n3*n2)/n2)"},{l:"(n1 + n2/n3)",r:"((n1*n3 + n2)/n3)"}],n.sucDivRules=r,n.firstRulesAgain=e.concat(t),n.finalRules=[l,{l:"n*-n",r:"-n^2"},{l:"n*n",r:"n^2"},c,{l:"n*-n^n1",r:"-n^(n1+1)"},{l:"n*n^n1",r:"n^(n1+1)"},{l:"n^n1*-n^n2",r:"-n^(n1+n2)"},{l:"n^n1*n^n2",r:"n^(n1+n2)"},{l:"n^n1*-n",r:"-n^(n1+1)"},{l:"n^n1*n",r:"n^(n1+1)"},{l:"n^n1/-n",r:"-n^(n1-1)"},{l:"n^n1/n",r:"n^(n1-1)"},{l:"n/-n^n1",r:"-n^(1-n1)"},{l:"n/n^n1",r:"n^(1-n1)"},{l:"n^n1/-n^n2",r:"n^(n1-n2)"},{l:"n^n1/n^n2",r:"n^(n1-n2)"},{l:"n1+(-n2*n3)",r:"n1-n2*n3"},{l:"v*(-c)",r:"-c*v"},{l:"n1+-n2",r:"n1-n2"},{l:"v*c",r:"c*v"},{l:"(n1^n2)^n3",r:"(n1^(n2*n3))"}],n}(),e=function(e,t,r){const n=[],i=f(e,r,t,{exactFractions:!1}),a="+-*/",o=(!function t(r){var e=r.type;if("FunctionNode"===e)throw new Error("There is an unsolved function call");if("OperatorNode"===e)if("^"===r.op){if("ConstantNode"!==r.args[1].type||!v(parseFloat(r.args[1].value)))throw new Error("There is a non-integer exponent");t(r.args[0])}else{if(!a.includes(r.op))throw new Error("Operator "+r.op+" invalid in polynomial expression");for(let e=0;e<r.args.length;e++)t(r.args[e])}else if("SymbolNode"===e){const t=r.name;-1===n.indexOf(t)&&n.push(t)}else if("ParenthesisNode"===e)t(r.content);else if("ConstantNode"!==e)throw new Error("type "+e+" is not allowed in polynomial expression")}(i),{});return o.expression=i,o.variables=n,o}(a,e,o.firstRules),r=e.variables.length,s={exactFractions:!1},u={exactFractions:!0};if(a=e.expression,1<=r){let e,t;a=function t(r,n,i){const e=r.type,a=1<arguments.length;if("OperatorNode"===e&&r.isBinary()){let e,t=!1;if("^"!==r.op||"ParenthesisNode"!==r.args[0].type&&"OperatorNode"!==r.args[0].type||"ConstantNode"!==r.args[1].type||(e=parseFloat(r.args[1].value),t=2<=e&&v(e)),t){if(2<e){const n=r.args[0],i=new m("^","pow",[r.args[0].cloneDeep(),new p(e-1)]);r=new m("*","multiply",[n,i])}else r=new m("*","multiply",[r.args[0],r.args[0].cloneDeep()]);a&&("content"===i?n.content=r:n.args[i]=r)}}if("ParenthesisNode"===e)t(r.content,r,"content");else if("ConstantNode"!==e&&"SymbolNode"!==e)for(let e=0;e<r.args.length;e++)t(r.args[e],r,e);if(!a)return r}(a);let r,n=!0,i=!1;for(a=f(a,o.firstRules,{},s);t=n?o.distrDivRules:o.sucDivRules,n=!n,(r=(a=f(a,t,{},u)).toString())!==e;)i=!0,e=r;i&&(a=f(a,o.firstRulesAgain,{},s)),a=f(a,o.finalRules,{},s)}const n=[],i={};return"OperatorNode"===a.type&&a.isBinary()&&"/"===a.op?(1===r&&(a.args[0]=d(a.args[0],n),a.args[1]=d(a.args[1])),t&&(i.numerator=a.args[0],i.denominator=a.args[1])):(1===r&&(a=d(a,n)),t&&(i.numerator=a,i.denominator=null)),t?(i.coefficients=n,i.variables=e.variables,i.expression=a,i):a}return t(Dm,{Node:r,"Node, boolean":(e,t)=>r(e,{},t),"Node, Object":r,"Node, Object, boolean":r});function d(e,a){let o=(a=void 0===a?[]:a)[0]=0,s="";!function t(r,e,n){var i=r.type;if("FunctionNode"===i)throw new Error("There is an unsolved function call");if("OperatorNode"===i){if(!"+-*^".includes(r.op))throw new Error("Operator "+r.op+" invalid");if(null!==e){if(("unaryMinus"===r.fn||"pow"===r.fn)&&"add"!==e.fn&&"subtract"!==e.fn&&"multiply"!==e.fn)throw new Error("Invalid "+r.op+" placing");if(("subtract"===r.fn||"add"===r.fn||"multiply"===r.fn)&&"add"!==e.fn&&"subtract"!==e.fn)throw new Error("Invalid "+r.op+" placing");if(("subtract"===r.fn||"add"===r.fn||"unaryMinus"===r.fn)&&0!==n.noFil)throw new Error("Invalid "+r.op+" placing")}"^"!==r.op&&"*"!==r.op||(n.fire=r.op);for(let e=0;e<r.args.length;e++)"unaryMinus"===r.fn&&(n.oper="-"),"+"!==r.op&&"subtract"!==r.fn||(n.fire="",n.cte=1,n.oper=0===e?"+":r.op),n.noFil=e,t(r.args[e],r,n)}else if("SymbolNode"===i){if(r.name!==s&&""!==s)throw new Error("There is more than one variable");if(s=r.name,null===e)return a[1]=1,0;if("^"===e.op&&0!==n.noFil)throw new Error("In power the variable should be the first parameter");if("*"===e.op&&1!==n.noFil)throw new Error("In multiply the variable should be the second parameter");""!==n.fire&&"*"!==n.fire||(o<1&&(a[1]=0),a[1]+=n.cte*("+"===n.oper?1:-1),o=Math.max(1,o))}else{if("ConstantNode"!==i)throw new Error("Type "+i+" is not allowed");{const t=parseFloat(r.value);if(null===e)return a[0]=t,0;if("^"===e.op){if(1!==n.noFil)throw new Error("Constant cannot be powered");if(!v(t)||t<=0)throw new Error("Non-integer exponent is not allowed");for(let e=o+1;e<t;e++)a[e]=0;return t>o&&(a[t]=0),a[t]+=n.cte*("+"===n.oper?1:-1),o=Math.max(t,o),0}n.cte=t,""===n.fire&&(a[0]+=n.cte*("+"===n.oper?1:-1))}}}(e,null,{cte:1,oper:"+",fire:""});let n,i=!0;for(let r=o=a.length-1;0<=r;r--)if(0!==a[r]){let t=new p(i?a[r]:Math.abs(a[r]));var u=a[r]<0?"-":"+";if(0<r){let e=new h(s);if(1<r){const a=new p(r);e=new m("^","pow",[e,a])}t=-1===a[r]&&i?new m("-","unaryMinus",[e]):1===Math.abs(a[r])?e:new m("*","multiply",[t,e])}n=i?t:"+"==u?new m("+","add",[n,t]):new m("-","subtract",[n,t]),i=!1}return i?new p(0):n}}),Bm=s("zpk2tf",["typed","add","multiply","Complex","number"],e=>{let{typed:t,add:a,multiply:o,Complex:s,number:u}=e;return t("zpk2tf",{"Array,Array,number":n,"Array,Array":function(e,t){return n(e,t,1)},"Matrix,Matrix,number":function(e,t,r){return n(e.valueOf(),t.valueOf(),r)},"Matrix,Matrix":function(e,t){return n(e.valueOf(),t.valueOf(),1)}});function n(r,n,t){r.some(e=>"BigNumber"===e.type)&&(r=r.map(e=>u(e))),n.some(e=>"BigNumber"===e.type)&&(n=n.map(e=>u(e)));let i=[s(1,0)],a=[s(1,0)];for(let t=0;t<r.length;t++){let e=r[t];"number"==typeof e&&(e=s(e,0)),i=c(i,[s(1,0),s(-e.re,-e.im)])}for(let t=0;t<n.length;t++){let e=n[t];"number"==typeof e&&(e=s(e,0)),a=c(a,[s(1,0),s(-e.re,-e.im)])}for(let e=0;e<i.length;e++)i[e]=o(i[e],t);return[i,a]}function c(r,n){const i=[];for(let t=0;t<r.length+n.length-1;t++){i[t]=s(0,0);for(let e=0;e<r.length;e++)0<=t-e&&t-e<n.length&&(i[t]=a(i[t],o(r[e],n[t-e])))}return i}}),Om=s("freqz",["typed","add","multiply","Complex","divide","matrix"],e=>{let{typed:t,add:c,multiply:l,Complex:f,divide:r,matrix:n}=e;return t("freqz",{"Array, Array":function(e,t){return i(e,t,a(512))},"Array, Array, Array":i,"Array, Array, number":function(e,t,r){if(r<0)throw new Error("w must be a positive number");return i(e,t,a(r))},"Matrix, Matrix":function(e,t){var r=a(512),{w:e,h:t}=i(e.valueOf(),t.valueOf(),r);return{w:n(e),h:n(t)}},"Matrix, Matrix, Matrix":function(e,t,r){e=i(e.valueOf(),t.valueOf(),r.valueOf()).h;return{h:n(e),w:n(r)}},"Matrix, Matrix, number":function(e,t,r){if(r<0)throw new Error("w must be a positive number");r=a(r),e=i(e.valueOf(),t.valueOf(),r).h;return{h:n(e),w:n(r)}}});function i(i,a,o){const s=[],u=[];for(let n=0;n<o.length;n++){let t=f(0,0),r=f(0,0);for(let e=0;e<i.length;e++)t=c(t,l(i[e],f(Math.cos(-e*o[n]),Math.sin(-e*o[n]))));for(let e=0;e<a.length;e++)r=c(r,l(a[e],f(Math.cos(-e*o[n]),Math.sin(-e*o[n]))));s.push(t),u.push(r)}const t=[];for(let e=0;e<s.length;e++)t.push(r(s[e],u[e]));return{h:t,w:o}}function a(t){const r=[];for(let e=0;e<t;e++)r.push(e/t*Math.PI);return r}}),_m=s("reviver",["classes"],e=>{let n=e["classes"];return function(e,t){const r=n[t&&t.mathjs];return r&&"function"==typeof r.fromJSON?r.fromJSON(t):t}}),zm=s("replacer",[],()=>function(e,t){return"number"!=typeof t||isFinite(t)&&!isNaN(t)?"bigint"==typeof t?{mathjs:"bigint",value:String(t)}:t:{mathjs:"number",value:String(t)}}),Im=Math.PI,km=2*Math.PI,qm=Math.E,Rm=s("true",[],()=>!0),Pm=s("false",[],()=>!1),jm=s("null",[],()=>null),Um=n0("Infinity",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1/0):1/0}),Lm=n0("NaN",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(NaN):NaN}),$m=n0("pi",["config","?BigNumber"],e=>{var{config:e,BigNumber:t}=e;return"BigNumber"===e.number?uc(t):Im}),Hm=n0("tau",["config","?BigNumber"],e=>{var{config:e,BigNumber:t}=e;return"BigNumber"===e.number?cc(t):km}),Gm=n0("e",["config","?BigNumber"],e=>{var{config:e,BigNumber:t}=e;return"BigNumber"===e.number?oc(t):qm}),Zm=n0("phi",["config","?BigNumber"],e=>{var{config:e,BigNumber:t}=e;return"BigNumber"===e.number?sc(t):1.618033988749895}),Vm=n0("LN2",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(2).ln():Math.LN2}),Wm=n0("LN10",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(10).ln():Math.LN10}),Ym=n0("LOG2E",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1).div(new r(2).ln()):Math.LOG2E}),Jm=n0("LOG10E",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(1).div(new r(10).ln()):Math.LOG10E}),Xm=n0("SQRT1_2",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r("0.5").sqrt():Math.SQRT1_2}),Qm=n0("SQRT2",["config","?BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(2).sqrt():Math.SQRT2}),Km=n0("i",["Complex"],e=>{e=e.Complex;return e.I}),e0=s("PI",["pi"],e=>{e=e.pi;return e}),t0=s("E",["e"],e=>{e=e.e;return e}),r0=s("version",[],()=>"13.0.3");function n0(e,t,r){return s(e,t,r,{recreateOnConfigChange:!0})}const i0=e("speedOfLight","299792458","m s^-1"),a0=e("gravitationConstant","6.67430e-11","m^3 kg^-1 s^-2"),o0=e("planckConstant","6.62607015e-34","J s"),s0=e("reducedPlanckConstant","1.0545718176461565e-34","J s"),u0=e("magneticConstant","1.25663706212e-6","N A^-2"),c0=e("electricConstant","8.8541878128e-12","F m^-1"),l0=e("vacuumImpedance","376.730313667","ohm"),f0=e("coulomb","8.987551792261171e9","N m^2 C^-2"),p0=e("elementaryCharge","1.602176634e-19","C"),m0=e("bohrMagneton","9.2740100783e-24","J T^-1"),h0=e("conductanceQuantum","7.748091729863649e-5","S"),d0=e("inverseConductanceQuantum","12906.403729652257","ohm"),g0=e("magneticFluxQuantum","2.0678338484619295e-15","Wb"),y0=e("nuclearMagneton","5.0507837461e-27","J T^-1"),x0=e("klitzing","25812.807459304513","ohm"),b0=e("bohrRadius","5.29177210903e-11","m"),v0=e("classicalElectronRadius","2.8179403262e-15","m"),w0=e("electronMass","9.1093837015e-31","kg"),N0=e("fermiCoupling","1.1663787e-5","GeV^-2"),E0=eh("fineStructure",.0072973525693),A0=e("hartreeEnergy","4.3597447222071e-18","J"),S0=e("protonMass","1.67262192369e-27","kg"),M0=e("deuteronMass","3.3435830926e-27","kg"),C0=e("neutronMass","1.6749271613e-27","kg"),T0=e("quantumOfCirculation","3.6369475516e-4","m^2 s^-1"),D0=e("rydberg","10973731.568160","m^-1"),F0=e("thomsonCrossSection","6.6524587321e-29","m^2"),B0=eh("weakMixingAngle",.2229),O0=eh("efimovFactor",22.7),_0=e("atomicMass","1.66053906660e-27","kg"),z0=e("avogadro","6.02214076e23","mol^-1"),I0=e("boltzmann","1.380649e-23","J K^-1"),k0=e("faraday","96485.33212331001","C mol^-1"),q0=e("firstRadiation","3.7417718521927573e-16","W m^2"),R0=e("loschmidt","2.686780111798444e25","m^-3"),P0=e("gasConstant","8.31446261815324","J K^-1 mol^-1"),j0=e("molarPlanckConstant","3.990312712893431e-10","J s mol^-1"),U0=e("molarVolume","0.022413969545014137","m^3 mol^-1"),L0=eh("sackurTetrode",-1.16487052358),$0=e("secondRadiation","0.014387768775039337","m K"),H0=e("stefanBoltzmann","5.67037441918443e-8","W m^-2 K^-4"),G0=e("wienDisplacement","2.897771955e-3","m K"),Z0=e("molarMass","0.99999999965e-3","kg mol^-1"),V0=e("molarMassC12","11.9999999958e-3","kg mol^-1"),W0=e("gravity","9.80665","m s^-2"),Y0=e("planckLength","1.616255e-35","m"),J0=e("planckMass","2.176435e-8","kg"),X0=e("planckTime","5.391245e-44","s"),Q0=e("planckCharge","1.87554603778e-18","C"),K0=e("planckTemperature","1.416785e+32","K");function e(e,a,o){return s(e,["config","Unit","BigNumber"],e=>{let{config:t,Unit:r,BigNumber:n}=e;const i=new r("BigNumber"===t.number?new n(a):parseFloat(a),o);return i.fixPrefix=!0,i})}function eh(e,n){return s(e,["config","BigNumber"],e=>{let{config:t,BigNumber:r}=e;return"BigNumber"===t.number?new r(n):n})}const th=s("apply",["typed","isInteger"],e=>{let{typed:t,isInteger:r}=e;const n=ta({typed:t,isInteger:r});return t("apply",{"...any":function(e){const t=e[1];E(t)?e[1]=t-1:Q(t)&&(e[1]=t.minus(1));try{return n.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),rh=s("column",["typed","Index","matrix","range"],e=>{let{typed:t,Index:r,matrix:n,range:i}=e;const a=Bo({typed:t,Index:r,matrix:n,range:i});return t("column",{"...any":function(e){var t=e.length-1,r=e[t];E(r)&&(e[t]=r-1);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0});function nh(e,t,r){var n=e.filter(function(e){return se(e)&&!(e.name in t)&&!r.has(e.name)})[0];if(!n)throw new Error('No undefined variable found in inline expression "'+e+'"');const i=n.name,a=new Map,o=new et(r,a,new Set([i])),s=e.compile();return function(e){return a.set(i,e),s.evaluate(o)}}const ih=s("filter",["typed"],e=>{let t=e["typed"];function r(e,t,r){let n,i;return e[0]&&(n=e[0].compile().evaluate(r)),e[1]&&(i=se(e[1])||pe(e[1])?e[1].compile().evaluate(r):nh(e[1],t,r)),a(n,i)}r.rawArgs=!0;const a=t("filter",{"Array, function":ah,"Matrix, function":function(e,t){return e.create(ah(e.toArray(),t))},"Array, RegExp":Mn,"Matrix, RegExp":function(e,t){return e.create(Mn(e.toArray(),t))}});return r},{isTransformFunction:!0});function ah(e,n){return Sn(e,function(e,t,r){return Io(n,e,[t+1],r,"filter")})}const oh=s("forEach",["typed"],e=>{let t=e["typed"];function r(e,t,r){let n,i;return e[0]&&(n=e[0].compile().evaluate(r)),e[1]&&(i=se(e[1])||pe(e[1])?e[1].compile().evaluate(r):nh(e[1],t,r)),a(n,i)}r.rawArgs=!0;const a=t("forEach",{"Array | Matrix, function":function(t,n){function i(e,r){if(!Array.isArray(e))return Io(n,e,r,t,"forEach");An(e,function(e,t){i(e,r.concat(t+1))})}i(t.valueOf(),[])}});return r},{isTransformFunction:!0}),sh=s("index",["Index","getMatrixDataType"],e=>{let{Index:t,getMatrixDataType:n}=e;return function(){const r=[];for(let t=0,e=arguments.length;t<e;t++){let e=arguments[t];if(h(e))e.start--,e.end-=0<e.step?0:2;else if(e&&!0===e.isSet)e=e.map(function(e){return e-1});else if(g(e)||_(e))"boolean"!==n(e)&&(e=e.map(function(e){return e-1}));else if(E(e))e--;else if(Q(e))e=e.toNumber()-1;else if("string"!=typeof e)throw new TypeError("Dimension must be an Array, Matrix, number, string, or Range");r[t]=e}var e=new t;return t.apply(e,r),e}},{isTransformFunction:!0}),uh=s("map",["typed"],e=>{let t=e["typed"];function r(e,t,r){let n,i;return e[0]&&(n=e[0].compile().evaluate(r)),e[1]&&(i=se(e[1])||pe(e[1])?e[1].compile().evaluate(r):nh(e[1],t,r)),a(n,i)}r.rawArgs=!0;const a=t("map",{"Array, function":function(e,t){return ch(e,t,e)},"Matrix, function":function(e,t){return e.create(ch(e.valueOf(),t,e))}});return r},{isTransformFunction:!0});function ch(e,t,i){return function r(e,n){return Array.isArray(e)?En(e,function(e,t){return r(e,n.concat(t+1))}):Io(t,e,n,i,"map")}(e,[])}function lh(e){if(2===e.length&&q(e[0])){const t=(e=e.slice())[1];E(t)?e[1]=t-1:Q(t)&&(e[1]=t.minus(1))}return e}const fh=s("max",["typed","config","numeric","larger"],e=>{let{typed:t,config:r,numeric:n,larger:i}=e;const a=Ku({typed:t,config:r,numeric:n,larger:i});return t("max",{"...any":function(e){e=lh(e);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),ph=s("mean",["typed","add","divide"],e=>{let{typed:t,add:r,divide:n}=e;const i=yp({typed:t,add:r,divide:n});return t("mean",{"...any":function(e){e=lh(e);try{return i.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),mh=s("min",["typed","config","numeric","smaller"],e=>{let{typed:t,config:r,numeric:n,smaller:i}=e;const a=ec({typed:t,config:r,numeric:n,smaller:i});return t("min",{"...any":function(e){e=lh(e);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),hh=s("range",["typed","config","?matrix","?bignumber","smaller","smallerEq","larger","largerEq","add","isPositive"],e=>{let{typed:t,config:r,matrix:n,bignumber:i,smaller:a,smallerEq:o,larger:s,largerEq:u,add:c,isPositive:l}=e;const f=ts({typed:t,config:r,matrix:n,bignumber:i,smaller:a,smallerEq:o,larger:s,largerEq:u,add:c,isPositive:l});return t("range",{"...any":function(e){return"boolean"!=typeof e[e.length-1]&&e.push(!0),f.apply(null,e)}})},{isTransformFunction:!0}),dh=s("row",["typed","Index","matrix","range"],e=>{let{typed:t,Index:r,matrix:n,range:i}=e;const a=us({typed:t,Index:r,matrix:n,range:i});return t("row",{"...any":function(e){var t=e.length-1,r=e[t];E(r)&&(e[t]=r-1);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),gh=s("subset",["typed","matrix","zeros","add"],e=>{let{typed:t,matrix:r,zeros:n,add:i}=e;const a=ps({typed:t,matrix:r,zeros:n,add:i});return t("subset",{"...any":function(e){try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),yh=s("concat",["typed","matrix","isInteger"],e=>{let{typed:t,matrix:r,isInteger:n}=e;const i=Fo({typed:t,matrix:r,isInteger:n});return t("concat",{"...any":function(e){const t=e.length-1,r=e[t];E(r)?e[t]=r-1:Q(r)&&(e[t]=r.minus(1));try{return i.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),xh=s("diff",["typed","matrix","subtract","number","bignumber"],e=>{let{typed:t,matrix:r,subtract:n,number:i,bignumber:a}=e;const o=Jo({typed:t,matrix:r,subtract:n,number:i,bignumber:a});return t("diff",{"...any":function(e){e=lh(e);try{return o.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),bh=s("std",["typed","map","sqrt","variance"],e=>{let{typed:t,map:r,sqrt:n,variance:i}=e;const a=Sp({typed:t,map:r,sqrt:n,variance:i});return t("std",{"...any":function(e){e=lh(e);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),vh=s("sum",["typed","config","add","numeric"],e=>{let{typed:t,config:r,add:n,numeric:i}=e;const a=hp({typed:t,config:r,add:n,numeric:i});return t("sum",{"...any":function(e){e=lh(e);try{return a.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),wh=s("quantileSeq",["typed","bignumber","add","subtract","divide","multiply","partitionSelect","compare","isInteger","smaller","smallerEq","larger"],e=>{let{typed:t,bignumber:r,add:n,subtract:i,divide:a,multiply:o,partitionSelect:s,compare:u,isInteger:c,smaller:l,smallerEq:f,larger:p}=e;const m=Ap({typed:t,bignumber:r,add:n,subtract:i,divide:a,multiply:o,partitionSelect:s,compare:u,isInteger:c,smaller:l,smallerEq:f,larger:p});return t("quantileSeq",{"Array | Matrix, number | BigNumber":m,"Array | Matrix, number | BigNumber, number":(e,t,r)=>m(e,t,h(r)),"Array | Matrix, number | BigNumber, boolean":m,"Array | Matrix, number | BigNumber, boolean, number":(e,t,r,n)=>m(e,t,r,h(n)),"Array | Matrix, Array | Matrix":m,"Array | Matrix, Array | Matrix, number":(e,t,r)=>m(e,t,h(r)),"Array | Matrix, Array | Matrix, boolean":m,"Array | Matrix, Array | Matrix, boolean, number":(e,t,r,n)=>m(e,t,r,h(n))});function h(e){return lh([[],e])[1]}},{isTransformFunction:!0}),Nh=s("cumsum",["typed","add","unaryPlus"],e=>{let{typed:t,add:r,unaryPlus:n}=e;const i=gp({typed:t,add:r,unaryPlus:n});return t("cumsum",{"...any":function(e){if(2===e.length&&q(e[0])){const t=e[1];E(t)?e[1]=t-1:Q(t)&&(e[1]=t.minus(1))}try{return i.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),Eh=s("variance",["typed","add","subtract","multiply","divide","apply","isNaN"],e=>{let{typed:t,add:r,subtract:n,multiply:i,divide:a,apply:o,isNaN:s}=e;const u=Np({typed:t,add:r,subtract:n,multiply:i,divide:a,apply:o,isNaN:s});return t("variance",{"...any":function(e){e=lh(e);try{return u.apply(null,e)}catch(e){throw Il(e)}}})},{isTransformFunction:!0}),Ah=s("print",["typed","matrix","zeros","add"],e=>{let{typed:t,matrix:r,zeros:n,add:i}=e;const a=js({typed:t,matrix:r,zeros:n,add:i});return t("print",{"string, Object | Array":function(e,t){return a(o(e),t)},"string, Object | Array, number | Object":function(e,t,r){return a(o(e),t,r)}});function o(e){return e.replace(Ps,e=>"$"+e.slice(1).split(".").map(function(e){return!isNaN(e)&&0<e.length?parseInt(e)-1:e}).join("."))}},{isTransformFunction:!0}),Sh=s("and",["typed","matrix","zeros","add","equalScalar","not","concat"],e=>{var{typed:e,matrix:t,equalScalar:r,zeros:n,not:i,concat:a}=e;const o=bu({typed:e,matrix:t,equalScalar:r,zeros:n,not:i,concat:a});function s(e,t,r){var n=e[0].compile().evaluate(r);if(!q(n)&&!o(n,!0))return!1;e=e[1].compile().evaluate(r);return o(n,e)}return s.rawArgs=!0,s},{isTransformFunction:!0}),Mh=s("or",["typed","matrix","equalScalar","DenseMatrix","concat"],e=>{var{typed:e,matrix:t,equalScalar:r,DenseMatrix:n,concat:i}=e;const a=To({typed:e,matrix:t,equalScalar:r,DenseMatrix:n,concat:i});function o(e,t,r){var n=e[0].compile().evaluate(r);if(!q(n)&&a(n,!1))return!0;e=e[1].compile().evaluate(r);return a(n,e)}return o.rawArgs=!0,o},{isTransformFunction:!0}),Ch=s("bitAnd",["typed","matrix","zeros","add","equalScalar","not","concat"],e=>{var{typed:e,matrix:t,equalScalar:r,zeros:n,not:i,concat:a}=e;const o=po({typed:e,matrix:t,equalScalar:r,zeros:n,not:i,concat:a});function s(e,t,r){var n=e[0].compile().evaluate(r);if(!q(n)){if(isNaN(n))return NaN;if(0===n||!1===n)return 0}e=e[1].compile().evaluate(r);return o(n,e)}return s.rawArgs=!0,s},{isTransformFunction:!0}),Th=s("bitOr",["typed","matrix","equalScalar","DenseMatrix","concat"],e=>{var{typed:e,matrix:t,equalScalar:r,DenseMatrix:n,concat:i}=e;const a=ho({typed:e,matrix:t,equalScalar:r,DenseMatrix:n,concat:i});function o(e,t,r){var n=e[0].compile().evaluate(r);if(!q(n)){if(isNaN(n))return NaN;if(-1===n)return-1;if(!0===n)return 1}e=e[1].compile().evaluate(r);return a(n,e)}return o.rawArgs=!0,o},{isTransformFunction:!0});var Dh=kh(1504);const Fh={relTol:1e-12,absTol:1e-15,matrix:"Matrix",number:"number",numberFallback:"number",precision:64,predictable:!1,randomSeed:null},Bh=["Matrix","Array"],Oh=["number","BigNumber","Fraction"];function _h(n,i){function a(e){if(e){if(void 0!==e.epsilon){console.warn('Warning: The configuration option "epsilon" is deprecated. Use "relTol" and "absTol" instead.');const n=ee(e);return n.relTol=e.epsilon,n.absTol=.001*e.epsilon,delete n.epsilon,a(n)}var t=ee(n),r=(zh(e,"matrix",Bh),zh(e,"number",Oh),function e(t,r){if(Array.isArray(r))throw new TypeError("Arrays are not supported by deepExtend");for(const n in r)if(ue(r,n)&&!(n in Object.prototype)&&!(n in Function.prototype))if(r[n]&&r[n].constructor===Object)void 0===t[n]&&(t[n]={}),t[n]&&t[n].constructor===Object?e(t[n],r[n]):t[n]=r[n];else{if(Array.isArray(r[n]))throw new TypeError("Arrays are not supported by deepExtend");t[n]=r[n]}}(n,e),ee(n)),e=ee(e);return i("config",r,t,e),r}return ee(n)}return a.MATRIX_OPTIONS=Bh,a.NUMBER_OPTIONS=Oh,Object.keys(Fh).forEach(e=>{Object.defineProperty(a,e,{get:()=>n[e],enumerable:!0,configurable:!0})}),a}function zh(e,t,r){void 0===e[t]||r.includes(e[t])||console.warn('Warning: Unknown value "'+e[t]+'" for configuration option "'+t+'". Available options: '+r.map(e=>JSON.stringify(e)).join(", ")+".")}const Ih=function e(t,r){r=an({},Fh,r);if("function"!=typeof Object.create)throw new Error("ES5 not supported by this JavaScript engine. Please load the es5-shim and es5-sham library for compatibility.");const n=function(e){const t=new Dh;return e.on=t.on.bind(t),e.off=t.off.bind(t),e.once=t.once.bind(t),e.emit=t.emit.bind(t),e}({isNumber:E,isComplex:te,isBigNumber:Q,isBigInt:c,isFraction:I,isUnit:L,isString:k,isArray:g,isMatrix:_,isCollection:q,isDenseMatrix:R,isSparseMatrix:P,isRange:h,isIndex:j,isBoolean:U,isResultSet:$,isHelp:H,isFunction:G,isDate:Z,isRegExp:V,isObject:W,isNull:Y,isUndefined:J,isAccessorNode:le,isArrayNode:X,isAssignmentNode:re,isBlockNode:ne,isConditionalNode:ie,isConstantNode:ae,isFunctionAssignmentNode:pe,isFunctionNode:me,isIndexNode:he,isNode:O,isObjectNode:de,isOperatorNode:oe,isParenthesisNode:ge,isRangeNode:ye,isRelationalNode:xe,isSymbolNode:se,isChain:be}),i=(n.config=_h(r,n.emit),n.expression={transform:{},mathWithTransform:{config:n.config}},{});function a(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return n.typed.apply(n.typed,t)}a.isTypedFunction=ve.isTypedFunction;const o=function(u,c,l){function a(e,t,r){var n;if(r.wrap&&"function"==typeof t&&((n=t).transform&&(i.transform=n.transform),t=i),"function"==typeof t&&"string"==typeof t.signature&&(t=u(e,{[t.signature]:t})),u.isTypedFunction(c[e])&&u.isTypedFunction(t))return t=r.override?u(e,t.signatures):u(c[e],t),c[e]=t,delete l[e],o(e,t),c.emit("import",e,function(){return t});function i(){const r=[];for(let e=0,t=arguments.length;e<t;e++){const c=arguments[e];r[e]=c&&c.valueOf()}return n.apply(c,r)}if(void 0===c[e]||r.override)return c[e]=t,delete l[e],o(e,t),c.emit("import",e,function(){return t});if(!r.silent)throw new Error('Cannot import "'+e+'": already exists')}function o(e,t){t&&"function"==typeof t.transform?(c.expression.transform[e]=t.transform,r(e)&&(c.expression.mathWithTransform[e]=t.transform)):(delete c.expression.transform[e],r(e)&&(c.expression.mathWithTransform[e]=t))}function f(e){delete c.expression.transform[e],r(e)?c.expression.mathWithTransform[e]=c[e]:delete c.expression.mathWithTransform[e]}function s(r,n,e){let i=2<arguments.length&&void 0!==e?e:r.fn;if(i.includes("."))throw new Error("Factory name should not contain a nested path. Name: "+JSON.stringify(i));function t(){const t={};r.dependencies.map(Ge).forEach(e=>{if(e.includes("."))throw new Error("Factory dependency should not contain a nested path. Name: "+JSON.stringify(e));"math"===e?t.math=c:"mathWithTransform"===e?t.mathWithTransform=c.expression.mathWithTransform:"classes"===e?t.classes=c:t[e]=c[e]});var e=r(t);if(e&&"function"==typeof e.transform)throw new Error('Transforms cannot be attached to factory functions. Please create a separate function for it with export const path = "expression.transform"');if(void 0===s||n.override)return e;if(u.isTypedFunction(s)&&u.isTypedFunction(e))return u(s,e);if(n.silent)return s;throw new Error('Cannot import "'+i+'": already exists')}const a=m(r)?c.expression.transform:c,o=i in c.expression.transform,s=ue(a,i)?a[i]:void 0;r.meta&&!1===r.meta.lazy?a[i]=t():$e(a,i,t),s&&o?f(i):(m(r)||p(r))&&$e(c.expression.mathWithTransform,i,()=>a[i]),l[i]=r,c.emit("import",i,t)}function r(e){return!ue(t,e)}function p(e){return!(e.fn.includes(".")||ue(t,e.fn)||e.meta&&e.meta.isClass)}function m(e){return void 0!==e&&void 0!==e.meta&&!0===e.meta.isTransformFunction}const t={expression:!0,type:!0,docs:!0,error:!0,json:!0,chain:!0};return function(e,i){const t=arguments.length;if(1!==t&&2!==t)throw new Ta("import",t,1,2);i=i||{};var r,n={};!function t(r,e,n){if(Array.isArray(e))e.forEach(e=>t(r,e));else if("object"==typeof e)for(const i in e)ue(e,i)&&t(r,e[i],i);else if(He(e)||void 0!==n){const t=He(e)?m(e)?e.fn+".transform":e.fn:n;if(ue(r,t)&&r[t]!==e&&!i.silent)throw new Error('Cannot import "'+t+'" twice');r[t]=e}else if(!i.silent)throw new TypeError("Factory, Object, or Array expected")}(n,e);for(const e in n)if(ue(n,e)){const t=n[e];if(He(t))s(t,i);else if("function"==typeof(r=t)||"number"==typeof r||"string"==typeof r||"boolean"==typeof r||null===r||L(r)||te(r)||Q(r)||I(r)||_(r)||Array.isArray(r))a(e,t,i);else if(!i.silent)throw new TypeError("Factory, Object, or Array expected")}}}(a,n,i);return n.import=o,n.on("config",()=>{Object.values(i).forEach(e=>{e&&e.meta&&e.meta.recreateOnConfigChange&&o(e,{override:!0})})}),n.create=e.bind(null,t),n.factory=s,n.import(Object.values(Le(t))),n.ArgumentsError=Ta,n.DimensionError=z,n.IndexError=mn,n}(t)})(),qh.default});
\ No newline at end of file
diff --git a/src/imports/measure.png b/src/imports/measure.png
deleted file mode 100644 (file)
index d44c75c..0000000
Binary files a/src/imports/measure.png and /dev/null differ
diff --git a/src/imports/micromodal.css b/src/imports/micromodal.css
deleted file mode 100644 (file)
index 03dd044..0000000
+++ /dev/null
@@ -1,151 +0,0 @@
-/**************************\
-  Basic Modal Styles
-\**************************/
-
-.modal {
-  font-family: -apple-system,BlinkMacSystemFont,avenir next,avenir,helvetica neue,helvetica,ubuntu,roboto,noto,segoe ui,arial,sans-serif;
-}
-
-.modal__overlay {
-  position: fixed;
-  top: 0;
-  left: 0;
-  right: 0;
-  bottom: 0;
-  background: rgba(0,0,0,0.6);
-  display: flex;
-  justify-content: center;
-  align-items: center;
-}
-
-.modal__container {
-  background-color: #fff;
-  padding: 30px;
-  max-width: 500px;
-  max-height: 100vh;
-  border-radius: 4px;
-  overflow-y: auto;
-  box-sizing: border-box;
-}
-
-.modal__header {
-  display: flex;
-  justify-content: space-between;
-  align-items: center;
-}
-
-.modal__title {
-  margin-top: 0;
-  margin-bottom: 0;
-  font-weight: 600;
-  font-size: 1.25rem;
-  line-height: 1.25;
-  color: #00449e;
-  box-sizing: border-box;
-}
-
-.modal__close {
-  background: transparent;
-  border: 0;
-}
-
-.modal__header .modal__close:before { content: "\2715"; }
-
-.modal__content {
-  margin-top: 2rem;
-  margin-bottom: 2rem;
-  line-height: 1.5;
-  color: rgba(0,0,0,.8);
-}
-
-.modal__btn {
-  font-size: .875rem;
-  padding-left: 1rem;
-  padding-right: 1rem;
-  padding-top: .5rem;
-  padding-bottom: .5rem;
-  background-color: #e6e6e6;
-  color: rgba(0,0,0,.8);
-  border-radius: .25rem;
-  border-style: none;
-  border-width: 0;
-  cursor: pointer;
-  -webkit-appearance: button;
-  text-transform: none;
-  overflow: visible;
-  line-height: 1.15;
-  margin: 0;
-  will-change: transform;
-  -moz-osx-font-smoothing: grayscale;
-  -webkit-backface-visibility: hidden;
-  backface-visibility: hidden;
-  -webkit-transform: translateZ(0);
-  transform: translateZ(0);
-  transition: -webkit-transform .25s ease-out;
-  transition: transform .25s ease-out;
-  transition: transform .25s ease-out,-webkit-transform .25s ease-out;
-}
-
-.modal__btn:focus, .modal__btn:hover {
-  -webkit-transform: scale(1.05);
-  transform: scale(1.05);
-}
-
-.modal__btn-primary {
-  background-color: #00449e;
-  color: #fff;
-}
-
-
-
-/**************************\
-  Demo Animation Style
-\**************************/
-@keyframes mmfadeIn {
-    from { opacity: 0; }
-      to { opacity: 1; }
-}
-
-@keyframes mmfadeOut {
-    from { opacity: 1; }
-      to { opacity: 0; }
-}
-
-@keyframes mmslideIn {
-  from { transform: translateY(15%); }
-    to { transform: translateY(0); }
-}
-
-@keyframes mmslideOut {
-    from { transform: translateY(0); }
-    to { transform: translateY(-10%); }
-}
-
-.micromodal-slide {
-  display: none;
-}
-
-.micromodal-slide.is-open {
-  display: block;
-}
-
-.micromodal-slide[aria-hidden="false"] .modal__overlay {
-  animation: mmfadeIn .3s cubic-bezier(0.0, 0.0, 0.2, 1);
-}
-
-.micromodal-slide[aria-hidden="false"] .modal__container {
-  animation: mmslideIn .3s cubic-bezier(0, 0, .2, 1);
-}
-
-.micromodal-slide[aria-hidden="true"] .modal__overlay {
-  animation: mmfadeOut .3s cubic-bezier(0.0, 0.0, 0.2, 1);
-}
-
-.micromodal-slide[aria-hidden="true"] .modal__container {
-  animation: mmslideOut .3s cubic-bezier(0, 0, .2, 1);
-}
-
-.micromodal-slide .modal__container,
-.micromodal-slide .modal__overlay {
-  will-change: transform;
-}
\ No newline at end of file
diff --git a/src/imports/micromodal.js b/src/imports/micromodal.js
deleted file mode 100644 (file)
index 6abbb68..0000000
+++ /dev/null
@@ -1,223 +0,0 @@
-! function(e, t) {
-    "object" == typeof exports && "undefined" != typeof module ? module.exports = t() : "function" == typeof define && define.amd ? define(t) : (e = "undefined" != typeof globalThis ? globalThis : e || self).MicroModal = t()
-}(this, (function() {
-    "use strict";
-
-    function e(e, t) {
-        for (var o = 0; o < t.length; o++) {
-            var n = t[o];
-            n.enumerable = n.enumerable || !1, n.configurable = !0, "value" in n && (n.writable = !0), Object.defineProperty(e, n.key, n)
-        }
-    }
-
-    function t(e) {
-        return function(e) {
-            if (Array.isArray(e)) return o(e)
-        }(e) || function(e) {
-            if ("undefined" != typeof Symbol && Symbol.iterator in Object(e)) return Array.from(e)
-        }(e) || function(e, t) {
-            if (!e) return;
-            if ("string" == typeof e) return o(e, t);
-            var n = Object.prototype.toString.call(e).slice(8, -1);
-            "Object" === n && e.constructor && (n = e.constructor.name);
-            if ("Map" === n || "Set" === n) return Array.from(e);
-            if ("Arguments" === n || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return o(e, t)
-        }(e) || function() {
-            throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
-        }()
-    }
-
-    function o(e, t) {
-        (null == t || t > e.length) && (t = e.length);
-        for (var o = 0, n = new Array(t); o < t; o++) n[o] = e[o];
-        return n
-    }
-    var n, i, a, r, s, l = (n = ["a[href]", "area[href]", 'input:not([disabled]):not([type="hidden"]):not([aria-hidden])', "select:not([disabled]):not([aria-hidden])", "textarea:not([disabled]):not([aria-hidden])", "button:not([disabled]):not([aria-hidden])", "iframe", "object", "embed", "[contenteditable]", '[tabindex]:not([tabindex^="-"])'], i = function() {
-        function o(e) {
-            var n = e.targetModal,
-                i = e.triggers,
-                a = void 0 === i ? [] : i,
-                r = e.onShow,
-                s = void 0 === r ? function() {} : r,
-                l = e.onClose,
-                c = void 0 === l ? function() {} : l,
-                d = e.openTrigger,
-                u = void 0 === d ? "data-micromodal-trigger" : d,
-                f = e.closeTrigger,
-                h = void 0 === f ? "data-micromodal-close" : f,
-                v = e.openClass,
-                g = void 0 === v ? "is-open" : v,
-                m = e.disableScroll,
-                b = void 0 !== m && m,
-                y = e.disableFocus,
-                p = void 0 !== y && y,
-                w = e.awaitCloseAnimation,
-                E = void 0 !== w && w,
-                k = e.awaitOpenAnimation,
-                M = void 0 !== k && k,
-                A = e.debugMode,
-                C = void 0 !== A && A;
-            ! function(e, t) {
-                if (!(e instanceof t)) throw new TypeError("Cannot call a class as a function")
-            }(this, o), this.modal = document.getElementById(n), this.config = {
-                debugMode: C,
-                disableScroll: b,
-                openTrigger: u,
-                closeTrigger: h,
-                openClass: g,
-                onShow: s,
-                onClose: c,
-                awaitCloseAnimation: E,
-                awaitOpenAnimation: M,
-                disableFocus: p
-            }, a.length > 0 && this.registerTriggers.apply(this, t(a)), this.onClick = this.onClick.bind(this), this.onKeydown = this.onKeydown.bind(this)
-        }
-        var i, a, r;
-        return i = o, (a = [{
-            key: "registerTriggers",
-            value: function() {
-                for (var e = this, t = arguments.length, o = new Array(t), n = 0; n < t; n++) o[n] = arguments[n];
-                o.filter(Boolean).forEach((function(t) {
-                    t.addEventListener("click", (function(t) {
-                        return e.showModal(t)
-                    }))
-                }))
-            }
-        }, {
-            key: "showModal",
-            value: function() {
-                var e = this,
-                    t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null;
-                if (this.activeElement = document.activeElement, this.modal.setAttribute("aria-hidden", "false"), this.modal.classList.add(this.config.openClass), this.scrollBehaviour("disable"), this.addEventListeners(), this.config.awaitOpenAnimation) {
-                    var o = function t() {
-                        e.modal.removeEventListener("animationend", t, !1), e.setFocusToFirstNode()
-                    };
-                    this.modal.addEventListener("animationend", o, !1)
-                } else this.setFocusToFirstNode();
-                this.config.onShow(this.modal, this.activeElement, t)
-            }
-        }, {
-            key: "closeModal",
-            value: function() {
-                var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null,
-                    t = this.modal;
-                if (this.modal.setAttribute("aria-hidden", "true"), this.removeEventListeners(), this.scrollBehaviour("enable"), this.activeElement && this.activeElement.focus && this.activeElement.focus(), this.config.onClose(this.modal, this.activeElement, e), this.config.awaitCloseAnimation) {
-                    var o = this.config.openClass;
-                    this.modal.addEventListener("animationend", (function e() {
-                        t.classList.remove(o), t.removeEventListener("animationend", e, !1)
-                    }), !1)
-                } else t.classList.remove(this.config.openClass)
-            }
-        }, {
-            key: "closeModalById",
-            value: function(e) {
-                this.modal = document.getElementById(e), this.modal && this.closeModal()
-            }
-        }, {
-            key: "scrollBehaviour",
-            value: function(e) {
-                if (this.config.disableScroll) {
-                    var t = document.querySelector("body");
-                    switch (e) {
-                        case "enable":
-                            Object.assign(t.style, {
-                                overflow: ""
-                            });
-                            break;
-                        case "disable":
-                            Object.assign(t.style, {
-                                overflow: "hidden"
-                            })
-                    }
-                }
-            }
-        }, {
-            key: "addEventListeners",
-            value: function() {
-                this.modal.addEventListener("touchstart", this.onClick), this.modal.addEventListener("click", this.onClick), document.addEventListener("keydown", this.onKeydown)
-            }
-        }, {
-            key: "removeEventListeners",
-            value: function() {
-                this.modal.removeEventListener("touchstart", this.onClick), this.modal.removeEventListener("click", this.onClick), document.removeEventListener("keydown", this.onKeydown)
-            }
-        }, {
-            key: "onClick",
-            value: function(e) {
-                (e.target.hasAttribute(this.config.closeTrigger)/* || e.target.parentNode.hasAttribute(this.config.closeTrigger)*/) && (e.preventDefault(), e.stopPropagation(), this.closeModal(e))
-            }
-        }, {
-            key: "onKeydown",
-            value: function(e) {
-                27 === e.keyCode && this.closeModal(e), 9 === e.keyCode && this.retainFocus(e)
-            }
-        }, {
-            key: "getFocusableNodes",
-            value: function() {
-                var e = this.modal.querySelectorAll(n);
-                return Array.apply(void 0, t(e))
-            }
-        }, {
-            key: "setFocusToFirstNode",
-            value: function() {
-                var e = this;
-                if (!this.config.disableFocus) {
-                    var t = this.getFocusableNodes();
-                    if (0 !== t.length) {
-                        var o = t.filter((function(t) {
-                            return !t.hasAttribute(e.config.closeTrigger)
-                        }));
-                        o.length > 0 && o[0].focus(), 0 === o.length && t[0].focus()
-                    }
-                }
-            }
-        }, {
-            key: "retainFocus",
-            value: function(e) {
-                var t = this.getFocusableNodes();
-                if (0 !== t.length)
-                    if (t = t.filter((function(e) {
-                            return null !== e.offsetParent
-                        })), this.modal.contains(document.activeElement)) {
-                        var o = t.indexOf(document.activeElement);
-                        e.shiftKey && 0 === o && (t[t.length - 1].focus(), e.preventDefault()), !e.shiftKey && t.length > 0 && o === t.length - 1 && (t[0].focus(), e.preventDefault())
-                    } else t[0].focus()
-            }
-        }]) && e(i.prototype, a), r && e(i, r), o
-    }(), a = null, r = function(e) {
-        if (!document.getElementById(e)) return console.warn("MicroModal: ❗Seems like you have missed %c'".concat(e, "'"), "background-color: #f8f9fa;color: #50596c;font-weight: bold;", "ID somewhere in your code. Refer example below to resolve it."), console.warn("%cExample:", "background-color: #f8f9fa;color: #50596c;font-weight: bold;", '<div class="modal" id="'.concat(e, '"></div>')), !1
-    }, s = function(e, t) {
-        if (function(e) {
-                e.length <= 0 && (console.warn("MicroModal: ❗Please specify at least one %c'micromodal-trigger'", "background-color: #f8f9fa;color: #50596c;font-weight: bold;", "data attribute."), console.warn("%cExample:", "background-color: #f8f9fa;color: #50596c;font-weight: bold;", '<a href="#" data-micromodal-trigger="my-modal"></a>'))
-            }(e), !t) return !0;
-        for (var o in t) r(o);
-        return !0
-    }, {
-        init: function(e) {
-            var o = Object.assign({}, {
-                    openTrigger: "data-micromodal-trigger"
-                }, e),
-                n = t(document.querySelectorAll("[".concat(o.openTrigger, "]"))),
-                r = function(e, t) {
-                    var o = [];
-                    return e.forEach((function(e) {
-                        var n = e.attributes[t].value;
-                        void 0 === o[n] && (o[n] = []), o[n].push(e)
-                    })), o
-                }(n, o.openTrigger);
-            if (!0 !== o.debugMode || !1 !== s(n, r))
-                for (var l in r) {
-                    var c = r[l];
-                    o.targetModal = l, o.triggers = t(c), a = new i(o)
-                }
-        },
-        show: function(e, t) {
-            var o = t || {};
-            o.targetModal = e, !0 === o.debugMode && !1 === r(e) || (a && a.removeEventListeners(), (a = new i(o)).showModal())
-        },
-        close: function(e) {
-            e ? a.closeModalById(e) : a.closeModal()
-        }
-    });
-    return "undefined" != typeof window && (window.MicroModal = l), l
-}));
\ No newline at end of file
diff --git a/src/imports/spinner.gif b/src/imports/spinner.gif
deleted file mode 100644 (file)
index 9897f4d..0000000
Binary files a/src/imports/spinner.gif and /dev/null differ
diff --git a/src/imports/three.min.js b/src/imports/three.min.js
deleted file mode 100644 (file)
index b14f47c..0000000
+++ /dev/null
@@ -1,6 +0,0 @@
-/**
- * @license
- * Copyright 2010-2021 Three.js Authors
- * SPDX-License-Identifier: MIT
- */
-!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).THREE={})}(this,(function(t){"use strict";const e="128",n=100,i=300,r=301,s=302,a=303,o=304,l=306,c=307,h=1e3,u=1001,d=1002,p=1003,m=1004,f=1005,g=1006,v=1007,y=1008,x=1009,_=1012,w=1014,b=1015,M=1016,S=1020,T=1022,E=1023,A=1026,L=1027,R=33776,C=33777,P=33778,D=33779,I=35840,N=35841,B=35842,z=35843,F=37492,O=37496,H=2300,G=2301,U=2302,k=2400,V=2401,W=2402,j=2500,q=2501,X=3e3,Y=3001,Z=3007,J=3002,Q=3004,K=3005,$=3006,tt=7680,et=35044,nt=35048,it="300 es";class rt{addEventListener(t,e){void 0===this._listeners&&(this._listeners={});const n=this._listeners;void 0===n[t]&&(n[t]=[]),-1===n[t].indexOf(e)&&n[t].push(e)}hasEventListener(t,e){if(void 0===this._listeners)return!1;const n=this._listeners;return void 0!==n[t]&&-1!==n[t].indexOf(e)}removeEventListener(t,e){if(void 0===this._listeners)return;const n=this._listeners[t];if(void 0!==n){const t=n.indexOf(e);-1!==t&&n.splice(t,1)}}dispatchEvent(t){if(void 0===this._listeners)return;const e=this._listeners[t.type];if(void 0!==e){t.target=this;const n=e.slice(0);for(let e=0,i=n.length;e<i;e++)n[e].call(this,t);t.target=null}}}const st=[];for(let t=0;t<256;t++)st[t]=(t<16?"0":"")+t.toString(16);let at=1234567;const ot=Math.PI/180,lt=180/Math.PI;function ct(){const t=4294967295*Math.random()|0,e=4294967295*Math.random()|0,n=4294967295*Math.random()|0,i=4294967295*Math.random()|0;return(st[255&t]+st[t>>8&255]+st[t>>16&255]+st[t>>24&255]+"-"+st[255&e]+st[e>>8&255]+"-"+st[e>>16&15|64]+st[e>>24&255]+"-"+st[63&n|128]+st[n>>8&255]+"-"+st[n>>16&255]+st[n>>24&255]+st[255&i]+st[i>>8&255]+st[i>>16&255]+st[i>>24&255]).toUpperCase()}function ht(t,e,n){return Math.max(e,Math.min(n,t))}function ut(t,e){return(t%e+e)%e}function dt(t,e,n){return(1-n)*t+n*e}function pt(t){return 0==(t&t-1)&&0!==t}function mt(t){return Math.pow(2,Math.ceil(Math.log(t)/Math.LN2))}function ft(t){return Math.pow(2,Math.floor(Math.log(t)/Math.LN2))}var gt=Object.freeze({__proto__:null,DEG2RAD:ot,RAD2DEG:lt,generateUUID:ct,clamp:ht,euclideanModulo:ut,mapLinear:function(t,e,n,i,r){return i+(t-e)*(r-i)/(n-e)},inverseLerp:function(t,e,n){return t!==e?(n-t)/(e-t):0},lerp:dt,damp:function(t,e,n,i){return dt(t,e,1-Math.exp(-n*i))},pingpong:function(t,e=1){return e-Math.abs(ut(t,2*e)-e)},smoothstep:function(t,e,n){return t<=e?0:t>=n?1:(t=(t-e)/(n-e))*t*(3-2*t)},smootherstep:function(t,e,n){return t<=e?0:t>=n?1:(t=(t-e)/(n-e))*t*t*(t*(6*t-15)+10)},randInt:function(t,e){return t+Math.floor(Math.random()*(e-t+1))},randFloat:function(t,e){return t+Math.random()*(e-t)},randFloatSpread:function(t){return t*(.5-Math.random())},seededRandom:function(t){return void 0!==t&&(at=t%2147483647),at=16807*at%2147483647,(at-1)/2147483646},degToRad:function(t){return t*ot},radToDeg:function(t){return t*lt},isPowerOfTwo:pt,ceilPowerOfTwo:mt,floorPowerOfTwo:ft,setQuaternionFromProperEuler:function(t,e,n,i,r){const s=Math.cos,a=Math.sin,o=s(n/2),l=a(n/2),c=s((e+i)/2),h=a((e+i)/2),u=s((e-i)/2),d=a((e-i)/2),p=s((i-e)/2),m=a((i-e)/2);switch(r){case"XYX":t.set(o*h,l*u,l*d,o*c);break;case"YZY":t.set(l*d,o*h,l*u,o*c);break;case"ZXZ":t.set(l*u,l*d,o*h,o*c);break;case"XZX":t.set(o*h,l*m,l*p,o*c);break;case"YXY":t.set(l*p,o*h,l*m,o*c);break;case"ZYZ":t.set(l*m,l*p,o*h,o*c);break;default:console.warn("THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: "+r)}}});class vt{constructor(t=0,e=0){this.x=t,this.y=e}get width(){return this.x}set width(t){this.x=t}get height(){return this.y}set height(t){this.y=t}set(t,e){return this.x=t,this.y=e,this}setScalar(t){return this.x=t,this.y=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y)}copy(t){return this.x=t.x,this.y=t.y,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this)}addScalar(t){return this.x+=t,this.y+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this)}subScalar(t){return this.x-=t,this.y-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this}multiply(t){return this.x*=t.x,this.y*=t.y,this}multiplyScalar(t){return this.x*=t,this.y*=t,this}divide(t){return this.x/=t.x,this.y/=t.y,this}divideScalar(t){return this.multiplyScalar(1/t)}applyMatrix3(t){const e=this.x,n=this.y,i=t.elements;return this.x=i[0]*e+i[3]*n+i[6],this.y=i[1]*e+i[4]*n+i[7],this}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this}clampLength(t,e){const n=this.length();return this.divideScalar(n||1).multiplyScalar(Math.max(t,Math.min(e,n)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}roundToZero(){return this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x),this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y),this}negate(){return this.x=-this.x,this.y=-this.y,this}dot(t){return this.x*t.x+this.y*t.y}cross(t){return this.x*t.y-this.y*t.x}lengthSq(){return this.x*this.x+this.y*this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)}normalize(){return this.divideScalar(this.length()||1)}angle(){return Math.atan2(-this.y,-this.x)+Math.PI}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,n=this.y-t.y;return e*e+n*n}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this}lerpVectors(t,e,n){return this.x=t.x+(e.x-t.x)*n,this.y=t.y+(e.y-t.y)*n,this}equals(t){return t.x===this.x&&t.y===this.y}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t}fromBufferAttribute(t,e,n){return void 0!==n&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."),this.x=t.getX(e),this.y=t.getY(e),this}rotateAround(t,e){const n=Math.cos(e),i=Math.sin(e),r=this.x-t.x,s=this.y-t.y;return this.x=r*n-s*i+t.x,this.y=r*i+s*n+t.y,this}random(){return this.x=Math.random(),this.y=Math.random(),this}}vt.prototype.isVector2=!0;class yt{constructor(){this.elements=[1,0,0,0,1,0,0,0,1],arguments.length>0&&console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.")}set(t,e,n,i,r,s,a,o,l){const c=this.elements;return c[0]=t,c[1]=i,c[2]=a,c[3]=e,c[4]=r,c[5]=o,c[6]=n,c[7]=s,c[8]=l,this}identity(){return this.set(1,0,0,0,1,0,0,0,1),this}copy(t){const e=this.elements,n=t.elements;return e[0]=n[0],e[1]=n[1],e[2]=n[2],e[3]=n[3],e[4]=n[4],e[5]=n[5],e[6]=n[6],e[7]=n[7],e[8]=n[8],this}extractBasis(t,e,n){return t.setFromMatrix3Column(this,0),e.setFromMatrix3Column(this,1),n.setFromMatrix3Column(this,2),this}setFromMatrix4(t){const e=t.elements;return this.set(e[0],e[4],e[8],e[1],e[5],e[9],e[2],e[6],e[10]),this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const n=t.elements,i=e.elements,r=this.elements,s=n[0],a=n[3],o=n[6],l=n[1],c=n[4],h=n[7],u=n[2],d=n[5],p=n[8],m=i[0],f=i[3],g=i[6],v=i[1],y=i[4],x=i[7],_=i[2],w=i[5],b=i[8];return r[0]=s*m+a*v+o*_,r[3]=s*f+a*y+o*w,r[6]=s*g+a*x+o*b,r[1]=l*m+c*v+h*_,r[4]=l*f+c*y+h*w,r[7]=l*g+c*x+h*b,r[2]=u*m+d*v+p*_,r[5]=u*f+d*y+p*w,r[8]=u*g+d*x+p*b,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[3]*=t,e[6]*=t,e[1]*=t,e[4]*=t,e[7]*=t,e[2]*=t,e[5]*=t,e[8]*=t,this}determinant(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8];return e*s*c-e*a*l-n*r*c+n*a*o+i*r*l-i*s*o}invert(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8],h=c*s-a*l,u=a*o-c*r,d=l*r-s*o,p=e*h+n*u+i*d;if(0===p)return this.set(0,0,0,0,0,0,0,0,0);const m=1/p;return t[0]=h*m,t[1]=(i*l-c*n)*m,t[2]=(a*n-i*s)*m,t[3]=u*m,t[4]=(c*e-i*o)*m,t[5]=(i*r-a*e)*m,t[6]=d*m,t[7]=(n*o-l*e)*m,t[8]=(s*e-n*r)*m,this}transpose(){let t;const e=this.elements;return t=e[1],e[1]=e[3],e[3]=t,t=e[2],e[2]=e[6],e[6]=t,t=e[5],e[5]=e[7],e[7]=t,this}getNormalMatrix(t){return this.setFromMatrix4(t).invert().transpose()}transposeIntoArray(t){const e=this.elements;return t[0]=e[0],t[1]=e[3],t[2]=e[6],t[3]=e[1],t[4]=e[4],t[5]=e[7],t[6]=e[2],t[7]=e[5],t[8]=e[8],this}setUvTransform(t,e,n,i,r,s,a){const o=Math.cos(r),l=Math.sin(r);return this.set(n*o,n*l,-n*(o*s+l*a)+s+t,-i*l,i*o,-i*(-l*s+o*a)+a+e,0,0,1),this}scale(t,e){const n=this.elements;return n[0]*=t,n[3]*=t,n[6]*=t,n[1]*=e,n[4]*=e,n[7]*=e,this}rotate(t){const e=Math.cos(t),n=Math.sin(t),i=this.elements,r=i[0],s=i[3],a=i[6],o=i[1],l=i[4],c=i[7];return i[0]=e*r+n*o,i[3]=e*s+n*l,i[6]=e*a+n*c,i[1]=-n*r+e*o,i[4]=-n*s+e*l,i[7]=-n*a+e*c,this}translate(t,e){const n=this.elements;return n[0]+=t*n[2],n[3]+=t*n[5],n[6]+=t*n[8],n[1]+=e*n[2],n[4]+=e*n[5],n[7]+=e*n[8],this}equals(t){const e=this.elements,n=t.elements;for(let t=0;t<9;t++)if(e[t]!==n[t])return!1;return!0}fromArray(t,e=0){for(let n=0;n<9;n++)this.elements[n]=t[n+e];return this}toArray(t=[],e=0){const n=this.elements;return t[e]=n[0],t[e+1]=n[1],t[e+2]=n[2],t[e+3]=n[3],t[e+4]=n[4],t[e+5]=n[5],t[e+6]=n[6],t[e+7]=n[7],t[e+8]=n[8],t}clone(){return(new this.constructor).fromArray(this.elements)}}let xt;yt.prototype.isMatrix3=!0;class _t{static getDataURL(t){if(/^data:/i.test(t.src))return t.src;if("undefined"==typeof HTMLCanvasElement)return t.src;let e;if(t instanceof HTMLCanvasElement)e=t;else{void 0===xt&&(xt=document.createElementNS("http://www.w3.org/1999/xhtml","canvas")),xt.width=t.width,xt.height=t.height;const n=xt.getContext("2d");t instanceof ImageData?n.putImageData(t,0,0):n.drawImage(t,0,0,t.width,t.height),e=xt}return e.width>2048||e.height>2048?(console.warn("THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons",t),e.toDataURL("image/jpeg",.6)):e.toDataURL("image/png")}}let wt=0;class bt extends rt{constructor(t=bt.DEFAULT_IMAGE,e=bt.DEFAULT_MAPPING,n=1001,i=1001,r=1006,s=1008,a=1023,o=1009,l=1,c=3e3){super(),Object.defineProperty(this,"id",{value:wt++}),this.uuid=ct(),this.name="",this.image=t,this.mipmaps=[],this.mapping=e,this.wrapS=n,this.wrapT=i,this.magFilter=r,this.minFilter=s,this.anisotropy=l,this.format=a,this.internalFormat=null,this.type=o,this.offset=new vt(0,0),this.repeat=new vt(1,1),this.center=new vt(0,0),this.rotation=0,this.matrixAutoUpdate=!0,this.matrix=new yt,this.generateMipmaps=!0,this.premultiplyAlpha=!1,this.flipY=!0,this.unpackAlignment=4,this.encoding=c,this.version=0,this.onUpdate=null}updateMatrix(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y)}clone(){return(new this.constructor).copy(this)}copy(t){return this.name=t.name,this.image=t.image,this.mipmaps=t.mipmaps.slice(0),this.mapping=t.mapping,this.wrapS=t.wrapS,this.wrapT=t.wrapT,this.magFilter=t.magFilter,this.minFilter=t.minFilter,this.anisotropy=t.anisotropy,this.format=t.format,this.internalFormat=t.internalFormat,this.type=t.type,this.offset.copy(t.offset),this.repeat.copy(t.repeat),this.center.copy(t.center),this.rotation=t.rotation,this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrix.copy(t.matrix),this.generateMipmaps=t.generateMipmaps,this.premultiplyAlpha=t.premultiplyAlpha,this.flipY=t.flipY,this.unpackAlignment=t.unpackAlignment,this.encoding=t.encoding,this}toJSON(t){const e=void 0===t||"string"==typeof t;if(!e&&void 0!==t.textures[this.uuid])return t.textures[this.uuid];const n={metadata:{version:4.5,type:"Texture",generator:"Texture.toJSON"},uuid:this.uuid,name:this.name,mapping:this.mapping,repeat:[this.repeat.x,this.repeat.y],offset:[this.offset.x,this.offset.y],center:[this.center.x,this.center.y],rotation:this.rotation,wrap:[this.wrapS,this.wrapT],format:this.format,type:this.type,encoding:this.encoding,minFilter:this.minFilter,magFilter:this.magFilter,anisotropy:this.anisotropy,flipY:this.flipY,premultiplyAlpha:this.premultiplyAlpha,unpackAlignment:this.unpackAlignment};if(void 0!==this.image){const i=this.image;if(void 0===i.uuid&&(i.uuid=ct()),!e&&void 0===t.images[i.uuid]){let e;if(Array.isArray(i)){e=[];for(let t=0,n=i.length;t<n;t++)i[t].isDataTexture?e.push(Mt(i[t].image)):e.push(Mt(i[t]))}else e=Mt(i);t.images[i.uuid]={uuid:i.uuid,url:e}}n.image=i.uuid}return e||(t.textures[this.uuid]=n),n}dispose(){this.dispatchEvent({type:"dispose"})}transformUv(t){if(this.mapping!==i)return t;if(t.applyMatrix3(this.matrix),t.x<0||t.x>1)switch(this.wrapS){case h:t.x=t.x-Math.floor(t.x);break;case u:t.x=t.x<0?0:1;break;case d:1===Math.abs(Math.floor(t.x)%2)?t.x=Math.ceil(t.x)-t.x:t.x=t.x-Math.floor(t.x)}if(t.y<0||t.y>1)switch(this.wrapT){case h:t.y=t.y-Math.floor(t.y);break;case u:t.y=t.y<0?0:1;break;case d:1===Math.abs(Math.floor(t.y)%2)?t.y=Math.ceil(t.y)-t.y:t.y=t.y-Math.floor(t.y)}return this.flipY&&(t.y=1-t.y),t}set needsUpdate(t){!0===t&&this.version++}}function Mt(t){return"undefined"!=typeof HTMLImageElement&&t instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&t instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&t instanceof ImageBitmap?_t.getDataURL(t):t.data?{data:Array.prototype.slice.call(t.data),width:t.width,height:t.height,type:t.data.constructor.name}:(console.warn("THREE.Texture: Unable to serialize Texture."),{})}bt.DEFAULT_IMAGE=void 0,bt.DEFAULT_MAPPING=i,bt.prototype.isTexture=!0;class St{constructor(t=0,e=0,n=0,i=1){this.x=t,this.y=e,this.z=n,this.w=i}get width(){return this.z}set width(t){this.z=t}get height(){return this.w}set height(t){this.w=t}set(t,e,n,i){return this.x=t,this.y=e,this.z=n,this.w=i,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this.w=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setW(t){return this.w=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;case 3:this.w=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;case 3:return this.w;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y,this.z,this.w)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z,this.w=void 0!==t.w?t.w:1,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this.z+=t.z,this.w+=t.w,this)}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this.w+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this.w=t.w+e.w,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this.w+=t.w*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this.z-=t.z,this.w-=t.w,this)}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this.w-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this.w=t.w-e.w,this}multiply(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this.w*=t.w,this}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this.w*=t,this}applyMatrix4(t){const e=this.x,n=this.y,i=this.z,r=this.w,s=t.elements;return this.x=s[0]*e+s[4]*n+s[8]*i+s[12]*r,this.y=s[1]*e+s[5]*n+s[9]*i+s[13]*r,this.z=s[2]*e+s[6]*n+s[10]*i+s[14]*r,this.w=s[3]*e+s[7]*n+s[11]*i+s[15]*r,this}divideScalar(t){return this.multiplyScalar(1/t)}setAxisAngleFromQuaternion(t){this.w=2*Math.acos(t.w);const e=Math.sqrt(1-t.w*t.w);return e<1e-4?(this.x=1,this.y=0,this.z=0):(this.x=t.x/e,this.y=t.y/e,this.z=t.z/e),this}setAxisAngleFromRotationMatrix(t){let e,n,i,r;const s=.01,a=.1,o=t.elements,l=o[0],c=o[4],h=o[8],u=o[1],d=o[5],p=o[9],m=o[2],f=o[6],g=o[10];if(Math.abs(c-u)<s&&Math.abs(h-m)<s&&Math.abs(p-f)<s){if(Math.abs(c+u)<a&&Math.abs(h+m)<a&&Math.abs(p+f)<a&&Math.abs(l+d+g-3)<a)return this.set(1,0,0,0),this;e=Math.PI;const t=(l+1)/2,o=(d+1)/2,v=(g+1)/2,y=(c+u)/4,x=(h+m)/4,_=(p+f)/4;return t>o&&t>v?t<s?(n=0,i=.707106781,r=.707106781):(n=Math.sqrt(t),i=y/n,r=x/n):o>v?o<s?(n=.707106781,i=0,r=.707106781):(i=Math.sqrt(o),n=y/i,r=_/i):v<s?(n=.707106781,i=.707106781,r=0):(r=Math.sqrt(v),n=x/r,i=_/r),this.set(n,i,r,e),this}let v=Math.sqrt((f-p)*(f-p)+(h-m)*(h-m)+(u-c)*(u-c));return Math.abs(v)<.001&&(v=1),this.x=(f-p)/v,this.y=(h-m)/v,this.z=(u-c)/v,this.w=Math.acos((l+d+g-1)/2),this}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this.z=Math.min(this.z,t.z),this.w=Math.min(this.w,t.w),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this.z=Math.max(this.z,t.z),this.w=Math.max(this.w,t.w),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this.z=Math.max(t.z,Math.min(e.z,this.z)),this.w=Math.max(t.w,Math.min(e.w,this.w)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this.z=Math.max(t,Math.min(e,this.z)),this.w=Math.max(t,Math.min(e,this.w)),this}clampLength(t,e){const n=this.length();return this.divideScalar(n||1).multiplyScalar(Math.max(t,Math.min(e,n)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this.w=Math.floor(this.w),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this.w=Math.ceil(this.w),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this.w=Math.round(this.w),this}roundToZero(){return this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x),this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y),this.z=this.z<0?Math.ceil(this.z):Math.floor(this.z),this.w=this.w<0?Math.ceil(this.w):Math.floor(this.w),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this.w=-this.w,this}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z+this.w*t.w}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z+this.w*this.w)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)+Math.abs(this.w)}normalize(){return this.divideScalar(this.length()||1)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this.z+=(t.z-this.z)*e,this.w+=(t.w-this.w)*e,this}lerpVectors(t,e,n){return this.x=t.x+(e.x-t.x)*n,this.y=t.y+(e.y-t.y)*n,this.z=t.z+(e.z-t.z)*n,this.w=t.w+(e.w-t.w)*n,this}equals(t){return t.x===this.x&&t.y===this.y&&t.z===this.z&&t.w===this.w}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this.z=t[e+2],this.w=t[e+3],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t[e+3]=this.w,t}fromBufferAttribute(t,e,n){return void 0!==n&&console.warn("THREE.Vector4: offset has been removed from .fromBufferAttribute()."),this.x=t.getX(e),this.y=t.getY(e),this.z=t.getZ(e),this.w=t.getW(e),this}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this.w=Math.random(),this}}St.prototype.isVector4=!0;class Tt extends rt{constructor(t,e,n){super(),this.width=t,this.height=e,this.depth=1,this.scissor=new St(0,0,t,e),this.scissorTest=!1,this.viewport=new St(0,0,t,e),n=n||{},this.texture=new bt(void 0,n.mapping,n.wrapS,n.wrapT,n.magFilter,n.minFilter,n.format,n.type,n.anisotropy,n.encoding),this.texture.image={},this.texture.image.width=t,this.texture.image.height=e,this.texture.image.depth=1,this.texture.generateMipmaps=void 0!==n.generateMipmaps&&n.generateMipmaps,this.texture.minFilter=void 0!==n.minFilter?n.minFilter:g,this.depthBuffer=void 0===n.depthBuffer||n.depthBuffer,this.stencilBuffer=void 0!==n.stencilBuffer&&n.stencilBuffer,this.depthTexture=void 0!==n.depthTexture?n.depthTexture:null}setTexture(t){t.image={width:this.width,height:this.height,depth:this.depth},this.texture=t}setSize(t,e,n=1){this.width===t&&this.height===e&&this.depth===n||(this.width=t,this.height=e,this.depth=n,this.texture.image.width=t,this.texture.image.height=e,this.texture.image.depth=n,this.dispose()),this.viewport.set(0,0,t,e),this.scissor.set(0,0,t,e)}clone(){return(new this.constructor).copy(this)}copy(t){return this.width=t.width,this.height=t.height,this.depth=t.depth,this.viewport.copy(t.viewport),this.texture=t.texture.clone(),this.depthBuffer=t.depthBuffer,this.stencilBuffer=t.stencilBuffer,this.depthTexture=t.depthTexture,this}dispose(){this.dispatchEvent({type:"dispose"})}}Tt.prototype.isWebGLRenderTarget=!0;class Et extends Tt{constructor(t,e,n){super(t,e,n),this.samples=4}copy(t){return super.copy.call(this,t),this.samples=t.samples,this}}Et.prototype.isWebGLMultisampleRenderTarget=!0;class At{constructor(t=0,e=0,n=0,i=1){this._x=t,this._y=e,this._z=n,this._w=i}static slerp(t,e,n,i){return console.warn("THREE.Quaternion: Static .slerp() has been deprecated. Use qm.slerpQuaternions( qa, qb, t ) instead."),n.slerpQuaternions(t,e,i)}static slerpFlat(t,e,n,i,r,s,a){let o=n[i+0],l=n[i+1],c=n[i+2],h=n[i+3];const u=r[s+0],d=r[s+1],p=r[s+2],m=r[s+3];if(0===a)return t[e+0]=o,t[e+1]=l,t[e+2]=c,void(t[e+3]=h);if(1===a)return t[e+0]=u,t[e+1]=d,t[e+2]=p,void(t[e+3]=m);if(h!==m||o!==u||l!==d||c!==p){let t=1-a;const e=o*u+l*d+c*p+h*m,n=e>=0?1:-1,i=1-e*e;if(i>Number.EPSILON){const r=Math.sqrt(i),s=Math.atan2(r,e*n);t=Math.sin(t*s)/r,a=Math.sin(a*s)/r}const r=a*n;if(o=o*t+u*r,l=l*t+d*r,c=c*t+p*r,h=h*t+m*r,t===1-a){const t=1/Math.sqrt(o*o+l*l+c*c+h*h);o*=t,l*=t,c*=t,h*=t}}t[e]=o,t[e+1]=l,t[e+2]=c,t[e+3]=h}static multiplyQuaternionsFlat(t,e,n,i,r,s){const a=n[i],o=n[i+1],l=n[i+2],c=n[i+3],h=r[s],u=r[s+1],d=r[s+2],p=r[s+3];return t[e]=a*p+c*h+o*d-l*u,t[e+1]=o*p+c*u+l*h-a*d,t[e+2]=l*p+c*d+a*u-o*h,t[e+3]=c*p-a*h-o*u-l*d,t}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get w(){return this._w}set w(t){this._w=t,this._onChangeCallback()}set(t,e,n,i){return this._x=t,this._y=e,this._z=n,this._w=i,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._w)}copy(t){return this._x=t.x,this._y=t.y,this._z=t.z,this._w=t.w,this._onChangeCallback(),this}setFromEuler(t,e){if(!t||!t.isEuler)throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.");const n=t._x,i=t._y,r=t._z,s=t._order,a=Math.cos,o=Math.sin,l=a(n/2),c=a(i/2),h=a(r/2),u=o(n/2),d=o(i/2),p=o(r/2);switch(s){case"XYZ":this._x=u*c*h+l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h-u*d*p;break;case"YXZ":this._x=u*c*h+l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h+u*d*p;break;case"ZXY":this._x=u*c*h-l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h-u*d*p;break;case"ZYX":this._x=u*c*h-l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h+u*d*p;break;case"YZX":this._x=u*c*h+l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h-u*d*p;break;case"XZY":this._x=u*c*h-l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h+u*d*p;break;default:console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: "+s)}return!1!==e&&this._onChangeCallback(),this}setFromAxisAngle(t,e){const n=e/2,i=Math.sin(n);return this._x=t.x*i,this._y=t.y*i,this._z=t.z*i,this._w=Math.cos(n),this._onChangeCallback(),this}setFromRotationMatrix(t){const e=t.elements,n=e[0],i=e[4],r=e[8],s=e[1],a=e[5],o=e[9],l=e[2],c=e[6],h=e[10],u=n+a+h;if(u>0){const t=.5/Math.sqrt(u+1);this._w=.25/t,this._x=(c-o)*t,this._y=(r-l)*t,this._z=(s-i)*t}else if(n>a&&n>h){const t=2*Math.sqrt(1+n-a-h);this._w=(c-o)/t,this._x=.25*t,this._y=(i+s)/t,this._z=(r+l)/t}else if(a>h){const t=2*Math.sqrt(1+a-n-h);this._w=(r-l)/t,this._x=(i+s)/t,this._y=.25*t,this._z=(o+c)/t}else{const t=2*Math.sqrt(1+h-n-a);this._w=(s-i)/t,this._x=(r+l)/t,this._y=(o+c)/t,this._z=.25*t}return this._onChangeCallback(),this}setFromUnitVectors(t,e){let n=t.dot(e)+1;return n<Number.EPSILON?(n=0,Math.abs(t.x)>Math.abs(t.z)?(this._x=-t.y,this._y=t.x,this._z=0,this._w=n):(this._x=0,this._y=-t.z,this._z=t.y,this._w=n)):(this._x=t.y*e.z-t.z*e.y,this._y=t.z*e.x-t.x*e.z,this._z=t.x*e.y-t.y*e.x,this._w=n),this.normalize()}angleTo(t){return 2*Math.acos(Math.abs(ht(this.dot(t),-1,1)))}rotateTowards(t,e){const n=this.angleTo(t);if(0===n)return this;const i=Math.min(1,e/n);return this.slerp(t,i),this}identity(){return this.set(0,0,0,1)}invert(){return this.conjugate()}conjugate(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}dot(t){return this._x*t._x+this._y*t._y+this._z*t._z+this._w*t._w}lengthSq(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}length(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}normalize(){let t=this.length();return 0===t?(this._x=0,this._y=0,this._z=0,this._w=1):(t=1/t,this._x=this._x*t,this._y=this._y*t,this._z=this._z*t,this._w=this._w*t),this._onChangeCallback(),this}multiply(t,e){return void 0!==e?(console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."),this.multiplyQuaternions(t,e)):this.multiplyQuaternions(this,t)}premultiply(t){return this.multiplyQuaternions(t,this)}multiplyQuaternions(t,e){const n=t._x,i=t._y,r=t._z,s=t._w,a=e._x,o=e._y,l=e._z,c=e._w;return this._x=n*c+s*a+i*l-r*o,this._y=i*c+s*o+r*a-n*l,this._z=r*c+s*l+n*o-i*a,this._w=s*c-n*a-i*o-r*l,this._onChangeCallback(),this}slerp(t,e){if(0===e)return this;if(1===e)return this.copy(t);const n=this._x,i=this._y,r=this._z,s=this._w;let a=s*t._w+n*t._x+i*t._y+r*t._z;if(a<0?(this._w=-t._w,this._x=-t._x,this._y=-t._y,this._z=-t._z,a=-a):this.copy(t),a>=1)return this._w=s,this._x=n,this._y=i,this._z=r,this;const o=1-a*a;if(o<=Number.EPSILON){const t=1-e;return this._w=t*s+e*this._w,this._x=t*n+e*this._x,this._y=t*i+e*this._y,this._z=t*r+e*this._z,this.normalize(),this._onChangeCallback(),this}const l=Math.sqrt(o),c=Math.atan2(l,a),h=Math.sin((1-e)*c)/l,u=Math.sin(e*c)/l;return this._w=s*h+this._w*u,this._x=n*h+this._x*u,this._y=i*h+this._y*u,this._z=r*h+this._z*u,this._onChangeCallback(),this}slerpQuaternions(t,e,n){this.copy(t).slerp(e,n)}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._w===this._w}fromArray(t,e=0){return this._x=t[e],this._y=t[e+1],this._z=t[e+2],this._w=t[e+3],this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._w,t}fromBufferAttribute(t,e){return this._x=t.getX(e),this._y=t.getY(e),this._z=t.getZ(e),this._w=t.getW(e),this}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}}At.prototype.isQuaternion=!0;class Lt{constructor(t=0,e=0,n=0){this.x=t,this.y=e,this.z=n}set(t,e,n){return void 0===n&&(n=this.z),this.x=t,this.y=e,this.z=n,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y,this.z)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this.z+=t.z,this)}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this.z-=t.z,this)}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this}multiply(t,e){return void 0!==e?(console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."),this.multiplyVectors(t,e)):(this.x*=t.x,this.y*=t.y,this.z*=t.z,this)}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this}multiplyVectors(t,e){return this.x=t.x*e.x,this.y=t.y*e.y,this.z=t.z*e.z,this}applyEuler(t){return t&&t.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."),this.applyQuaternion(Ct.setFromEuler(t))}applyAxisAngle(t,e){return this.applyQuaternion(Ct.setFromAxisAngle(t,e))}applyMatrix3(t){const e=this.x,n=this.y,i=this.z,r=t.elements;return this.x=r[0]*e+r[3]*n+r[6]*i,this.y=r[1]*e+r[4]*n+r[7]*i,this.z=r[2]*e+r[5]*n+r[8]*i,this}applyNormalMatrix(t){return this.applyMatrix3(t).normalize()}applyMatrix4(t){const e=this.x,n=this.y,i=this.z,r=t.elements,s=1/(r[3]*e+r[7]*n+r[11]*i+r[15]);return this.x=(r[0]*e+r[4]*n+r[8]*i+r[12])*s,this.y=(r[1]*e+r[5]*n+r[9]*i+r[13])*s,this.z=(r[2]*e+r[6]*n+r[10]*i+r[14])*s,this}applyQuaternion(t){const e=this.x,n=this.y,i=this.z,r=t.x,s=t.y,a=t.z,o=t.w,l=o*e+s*i-a*n,c=o*n+a*e-r*i,h=o*i+r*n-s*e,u=-r*e-s*n-a*i;return this.x=l*o+u*-r+c*-a-h*-s,this.y=c*o+u*-s+h*-r-l*-a,this.z=h*o+u*-a+l*-s-c*-r,this}project(t){return this.applyMatrix4(t.matrixWorldInverse).applyMatrix4(t.projectionMatrix)}unproject(t){return this.applyMatrix4(t.projectionMatrixInverse).applyMatrix4(t.matrixWorld)}transformDirection(t){const e=this.x,n=this.y,i=this.z,r=t.elements;return this.x=r[0]*e+r[4]*n+r[8]*i,this.y=r[1]*e+r[5]*n+r[9]*i,this.z=r[2]*e+r[6]*n+r[10]*i,this.normalize()}divide(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this}divideScalar(t){return this.multiplyScalar(1/t)}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this.z=Math.min(this.z,t.z),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this.z=Math.max(this.z,t.z),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this.z=Math.max(t.z,Math.min(e.z,this.z)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this.z=Math.max(t,Math.min(e,this.z)),this}clampLength(t,e){const n=this.length();return this.divideScalar(n||1).multiplyScalar(Math.max(t,Math.min(e,n)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}roundToZero(){return this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x),this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y),this.z=this.z<0?Math.ceil(this.z):Math.floor(this.z),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}normalize(){return this.divideScalar(this.length()||1)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this.z+=(t.z-this.z)*e,this}lerpVectors(t,e,n){return this.x=t.x+(e.x-t.x)*n,this.y=t.y+(e.y-t.y)*n,this.z=t.z+(e.z-t.z)*n,this}cross(t,e){return void 0!==e?(console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."),this.crossVectors(t,e)):this.crossVectors(this,t)}crossVectors(t,e){const n=t.x,i=t.y,r=t.z,s=e.x,a=e.y,o=e.z;return this.x=i*o-r*a,this.y=r*s-n*o,this.z=n*a-i*s,this}projectOnVector(t){const e=t.lengthSq();if(0===e)return this.set(0,0,0);const n=t.dot(this)/e;return this.copy(t).multiplyScalar(n)}projectOnPlane(t){return Rt.copy(this).projectOnVector(t),this.sub(Rt)}reflect(t){return this.sub(Rt.copy(t).multiplyScalar(2*this.dot(t)))}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(0===e)return Math.PI/2;const n=this.dot(t)/e;return Math.acos(ht(n,-1,1))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,n=this.y-t.y,i=this.z-t.z;return e*e+n*n+i*i}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)+Math.abs(this.z-t.z)}setFromSpherical(t){return this.setFromSphericalCoords(t.radius,t.phi,t.theta)}setFromSphericalCoords(t,e,n){const i=Math.sin(e)*t;return this.x=i*Math.sin(n),this.y=Math.cos(e)*t,this.z=i*Math.cos(n),this}setFromCylindrical(t){return this.setFromCylindricalCoords(t.radius,t.theta,t.y)}setFromCylindricalCoords(t,e,n){return this.x=t*Math.sin(e),this.y=n,this.z=t*Math.cos(e),this}setFromMatrixPosition(t){const e=t.elements;return this.x=e[12],this.y=e[13],this.z=e[14],this}setFromMatrixScale(t){const e=this.setFromMatrixColumn(t,0).length(),n=this.setFromMatrixColumn(t,1).length(),i=this.setFromMatrixColumn(t,2).length();return this.x=e,this.y=n,this.z=i,this}setFromMatrixColumn(t,e){return this.fromArray(t.elements,4*e)}setFromMatrix3Column(t,e){return this.fromArray(t.elements,3*e)}equals(t){return t.x===this.x&&t.y===this.y&&t.z===this.z}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this.z=t[e+2],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t}fromBufferAttribute(t,e,n){return void 0!==n&&console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute()."),this.x=t.getX(e),this.y=t.getY(e),this.z=t.getZ(e),this}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}}Lt.prototype.isVector3=!0;const Rt=new Lt,Ct=new At;class Pt{constructor(t=new Lt(1/0,1/0,1/0),e=new Lt(-1/0,-1/0,-1/0)){this.min=t,this.max=e}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromArray(t){let e=1/0,n=1/0,i=1/0,r=-1/0,s=-1/0,a=-1/0;for(let o=0,l=t.length;o<l;o+=3){const l=t[o],c=t[o+1],h=t[o+2];l<e&&(e=l),c<n&&(n=c),h<i&&(i=h),l>r&&(r=l),c>s&&(s=c),h>a&&(a=h)}return this.min.set(e,n,i),this.max.set(r,s,a),this}setFromBufferAttribute(t){let e=1/0,n=1/0,i=1/0,r=-1/0,s=-1/0,a=-1/0;for(let o=0,l=t.count;o<l;o++){const l=t.getX(o),c=t.getY(o),h=t.getZ(o);l<e&&(e=l),c<n&&(n=c),h<i&&(i=h),l>r&&(r=l),c>s&&(s=c),h>a&&(a=h)}return this.min.set(e,n,i),this.max.set(r,s,a),this}setFromPoints(t){this.makeEmpty();for(let e=0,n=t.length;e<n;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const n=It.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(n),this.max.copy(t).add(n),this}setFromObject(t){return this.makeEmpty(),this.expandByObject(t)}clone(){return(new this.constructor).copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=this.min.z=1/0,this.max.x=this.max.y=this.max.z=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y||this.max.z<this.min.z}getCenter(t){return void 0===t&&(console.warn("THREE.Box3: .getCenter() target is now required"),t=new Lt),this.isEmpty()?t.set(0,0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return void 0===t&&(console.warn("THREE.Box3: .getSize() target is now required"),t=new Lt),this.isEmpty()?t.set(0,0,0):t.subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}expandByObject(t){t.updateWorldMatrix(!1,!1);const e=t.geometry;void 0!==e&&(null===e.boundingBox&&e.computeBoundingBox(),Nt.copy(e.boundingBox),Nt.applyMatrix4(t.matrixWorld),this.union(Nt));const n=t.children;for(let t=0,e=n.length;t<e;t++)this.expandByObject(n[t]);return this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y||t.z<this.min.z||t.z>this.max.z)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y&&this.min.z<=t.min.z&&t.max.z<=this.max.z}getParameter(t,e){return void 0===e&&(console.warn("THREE.Box3: .getParameter() target is now required"),e=new Lt),e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y),(t.z-this.min.z)/(this.max.z-this.min.z))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y||t.max.z<this.min.z||t.min.z>this.max.z)}intersectsSphere(t){return this.clampPoint(t.center,It),It.distanceToSquared(t.center)<=t.radius*t.radius}intersectsPlane(t){let e,n;return t.normal.x>0?(e=t.normal.x*this.min.x,n=t.normal.x*this.max.x):(e=t.normal.x*this.max.x,n=t.normal.x*this.min.x),t.normal.y>0?(e+=t.normal.y*this.min.y,n+=t.normal.y*this.max.y):(e+=t.normal.y*this.max.y,n+=t.normal.y*this.min.y),t.normal.z>0?(e+=t.normal.z*this.min.z,n+=t.normal.z*this.max.z):(e+=t.normal.z*this.max.z,n+=t.normal.z*this.min.z),e<=-t.constant&&n>=-t.constant}intersectsTriangle(t){if(this.isEmpty())return!1;this.getCenter(Ut),kt.subVectors(this.max,Ut),Bt.subVectors(t.a,Ut),zt.subVectors(t.b,Ut),Ft.subVectors(t.c,Ut),Ot.subVectors(zt,Bt),Ht.subVectors(Ft,zt),Gt.subVectors(Bt,Ft);let e=[0,-Ot.z,Ot.y,0,-Ht.z,Ht.y,0,-Gt.z,Gt.y,Ot.z,0,-Ot.x,Ht.z,0,-Ht.x,Gt.z,0,-Gt.x,-Ot.y,Ot.x,0,-Ht.y,Ht.x,0,-Gt.y,Gt.x,0];return!!jt(e,Bt,zt,Ft,kt)&&(e=[1,0,0,0,1,0,0,0,1],!!jt(e,Bt,zt,Ft,kt)&&(Vt.crossVectors(Ot,Ht),e=[Vt.x,Vt.y,Vt.z],jt(e,Bt,zt,Ft,kt)))}clampPoint(t,e){return void 0===e&&(console.warn("THREE.Box3: .clampPoint() target is now required"),e=new Lt),e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return It.copy(t).clamp(this.min,this.max).sub(t).length()}getBoundingSphere(t){return void 0===t&&console.error("THREE.Box3: .getBoundingSphere() target is now required"),this.getCenter(t.center),t.radius=.5*this.getSize(It).length(),t}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}applyMatrix4(t){return this.isEmpty()||(Dt[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(t),Dt[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(t),Dt[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(t),Dt[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(t),Dt[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(t),Dt[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(t),Dt[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(t),Dt[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(t),this.setFromPoints(Dt)),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}}Pt.prototype.isBox3=!0;const Dt=[new Lt,new Lt,new Lt,new Lt,new Lt,new Lt,new Lt,new Lt],It=new Lt,Nt=new Pt,Bt=new Lt,zt=new Lt,Ft=new Lt,Ot=new Lt,Ht=new Lt,Gt=new Lt,Ut=new Lt,kt=new Lt,Vt=new Lt,Wt=new Lt;function jt(t,e,n,i,r){for(let s=0,a=t.length-3;s<=a;s+=3){Wt.fromArray(t,s);const a=r.x*Math.abs(Wt.x)+r.y*Math.abs(Wt.y)+r.z*Math.abs(Wt.z),o=e.dot(Wt),l=n.dot(Wt),c=i.dot(Wt);if(Math.max(-Math.max(o,l,c),Math.min(o,l,c))>a)return!1}return!0}const qt=new Pt,Xt=new Lt,Yt=new Lt,Zt=new Lt;class Jt{constructor(t=new Lt,e=-1){this.center=t,this.radius=e}set(t,e){return this.center.copy(t),this.radius=e,this}setFromPoints(t,e){const n=this.center;void 0!==e?n.copy(e):qt.setFromPoints(t).getCenter(n);let i=0;for(let e=0,r=t.length;e<r;e++)i=Math.max(i,n.distanceToSquared(t[e]));return this.radius=Math.sqrt(i),this}copy(t){return this.center.copy(t.center),this.radius=t.radius,this}isEmpty(){return this.radius<0}makeEmpty(){return this.center.set(0,0,0),this.radius=-1,this}containsPoint(t){return t.distanceToSquared(this.center)<=this.radius*this.radius}distanceToPoint(t){return t.distanceTo(this.center)-this.radius}intersectsSphere(t){const e=this.radius+t.radius;return t.center.distanceToSquared(this.center)<=e*e}intersectsBox(t){return t.intersectsSphere(this)}intersectsPlane(t){return Math.abs(t.distanceToPoint(this.center))<=this.radius}clampPoint(t,e){const n=this.center.distanceToSquared(t);return void 0===e&&(console.warn("THREE.Sphere: .clampPoint() target is now required"),e=new Lt),e.copy(t),n>this.radius*this.radius&&(e.sub(this.center).normalize(),e.multiplyScalar(this.radius).add(this.center)),e}getBoundingBox(t){return void 0===t&&(console.warn("THREE.Sphere: .getBoundingBox() target is now required"),t=new Pt),this.isEmpty()?(t.makeEmpty(),t):(t.set(this.center,this.center),t.expandByScalar(this.radius),t)}applyMatrix4(t){return this.center.applyMatrix4(t),this.radius=this.radius*t.getMaxScaleOnAxis(),this}translate(t){return this.center.add(t),this}expandByPoint(t){Zt.subVectors(t,this.center);const e=Zt.lengthSq();if(e>this.radius*this.radius){const t=Math.sqrt(e),n=.5*(t-this.radius);this.center.add(Zt.multiplyScalar(n/t)),this.radius+=n}return this}union(t){return Yt.subVectors(t.center,this.center).normalize().multiplyScalar(t.radius),this.expandByPoint(Xt.copy(t.center).add(Yt)),this.expandByPoint(Xt.copy(t.center).sub(Yt)),this}equals(t){return t.center.equals(this.center)&&t.radius===this.radius}clone(){return(new this.constructor).copy(this)}}const Qt=new Lt,Kt=new Lt,$t=new Lt,te=new Lt,ee=new Lt,ne=new Lt,ie=new Lt;class re{constructor(t=new Lt,e=new Lt(0,0,-1)){this.origin=t,this.direction=e}set(t,e){return this.origin.copy(t),this.direction.copy(e),this}copy(t){return this.origin.copy(t.origin),this.direction.copy(t.direction),this}at(t,e){return void 0===e&&(console.warn("THREE.Ray: .at() target is now required"),e=new Lt),e.copy(this.direction).multiplyScalar(t).add(this.origin)}lookAt(t){return this.direction.copy(t).sub(this.origin).normalize(),this}recast(t){return this.origin.copy(this.at(t,Qt)),this}closestPointToPoint(t,e){void 0===e&&(console.warn("THREE.Ray: .closestPointToPoint() target is now required"),e=new Lt),e.subVectors(t,this.origin);const n=e.dot(this.direction);return n<0?e.copy(this.origin):e.copy(this.direction).multiplyScalar(n).add(this.origin)}distanceToPoint(t){return Math.sqrt(this.distanceSqToPoint(t))}distanceSqToPoint(t){const e=Qt.subVectors(t,this.origin).dot(this.direction);return e<0?this.origin.distanceToSquared(t):(Qt.copy(this.direction).multiplyScalar(e).add(this.origin),Qt.distanceToSquared(t))}distanceSqToSegment(t,e,n,i){Kt.copy(t).add(e).multiplyScalar(.5),$t.copy(e).sub(t).normalize(),te.copy(this.origin).sub(Kt);const r=.5*t.distanceTo(e),s=-this.direction.dot($t),a=te.dot(this.direction),o=-te.dot($t),l=te.lengthSq(),c=Math.abs(1-s*s);let h,u,d,p;if(c>0)if(h=s*o-a,u=s*a-o,p=r*c,h>=0)if(u>=-p)if(u<=p){const t=1/c;h*=t,u*=t,d=h*(h+s*u+2*a)+u*(s*h+u+2*o)+l}else u=r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;else u=-r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;else u<=-p?(h=Math.max(0,-(-s*r+a)),u=h>0?-r:Math.min(Math.max(-r,-o),r),d=-h*h+u*(u+2*o)+l):u<=p?(h=0,u=Math.min(Math.max(-r,-o),r),d=u*(u+2*o)+l):(h=Math.max(0,-(s*r+a)),u=h>0?r:Math.min(Math.max(-r,-o),r),d=-h*h+u*(u+2*o)+l);else u=s>0?-r:r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;return n&&n.copy(this.direction).multiplyScalar(h).add(this.origin),i&&i.copy($t).multiplyScalar(u).add(Kt),d}intersectSphere(t,e){Qt.subVectors(t.center,this.origin);const n=Qt.dot(this.direction),i=Qt.dot(Qt)-n*n,r=t.radius*t.radius;if(i>r)return null;const s=Math.sqrt(r-i),a=n-s,o=n+s;return a<0&&o<0?null:a<0?this.at(o,e):this.at(a,e)}intersectsSphere(t){return this.distanceSqToPoint(t.center)<=t.radius*t.radius}distanceToPlane(t){const e=t.normal.dot(this.direction);if(0===e)return 0===t.distanceToPoint(this.origin)?0:null;const n=-(this.origin.dot(t.normal)+t.constant)/e;return n>=0?n:null}intersectPlane(t,e){const n=this.distanceToPlane(t);return null===n?null:this.at(n,e)}intersectsPlane(t){const e=t.distanceToPoint(this.origin);if(0===e)return!0;return t.normal.dot(this.direction)*e<0}intersectBox(t,e){let n,i,r,s,a,o;const l=1/this.direction.x,c=1/this.direction.y,h=1/this.direction.z,u=this.origin;return l>=0?(n=(t.min.x-u.x)*l,i=(t.max.x-u.x)*l):(n=(t.max.x-u.x)*l,i=(t.min.x-u.x)*l),c>=0?(r=(t.min.y-u.y)*c,s=(t.max.y-u.y)*c):(r=(t.max.y-u.y)*c,s=(t.min.y-u.y)*c),n>s||r>i?null:((r>n||n!=n)&&(n=r),(s<i||i!=i)&&(i=s),h>=0?(a=(t.min.z-u.z)*h,o=(t.max.z-u.z)*h):(a=(t.max.z-u.z)*h,o=(t.min.z-u.z)*h),n>o||a>i?null:((a>n||n!=n)&&(n=a),(o<i||i!=i)&&(i=o),i<0?null:this.at(n>=0?n:i,e)))}intersectsBox(t){return null!==this.intersectBox(t,Qt)}intersectTriangle(t,e,n,i,r){ee.subVectors(e,t),ne.subVectors(n,t),ie.crossVectors(ee,ne);let s,a=this.direction.dot(ie);if(a>0){if(i)return null;s=1}else{if(!(a<0))return null;s=-1,a=-a}te.subVectors(this.origin,t);const o=s*this.direction.dot(ne.crossVectors(te,ne));if(o<0)return null;const l=s*this.direction.dot(ee.cross(te));if(l<0)return null;if(o+l>a)return null;const c=-s*te.dot(ie);return c<0?null:this.at(c/a,r)}applyMatrix4(t){return this.origin.applyMatrix4(t),this.direction.transformDirection(t),this}equals(t){return t.origin.equals(this.origin)&&t.direction.equals(this.direction)}clone(){return(new this.constructor).copy(this)}}class se{constructor(){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],arguments.length>0&&console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.")}set(t,e,n,i,r,s,a,o,l,c,h,u,d,p,m,f){const g=this.elements;return g[0]=t,g[4]=e,g[8]=n,g[12]=i,g[1]=r,g[5]=s,g[9]=a,g[13]=o,g[2]=l,g[6]=c,g[10]=h,g[14]=u,g[3]=d,g[7]=p,g[11]=m,g[15]=f,this}identity(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}clone(){return(new se).fromArray(this.elements)}copy(t){const e=this.elements,n=t.elements;return e[0]=n[0],e[1]=n[1],e[2]=n[2],e[3]=n[3],e[4]=n[4],e[5]=n[5],e[6]=n[6],e[7]=n[7],e[8]=n[8],e[9]=n[9],e[10]=n[10],e[11]=n[11],e[12]=n[12],e[13]=n[13],e[14]=n[14],e[15]=n[15],this}copyPosition(t){const e=this.elements,n=t.elements;return e[12]=n[12],e[13]=n[13],e[14]=n[14],this}setFromMatrix3(t){const e=t.elements;return this.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1),this}extractBasis(t,e,n){return t.setFromMatrixColumn(this,0),e.setFromMatrixColumn(this,1),n.setFromMatrixColumn(this,2),this}makeBasis(t,e,n){return this.set(t.x,e.x,n.x,0,t.y,e.y,n.y,0,t.z,e.z,n.z,0,0,0,0,1),this}extractRotation(t){const e=this.elements,n=t.elements,i=1/ae.setFromMatrixColumn(t,0).length(),r=1/ae.setFromMatrixColumn(t,1).length(),s=1/ae.setFromMatrixColumn(t,2).length();return e[0]=n[0]*i,e[1]=n[1]*i,e[2]=n[2]*i,e[3]=0,e[4]=n[4]*r,e[5]=n[5]*r,e[6]=n[6]*r,e[7]=0,e[8]=n[8]*s,e[9]=n[9]*s,e[10]=n[10]*s,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromEuler(t){t&&t.isEuler||console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.");const e=this.elements,n=t.x,i=t.y,r=t.z,s=Math.cos(n),a=Math.sin(n),o=Math.cos(i),l=Math.sin(i),c=Math.cos(r),h=Math.sin(r);if("XYZ"===t.order){const t=s*c,n=s*h,i=a*c,r=a*h;e[0]=o*c,e[4]=-o*h,e[8]=l,e[1]=n+i*l,e[5]=t-r*l,e[9]=-a*o,e[2]=r-t*l,e[6]=i+n*l,e[10]=s*o}else if("YXZ"===t.order){const t=o*c,n=o*h,i=l*c,r=l*h;e[0]=t+r*a,e[4]=i*a-n,e[8]=s*l,e[1]=s*h,e[5]=s*c,e[9]=-a,e[2]=n*a-i,e[6]=r+t*a,e[10]=s*o}else if("ZXY"===t.order){const t=o*c,n=o*h,i=l*c,r=l*h;e[0]=t-r*a,e[4]=-s*h,e[8]=i+n*a,e[1]=n+i*a,e[5]=s*c,e[9]=r-t*a,e[2]=-s*l,e[6]=a,e[10]=s*o}else if("ZYX"===t.order){const t=s*c,n=s*h,i=a*c,r=a*h;e[0]=o*c,e[4]=i*l-n,e[8]=t*l+r,e[1]=o*h,e[5]=r*l+t,e[9]=n*l-i,e[2]=-l,e[6]=a*o,e[10]=s*o}else if("YZX"===t.order){const t=s*o,n=s*l,i=a*o,r=a*l;e[0]=o*c,e[4]=r-t*h,e[8]=i*h+n,e[1]=h,e[5]=s*c,e[9]=-a*c,e[2]=-l*c,e[6]=n*h+i,e[10]=t-r*h}else if("XZY"===t.order){const t=s*o,n=s*l,i=a*o,r=a*l;e[0]=o*c,e[4]=-h,e[8]=l*c,e[1]=t*h+r,e[5]=s*c,e[9]=n*h-i,e[2]=i*h-n,e[6]=a*c,e[10]=r*h+t}return e[3]=0,e[7]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromQuaternion(t){return this.compose(le,t,ce)}lookAt(t,e,n){const i=this.elements;return de.subVectors(t,e),0===de.lengthSq()&&(de.z=1),de.normalize(),he.crossVectors(n,de),0===he.lengthSq()&&(1===Math.abs(n.z)?de.x+=1e-4:de.z+=1e-4,de.normalize(),he.crossVectors(n,de)),he.normalize(),ue.crossVectors(de,he),i[0]=he.x,i[4]=ue.x,i[8]=de.x,i[1]=he.y,i[5]=ue.y,i[9]=de.y,i[2]=he.z,i[6]=ue.z,i[10]=de.z,this}multiply(t,e){return void 0!==e?(console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."),this.multiplyMatrices(t,e)):this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const n=t.elements,i=e.elements,r=this.elements,s=n[0],a=n[4],o=n[8],l=n[12],c=n[1],h=n[5],u=n[9],d=n[13],p=n[2],m=n[6],f=n[10],g=n[14],v=n[3],y=n[7],x=n[11],_=n[15],w=i[0],b=i[4],M=i[8],S=i[12],T=i[1],E=i[5],A=i[9],L=i[13],R=i[2],C=i[6],P=i[10],D=i[14],I=i[3],N=i[7],B=i[11],z=i[15];return r[0]=s*w+a*T+o*R+l*I,r[4]=s*b+a*E+o*C+l*N,r[8]=s*M+a*A+o*P+l*B,r[12]=s*S+a*L+o*D+l*z,r[1]=c*w+h*T+u*R+d*I,r[5]=c*b+h*E+u*C+d*N,r[9]=c*M+h*A+u*P+d*B,r[13]=c*S+h*L+u*D+d*z,r[2]=p*w+m*T+f*R+g*I,r[6]=p*b+m*E+f*C+g*N,r[10]=p*M+m*A+f*P+g*B,r[14]=p*S+m*L+f*D+g*z,r[3]=v*w+y*T+x*R+_*I,r[7]=v*b+y*E+x*C+_*N,r[11]=v*M+y*A+x*P+_*B,r[15]=v*S+y*L+x*D+_*z,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[4]*=t,e[8]*=t,e[12]*=t,e[1]*=t,e[5]*=t,e[9]*=t,e[13]*=t,e[2]*=t,e[6]*=t,e[10]*=t,e[14]*=t,e[3]*=t,e[7]*=t,e[11]*=t,e[15]*=t,this}determinant(){const t=this.elements,e=t[0],n=t[4],i=t[8],r=t[12],s=t[1],a=t[5],o=t[9],l=t[13],c=t[2],h=t[6],u=t[10],d=t[14];return t[3]*(+r*o*h-i*l*h-r*a*u+n*l*u+i*a*d-n*o*d)+t[7]*(+e*o*d-e*l*u+r*s*u-i*s*d+i*l*c-r*o*c)+t[11]*(+e*l*h-e*a*d-r*s*h+n*s*d+r*a*c-n*l*c)+t[15]*(-i*a*c-e*o*h+e*a*u+i*s*h-n*s*u+n*o*c)}transpose(){const t=this.elements;let e;return e=t[1],t[1]=t[4],t[4]=e,e=t[2],t[2]=t[8],t[8]=e,e=t[6],t[6]=t[9],t[9]=e,e=t[3],t[3]=t[12],t[12]=e,e=t[7],t[7]=t[13],t[13]=e,e=t[11],t[11]=t[14],t[14]=e,this}setPosition(t,e,n){const i=this.elements;return t.isVector3?(i[12]=t.x,i[13]=t.y,i[14]=t.z):(i[12]=t,i[13]=e,i[14]=n),this}invert(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8],h=t[9],u=t[10],d=t[11],p=t[12],m=t[13],f=t[14],g=t[15],v=h*f*l-m*u*l+m*o*d-a*f*d-h*o*g+a*u*g,y=p*u*l-c*f*l-p*o*d+s*f*d+c*o*g-s*u*g,x=c*m*l-p*h*l+p*a*d-s*m*d-c*a*g+s*h*g,_=p*h*o-c*m*o-p*a*u+s*m*u+c*a*f-s*h*f,w=e*v+n*y+i*x+r*_;if(0===w)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);const b=1/w;return t[0]=v*b,t[1]=(m*u*r-h*f*r-m*i*d+n*f*d+h*i*g-n*u*g)*b,t[2]=(a*f*r-m*o*r+m*i*l-n*f*l-a*i*g+n*o*g)*b,t[3]=(h*o*r-a*u*r-h*i*l+n*u*l+a*i*d-n*o*d)*b,t[4]=y*b,t[5]=(c*f*r-p*u*r+p*i*d-e*f*d-c*i*g+e*u*g)*b,t[6]=(p*o*r-s*f*r-p*i*l+e*f*l+s*i*g-e*o*g)*b,t[7]=(s*u*r-c*o*r+c*i*l-e*u*l-s*i*d+e*o*d)*b,t[8]=x*b,t[9]=(p*h*r-c*m*r-p*n*d+e*m*d+c*n*g-e*h*g)*b,t[10]=(s*m*r-p*a*r+p*n*l-e*m*l-s*n*g+e*a*g)*b,t[11]=(c*a*r-s*h*r-c*n*l+e*h*l+s*n*d-e*a*d)*b,t[12]=_*b,t[13]=(c*m*i-p*h*i+p*n*u-e*m*u-c*n*f+e*h*f)*b,t[14]=(p*a*i-s*m*i-p*n*o+e*m*o+s*n*f-e*a*f)*b,t[15]=(s*h*i-c*a*i+c*n*o-e*h*o-s*n*u+e*a*u)*b,this}scale(t){const e=this.elements,n=t.x,i=t.y,r=t.z;return e[0]*=n,e[4]*=i,e[8]*=r,e[1]*=n,e[5]*=i,e[9]*=r,e[2]*=n,e[6]*=i,e[10]*=r,e[3]*=n,e[7]*=i,e[11]*=r,this}getMaxScaleOnAxis(){const t=this.elements,e=t[0]*t[0]+t[1]*t[1]+t[2]*t[2],n=t[4]*t[4]+t[5]*t[5]+t[6]*t[6],i=t[8]*t[8]+t[9]*t[9]+t[10]*t[10];return Math.sqrt(Math.max(e,n,i))}makeTranslation(t,e,n){return this.set(1,0,0,t,0,1,0,e,0,0,1,n,0,0,0,1),this}makeRotationX(t){const e=Math.cos(t),n=Math.sin(t);return this.set(1,0,0,0,0,e,-n,0,0,n,e,0,0,0,0,1),this}makeRotationY(t){const e=Math.cos(t),n=Math.sin(t);return this.set(e,0,n,0,0,1,0,0,-n,0,e,0,0,0,0,1),this}makeRotationZ(t){const e=Math.cos(t),n=Math.sin(t);return this.set(e,-n,0,0,n,e,0,0,0,0,1,0,0,0,0,1),this}makeRotationAxis(t,e){const n=Math.cos(e),i=Math.sin(e),r=1-n,s=t.x,a=t.y,o=t.z,l=r*s,c=r*a;return this.set(l*s+n,l*a-i*o,l*o+i*a,0,l*a+i*o,c*a+n,c*o-i*s,0,l*o-i*a,c*o+i*s,r*o*o+n,0,0,0,0,1),this}makeScale(t,e,n){return this.set(t,0,0,0,0,e,0,0,0,0,n,0,0,0,0,1),this}makeShear(t,e,n){return this.set(1,e,n,0,t,1,n,0,t,e,1,0,0,0,0,1),this}compose(t,e,n){const i=this.elements,r=e._x,s=e._y,a=e._z,o=e._w,l=r+r,c=s+s,h=a+a,u=r*l,d=r*c,p=r*h,m=s*c,f=s*h,g=a*h,v=o*l,y=o*c,x=o*h,_=n.x,w=n.y,b=n.z;return i[0]=(1-(m+g))*_,i[1]=(d+x)*_,i[2]=(p-y)*_,i[3]=0,i[4]=(d-x)*w,i[5]=(1-(u+g))*w,i[6]=(f+v)*w,i[7]=0,i[8]=(p+y)*b,i[9]=(f-v)*b,i[10]=(1-(u+m))*b,i[11]=0,i[12]=t.x,i[13]=t.y,i[14]=t.z,i[15]=1,this}decompose(t,e,n){const i=this.elements;let r=ae.set(i[0],i[1],i[2]).length();const s=ae.set(i[4],i[5],i[6]).length(),a=ae.set(i[8],i[9],i[10]).length();this.determinant()<0&&(r=-r),t.x=i[12],t.y=i[13],t.z=i[14],oe.copy(this);const o=1/r,l=1/s,c=1/a;return oe.elements[0]*=o,oe.elements[1]*=o,oe.elements[2]*=o,oe.elements[4]*=l,oe.elements[5]*=l,oe.elements[6]*=l,oe.elements[8]*=c,oe.elements[9]*=c,oe.elements[10]*=c,e.setFromRotationMatrix(oe),n.x=r,n.y=s,n.z=a,this}makePerspective(t,e,n,i,r,s){void 0===s&&console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.");const a=this.elements,o=2*r/(e-t),l=2*r/(n-i),c=(e+t)/(e-t),h=(n+i)/(n-i),u=-(s+r)/(s-r),d=-2*s*r/(s-r);return a[0]=o,a[4]=0,a[8]=c,a[12]=0,a[1]=0,a[5]=l,a[9]=h,a[13]=0,a[2]=0,a[6]=0,a[10]=u,a[14]=d,a[3]=0,a[7]=0,a[11]=-1,a[15]=0,this}makeOrthographic(t,e,n,i,r,s){const a=this.elements,o=1/(e-t),l=1/(n-i),c=1/(s-r),h=(e+t)*o,u=(n+i)*l,d=(s+r)*c;return a[0]=2*o,a[4]=0,a[8]=0,a[12]=-h,a[1]=0,a[5]=2*l,a[9]=0,a[13]=-u,a[2]=0,a[6]=0,a[10]=-2*c,a[14]=-d,a[3]=0,a[7]=0,a[11]=0,a[15]=1,this}equals(t){const e=this.elements,n=t.elements;for(let t=0;t<16;t++)if(e[t]!==n[t])return!1;return!0}fromArray(t,e=0){for(let n=0;n<16;n++)this.elements[n]=t[n+e];return this}toArray(t=[],e=0){const n=this.elements;return t[e]=n[0],t[e+1]=n[1],t[e+2]=n[2],t[e+3]=n[3],t[e+4]=n[4],t[e+5]=n[5],t[e+6]=n[6],t[e+7]=n[7],t[e+8]=n[8],t[e+9]=n[9],t[e+10]=n[10],t[e+11]=n[11],t[e+12]=n[12],t[e+13]=n[13],t[e+14]=n[14],t[e+15]=n[15],t}}se.prototype.isMatrix4=!0;const ae=new Lt,oe=new se,le=new Lt(0,0,0),ce=new Lt(1,1,1),he=new Lt,ue=new Lt,de=new Lt,pe=new se,me=new At;class fe{constructor(t=0,e=0,n=0,i=fe.DefaultOrder){this._x=t,this._y=e,this._z=n,this._order=i}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get order(){return this._order}set order(t){this._order=t,this._onChangeCallback()}set(t,e,n,i){return this._x=t,this._y=e,this._z=n,this._order=i||this._order,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._order)}copy(t){return this._x=t._x,this._y=t._y,this._z=t._z,this._order=t._order,this._onChangeCallback(),this}setFromRotationMatrix(t,e,n){const i=t.elements,r=i[0],s=i[4],a=i[8],o=i[1],l=i[5],c=i[9],h=i[2],u=i[6],d=i[10];switch(e=e||this._order){case"XYZ":this._y=Math.asin(ht(a,-1,1)),Math.abs(a)<.9999999?(this._x=Math.atan2(-c,d),this._z=Math.atan2(-s,r)):(this._x=Math.atan2(u,l),this._z=0);break;case"YXZ":this._x=Math.asin(-ht(c,-1,1)),Math.abs(c)<.9999999?(this._y=Math.atan2(a,d),this._z=Math.atan2(o,l)):(this._y=Math.atan2(-h,r),this._z=0);break;case"ZXY":this._x=Math.asin(ht(u,-1,1)),Math.abs(u)<.9999999?(this._y=Math.atan2(-h,d),this._z=Math.atan2(-s,l)):(this._y=0,this._z=Math.atan2(o,r));break;case"ZYX":this._y=Math.asin(-ht(h,-1,1)),Math.abs(h)<.9999999?(this._x=Math.atan2(u,d),this._z=Math.atan2(o,r)):(this._x=0,this._z=Math.atan2(-s,l));break;case"YZX":this._z=Math.asin(ht(o,-1,1)),Math.abs(o)<.9999999?(this._x=Math.atan2(-c,l),this._y=Math.atan2(-h,r)):(this._x=0,this._y=Math.atan2(a,d));break;case"XZY":this._z=Math.asin(-ht(s,-1,1)),Math.abs(s)<.9999999?(this._x=Math.atan2(u,l),this._y=Math.atan2(a,r)):(this._x=Math.atan2(-c,d),this._y=0);break;default:console.warn("THREE.Euler: .setFromRotationMatrix() encountered an unknown order: "+e)}return this._order=e,!1!==n&&this._onChangeCallback(),this}setFromQuaternion(t,e,n){return pe.makeRotationFromQuaternion(t),this.setFromRotationMatrix(pe,e,n)}setFromVector3(t,e){return this.set(t.x,t.y,t.z,e||this._order)}reorder(t){return me.setFromEuler(this),this.setFromQuaternion(me,t)}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._order===this._order}fromArray(t){return this._x=t[0],this._y=t[1],this._z=t[2],void 0!==t[3]&&(this._order=t[3]),this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._order,t}toVector3(t){return t?t.set(this._x,this._y,this._z):new Lt(this._x,this._y,this._z)}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}}fe.prototype.isEuler=!0,fe.DefaultOrder="XYZ",fe.RotationOrders=["XYZ","YZX","ZXY","XZY","YXZ","ZYX"];class ge{constructor(){this.mask=1}set(t){this.mask=1<<t|0}enable(t){this.mask|=1<<t|0}enableAll(){this.mask=-1}toggle(t){this.mask^=1<<t|0}disable(t){this.mask&=~(1<<t|0)}disableAll(){this.mask=0}test(t){return 0!=(this.mask&t.mask)}}let ve=0;const ye=new Lt,xe=new At,_e=new se,we=new Lt,be=new Lt,Me=new Lt,Se=new At,Te=new Lt(1,0,0),Ee=new Lt(0,1,0),Ae=new Lt(0,0,1),Le={type:"added"},Re={type:"removed"};class Ce extends rt{constructor(){super(),Object.defineProperty(this,"id",{value:ve++}),this.uuid=ct(),this.name="",this.type="Object3D",this.parent=null,this.children=[],this.up=Ce.DefaultUp.clone();const t=new Lt,e=new fe,n=new At,i=new Lt(1,1,1);e._onChange((function(){n.setFromEuler(e,!1)})),n._onChange((function(){e.setFromQuaternion(n,void 0,!1)})),Object.defineProperties(this,{position:{configurable:!0,enumerable:!0,value:t},rotation:{configurable:!0,enumerable:!0,value:e},quaternion:{configurable:!0,enumerable:!0,value:n},scale:{configurable:!0,enumerable:!0,value:i},modelViewMatrix:{value:new se},normalMatrix:{value:new yt}}),this.matrix=new se,this.matrixWorld=new se,this.matrixAutoUpdate=Ce.DefaultMatrixAutoUpdate,this.matrixWorldNeedsUpdate=!1,this.layers=new ge,this.visible=!0,this.castShadow=!1,this.receiveShadow=!1,this.frustumCulled=!0,this.renderOrder=0,this.animations=[],this.userData={}}onBeforeRender(){}onAfterRender(){}applyMatrix4(t){this.matrixAutoUpdate&&this.updateMatrix(),this.matrix.premultiply(t),this.matrix.decompose(this.position,this.quaternion,this.scale)}applyQuaternion(t){return this.quaternion.premultiply(t),this}setRotationFromAxisAngle(t,e){this.quaternion.setFromAxisAngle(t,e)}setRotationFromEuler(t){this.quaternion.setFromEuler(t,!0)}setRotationFromMatrix(t){this.quaternion.setFromRotationMatrix(t)}setRotationFromQuaternion(t){this.quaternion.copy(t)}rotateOnAxis(t,e){return xe.setFromAxisAngle(t,e),this.quaternion.multiply(xe),this}rotateOnWorldAxis(t,e){return xe.setFromAxisAngle(t,e),this.quaternion.premultiply(xe),this}rotateX(t){return this.rotateOnAxis(Te,t)}rotateY(t){return this.rotateOnAxis(Ee,t)}rotateZ(t){return this.rotateOnAxis(Ae,t)}translateOnAxis(t,e){return ye.copy(t).applyQuaternion(this.quaternion),this.position.add(ye.multiplyScalar(e)),this}translateX(t){return this.translateOnAxis(Te,t)}translateY(t){return this.translateOnAxis(Ee,t)}translateZ(t){return this.translateOnAxis(Ae,t)}localToWorld(t){return t.applyMatrix4(this.matrixWorld)}worldToLocal(t){return t.applyMatrix4(_e.copy(this.matrixWorld).invert())}lookAt(t,e,n){t.isVector3?we.copy(t):we.set(t,e,n);const i=this.parent;this.updateWorldMatrix(!0,!1),be.setFromMatrixPosition(this.matrixWorld),this.isCamera||this.isLight?_e.lookAt(be,we,this.up):_e.lookAt(we,be,this.up),this.quaternion.setFromRotationMatrix(_e),i&&(_e.extractRotation(i.matrixWorld),xe.setFromRotationMatrix(_e),this.quaternion.premultiply(xe.invert()))}add(t){if(arguments.length>1){for(let t=0;t<arguments.length;t++)this.add(arguments[t]);return this}return t===this?(console.error("THREE.Object3D.add: object can't be added as a child of itself.",t),this):(t&&t.isObject3D?(null!==t.parent&&t.parent.remove(t),t.parent=this,this.children.push(t),t.dispatchEvent(Le)):console.error("THREE.Object3D.add: object not an instance of THREE.Object3D.",t),this)}remove(t){if(arguments.length>1){for(let t=0;t<arguments.length;t++)this.remove(arguments[t]);return this}const e=this.children.indexOf(t);return-1!==e&&(t.parent=null,this.children.splice(e,1),t.dispatchEvent(Re)),this}clear(){for(let t=0;t<this.children.length;t++){const e=this.children[t];e.parent=null,e.dispatchEvent(Re)}return this.children.length=0,this}attach(t){return this.updateWorldMatrix(!0,!1),_e.copy(this.matrixWorld).invert(),null!==t.parent&&(t.parent.updateWorldMatrix(!0,!1),_e.multiply(t.parent.matrixWorld)),t.applyMatrix4(_e),this.add(t),t.updateWorldMatrix(!1,!0),this}getObjectById(t){return this.getObjectByProperty("id",t)}getObjectByName(t){return this.getObjectByProperty("name",t)}getObjectByProperty(t,e){if(this[t]===e)return this;for(let n=0,i=this.children.length;n<i;n++){const i=this.children[n].getObjectByProperty(t,e);if(void 0!==i)return i}}getWorldPosition(t){return void 0===t&&(console.warn("THREE.Object3D: .getWorldPosition() target is now required"),t=new Lt),this.updateWorldMatrix(!0,!1),t.setFromMatrixPosition(this.matrixWorld)}getWorldQuaternion(t){return void 0===t&&(console.warn("THREE.Object3D: .getWorldQuaternion() target is now required"),t=new At),this.updateWorldMatrix(!0,!1),this.matrixWorld.decompose(be,t,Me),t}getWorldScale(t){return void 0===t&&(console.warn("THREE.Object3D: .getWorldScale() target is now required"),t=new Lt),this.updateWorldMatrix(!0,!1),this.matrixWorld.decompose(be,Se,t),t}getWorldDirection(t){void 0===t&&(console.warn("THREE.Object3D: .getWorldDirection() target is now required"),t=new Lt),this.updateWorldMatrix(!0,!1);const e=this.matrixWorld.elements;return t.set(e[8],e[9],e[10]).normalize()}raycast(){}traverse(t){t(this);const e=this.children;for(let n=0,i=e.length;n<i;n++)e[n].traverse(t)}traverseVisible(t){if(!1===this.visible)return;t(this);const e=this.children;for(let n=0,i=e.length;n<i;n++)e[n].traverseVisible(t)}traverseAncestors(t){const e=this.parent;null!==e&&(t(e),e.traverseAncestors(t))}updateMatrix(){this.matrix.compose(this.position,this.quaternion,this.scale),this.matrixWorldNeedsUpdate=!0}updateMatrixWorld(t){this.matrixAutoUpdate&&this.updateMatrix(),(this.matrixWorldNeedsUpdate||t)&&(null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix),this.matrixWorldNeedsUpdate=!1,t=!0);const e=this.children;for(let n=0,i=e.length;n<i;n++)e[n].updateMatrixWorld(t)}updateWorldMatrix(t,e){const n=this.parent;if(!0===t&&null!==n&&n.updateWorldMatrix(!0,!1),this.matrixAutoUpdate&&this.updateMatrix(),null===this.parent?this.matrixWorld.copy(this.matrix):this.matrixWorld.multiplyMatrices(this.parent.matrixWorld,this.matrix),!0===e){const t=this.children;for(let e=0,n=t.length;e<n;e++)t[e].updateWorldMatrix(!1,!0)}}toJSON(t){const e=void 0===t||"string"==typeof t,n={};e&&(t={geometries:{},materials:{},textures:{},images:{},shapes:{},skeletons:{},animations:{}},n.metadata={version:4.5,type:"Object",generator:"Object3D.toJSON"});const i={};function r(e,n){return void 0===e[n.uuid]&&(e[n.uuid]=n.toJSON(t)),n.uuid}if(i.uuid=this.uuid,i.type=this.type,""!==this.name&&(i.name=this.name),!0===this.castShadow&&(i.castShadow=!0),!0===this.receiveShadow&&(i.receiveShadow=!0),!1===this.visible&&(i.visible=!1),!1===this.frustumCulled&&(i.frustumCulled=!1),0!==this.renderOrder&&(i.renderOrder=this.renderOrder),"{}"!==JSON.stringify(this.userData)&&(i.userData=this.userData),i.layers=this.layers.mask,i.matrix=this.matrix.toArray(),!1===this.matrixAutoUpdate&&(i.matrixAutoUpdate=!1),this.isInstancedMesh&&(i.type="InstancedMesh",i.count=this.count,i.instanceMatrix=this.instanceMatrix.toJSON(),null!==this.instanceColor&&(i.instanceColor=this.instanceColor.toJSON())),this.isMesh||this.isLine||this.isPoints){i.geometry=r(t.geometries,this.geometry);const e=this.geometry.parameters;if(void 0!==e&&void 0!==e.shapes){const n=e.shapes;if(Array.isArray(n))for(let e=0,i=n.length;e<i;e++){const i=n[e];r(t.shapes,i)}else r(t.shapes,n)}}if(this.isSkinnedMesh&&(i.bindMode=this.bindMode,i.bindMatrix=this.bindMatrix.toArray(),void 0!==this.skeleton&&(r(t.skeletons,this.skeleton),i.skeleton=this.skeleton.uuid)),void 0!==this.material)if(Array.isArray(this.material)){const e=[];for(let n=0,i=this.material.length;n<i;n++)e.push(r(t.materials,this.material[n]));i.material=e}else i.material=r(t.materials,this.material);if(this.children.length>0){i.children=[];for(let e=0;e<this.children.length;e++)i.children.push(this.children[e].toJSON(t).object)}if(this.animations.length>0){i.animations=[];for(let e=0;e<this.animations.length;e++){const n=this.animations[e];i.animations.push(r(t.animations,n))}}if(e){const e=s(t.geometries),i=s(t.materials),r=s(t.textures),a=s(t.images),o=s(t.shapes),l=s(t.skeletons),c=s(t.animations);e.length>0&&(n.geometries=e),i.length>0&&(n.materials=i),r.length>0&&(n.textures=r),a.length>0&&(n.images=a),o.length>0&&(n.shapes=o),l.length>0&&(n.skeletons=l),c.length>0&&(n.animations=c)}return n.object=i,n;function s(t){const e=[];for(const n in t){const i=t[n];delete i.metadata,e.push(i)}return e}}clone(t){return(new this.constructor).copy(this,t)}copy(t,e=!0){if(this.name=t.name,this.up.copy(t.up),this.position.copy(t.position),this.rotation.order=t.rotation.order,this.quaternion.copy(t.quaternion),this.scale.copy(t.scale),this.matrix.copy(t.matrix),this.matrixWorld.copy(t.matrixWorld),this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrixWorldNeedsUpdate=t.matrixWorldNeedsUpdate,this.layers.mask=t.layers.mask,this.visible=t.visible,this.castShadow=t.castShadow,this.receiveShadow=t.receiveShadow,this.frustumCulled=t.frustumCulled,this.renderOrder=t.renderOrder,this.userData=JSON.parse(JSON.stringify(t.userData)),!0===e)for(let e=0;e<t.children.length;e++){const n=t.children[e];this.add(n.clone())}return this}}Ce.DefaultUp=new Lt(0,1,0),Ce.DefaultMatrixAutoUpdate=!0,Ce.prototype.isObject3D=!0;const Pe=new Lt,De=new Lt,Ie=new yt;class Ne{constructor(t=new Lt(1,0,0),e=0){this.normal=t,this.constant=e}set(t,e){return this.normal.copy(t),this.constant=e,this}setComponents(t,e,n,i){return this.normal.set(t,e,n),this.constant=i,this}setFromNormalAndCoplanarPoint(t,e){return this.normal.copy(t),this.constant=-e.dot(this.normal),this}setFromCoplanarPoints(t,e,n){const i=Pe.subVectors(n,e).cross(De.subVectors(t,e)).normalize();return this.setFromNormalAndCoplanarPoint(i,t),this}copy(t){return this.normal.copy(t.normal),this.constant=t.constant,this}normalize(){const t=1/this.normal.length();return this.normal.multiplyScalar(t),this.constant*=t,this}negate(){return this.constant*=-1,this.normal.negate(),this}distanceToPoint(t){return this.normal.dot(t)+this.constant}distanceToSphere(t){return this.distanceToPoint(t.center)-t.radius}projectPoint(t,e){return void 0===e&&(console.warn("THREE.Plane: .projectPoint() target is now required"),e=new Lt),e.copy(this.normal).multiplyScalar(-this.distanceToPoint(t)).add(t)}intersectLine(t,e){void 0===e&&(console.warn("THREE.Plane: .intersectLine() target is now required"),e=new Lt);const n=t.delta(Pe),i=this.normal.dot(n);if(0===i)return 0===this.distanceToPoint(t.start)?e.copy(t.start):null;const r=-(t.start.dot(this.normal)+this.constant)/i;return r<0||r>1?null:e.copy(n).multiplyScalar(r).add(t.start)}intersectsLine(t){const e=this.distanceToPoint(t.start),n=this.distanceToPoint(t.end);return e<0&&n>0||n<0&&e>0}intersectsBox(t){return t.intersectsPlane(this)}intersectsSphere(t){return t.intersectsPlane(this)}coplanarPoint(t){return void 0===t&&(console.warn("THREE.Plane: .coplanarPoint() target is now required"),t=new Lt),t.copy(this.normal).multiplyScalar(-this.constant)}applyMatrix4(t,e){const n=e||Ie.getNormalMatrix(t),i=this.coplanarPoint(Pe).applyMatrix4(t),r=this.normal.applyMatrix3(n).normalize();return this.constant=-i.dot(r),this}translate(t){return this.constant-=t.dot(this.normal),this}equals(t){return t.normal.equals(this.normal)&&t.constant===this.constant}clone(){return(new this.constructor).copy(this)}}Ne.prototype.isPlane=!0;const Be=new Lt,ze=new Lt,Fe=new Lt,Oe=new Lt,He=new Lt,Ge=new Lt,Ue=new Lt,ke=new Lt,Ve=new Lt,We=new Lt;class je{constructor(t=new Lt,e=new Lt,n=new Lt){this.a=t,this.b=e,this.c=n}static getNormal(t,e,n,i){void 0===i&&(console.warn("THREE.Triangle: .getNormal() target is now required"),i=new Lt),i.subVectors(n,e),Be.subVectors(t,e),i.cross(Be);const r=i.lengthSq();return r>0?i.multiplyScalar(1/Math.sqrt(r)):i.set(0,0,0)}static getBarycoord(t,e,n,i,r){Be.subVectors(i,e),ze.subVectors(n,e),Fe.subVectors(t,e);const s=Be.dot(Be),a=Be.dot(ze),o=Be.dot(Fe),l=ze.dot(ze),c=ze.dot(Fe),h=s*l-a*a;if(void 0===r&&(console.warn("THREE.Triangle: .getBarycoord() target is now required"),r=new Lt),0===h)return r.set(-2,-1,-1);const u=1/h,d=(l*o-a*c)*u,p=(s*c-a*o)*u;return r.set(1-d-p,p,d)}static containsPoint(t,e,n,i){return this.getBarycoord(t,e,n,i,Oe),Oe.x>=0&&Oe.y>=0&&Oe.x+Oe.y<=1}static getUV(t,e,n,i,r,s,a,o){return this.getBarycoord(t,e,n,i,Oe),o.set(0,0),o.addScaledVector(r,Oe.x),o.addScaledVector(s,Oe.y),o.addScaledVector(a,Oe.z),o}static isFrontFacing(t,e,n,i){return Be.subVectors(n,e),ze.subVectors(t,e),Be.cross(ze).dot(i)<0}set(t,e,n){return this.a.copy(t),this.b.copy(e),this.c.copy(n),this}setFromPointsAndIndices(t,e,n,i){return this.a.copy(t[e]),this.b.copy(t[n]),this.c.copy(t[i]),this}clone(){return(new this.constructor).copy(this)}copy(t){return this.a.copy(t.a),this.b.copy(t.b),this.c.copy(t.c),this}getArea(){return Be.subVectors(this.c,this.b),ze.subVectors(this.a,this.b),.5*Be.cross(ze).length()}getMidpoint(t){return void 0===t&&(console.warn("THREE.Triangle: .getMidpoint() target is now required"),t=new Lt),t.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3)}getNormal(t){return je.getNormal(this.a,this.b,this.c,t)}getPlane(t){return void 0===t&&(console.warn("THREE.Triangle: .getPlane() target is now required"),t=new Ne),t.setFromCoplanarPoints(this.a,this.b,this.c)}getBarycoord(t,e){return je.getBarycoord(t,this.a,this.b,this.c,e)}getUV(t,e,n,i,r){return je.getUV(t,this.a,this.b,this.c,e,n,i,r)}containsPoint(t){return je.containsPoint(t,this.a,this.b,this.c)}isFrontFacing(t){return je.isFrontFacing(this.a,this.b,this.c,t)}intersectsBox(t){return t.intersectsTriangle(this)}closestPointToPoint(t,e){void 0===e&&(console.warn("THREE.Triangle: .closestPointToPoint() target is now required"),e=new Lt);const n=this.a,i=this.b,r=this.c;let s,a;He.subVectors(i,n),Ge.subVectors(r,n),ke.subVectors(t,n);const o=He.dot(ke),l=Ge.dot(ke);if(o<=0&&l<=0)return e.copy(n);Ve.subVectors(t,i);const c=He.dot(Ve),h=Ge.dot(Ve);if(c>=0&&h<=c)return e.copy(i);const u=o*h-c*l;if(u<=0&&o>=0&&c<=0)return s=o/(o-c),e.copy(n).addScaledVector(He,s);We.subVectors(t,r);const d=He.dot(We),p=Ge.dot(We);if(p>=0&&d<=p)return e.copy(r);const m=d*l-o*p;if(m<=0&&l>=0&&p<=0)return a=l/(l-p),e.copy(n).addScaledVector(Ge,a);const f=c*p-d*h;if(f<=0&&h-c>=0&&d-p>=0)return Ue.subVectors(r,i),a=(h-c)/(h-c+(d-p)),e.copy(i).addScaledVector(Ue,a);const g=1/(f+m+u);return s=m*g,a=u*g,e.copy(n).addScaledVector(He,s).addScaledVector(Ge,a)}equals(t){return t.a.equals(this.a)&&t.b.equals(this.b)&&t.c.equals(this.c)}}let qe=0;function Xe(){Object.defineProperty(this,"id",{value:qe++}),this.uuid=ct(),this.name="",this.type="Material",this.fog=!0,this.blending=1,this.side=0,this.vertexColors=!1,this.opacity=1,this.transparent=!1,this.blendSrc=204,this.blendDst=205,this.blendEquation=n,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.depthFunc=3,this.depthTest=!0,this.depthWrite=!0,this.stencilWriteMask=255,this.stencilFunc=519,this.stencilRef=0,this.stencilFuncMask=255,this.stencilFail=tt,this.stencilZFail=tt,this.stencilZPass=tt,this.stencilWrite=!1,this.clippingPlanes=null,this.clipIntersection=!1,this.clipShadows=!1,this.shadowSide=null,this.colorWrite=!0,this.precision=null,this.polygonOffset=!1,this.polygonOffsetFactor=0,this.polygonOffsetUnits=0,this.dithering=!1,this.alphaTest=0,this.alphaToCoverage=!1,this.premultipliedAlpha=!1,this.visible=!0,this.toneMapped=!0,this.userData={},this.version=0}Xe.prototype=Object.assign(Object.create(rt.prototype),{constructor:Xe,isMaterial:!0,onBuild:function(){},onBeforeCompile:function(){},customProgramCacheKey:function(){return this.onBeforeCompile.toString()},setValues:function(t){if(void 0!==t)for(const e in t){const n=t[e];if(void 0===n){console.warn("THREE.Material: '"+e+"' parameter is undefined.");continue}if("shading"===e){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===n;continue}const i=this[e];void 0!==i?i&&i.isColor?i.set(n):i&&i.isVector3&&n&&n.isVector3?i.copy(n):this[e]=n:console.warn("THREE."+this.type+": '"+e+"' is not a property of this material.")}},toJSON:function(t){const e=void 0===t||"string"==typeof t;e&&(t={textures:{},images:{}});const n={metadata:{version:4.5,type:"Material",generator:"Material.toJSON"}};function i(t){const e=[];for(const n in t){const i=t[n];delete i.metadata,e.push(i)}return e}if(n.uuid=this.uuid,n.type=this.type,""!==this.name&&(n.name=this.name),this.color&&this.color.isColor&&(n.color=this.color.getHex()),void 0!==this.roughness&&(n.roughness=this.roughness),void 0!==this.metalness&&(n.metalness=this.metalness),this.sheen&&this.sheen.isColor&&(n.sheen=this.sheen.getHex()),this.emissive&&this.emissive.isColor&&(n.emissive=this.emissive.getHex()),this.emissiveIntensity&&1!==this.emissiveIntensity&&(n.emissiveIntensity=this.emissiveIntensity),this.specular&&this.specular.isColor&&(n.specular=this.specular.getHex()),void 0!==this.shininess&&(n.shininess=this.shininess),void 0!==this.clearcoat&&(n.clearcoat=this.clearcoat),void 0!==this.clearcoatRoughness&&(n.clearcoatRoughness=this.clearcoatRoughness),this.clearcoatMap&&this.clearcoatMap.isTexture&&(n.clearcoatMap=this.clearcoatMap.toJSON(t).uuid),this.clearcoatRoughnessMap&&this.clearcoatRoughnessMap.isTexture&&(n.clearcoatRoughnessMap=this.clearcoatRoughnessMap.toJSON(t).uuid),this.clearcoatNormalMap&&this.clearcoatNormalMap.isTexture&&(n.clearcoatNormalMap=this.clearcoatNormalMap.toJSON(t).uuid,n.clearcoatNormalScale=this.clearcoatNormalScale.toArray()),this.map&&this.map.isTexture&&(n.map=this.map.toJSON(t).uuid),this.matcap&&this.matcap.isTexture&&(n.matcap=this.matcap.toJSON(t).uuid),this.alphaMap&&this.alphaMap.isTexture&&(n.alphaMap=this.alphaMap.toJSON(t).uuid),this.lightMap&&this.lightMap.isTexture&&(n.lightMap=this.lightMap.toJSON(t).uuid,n.lightMapIntensity=this.lightMapIntensity),this.aoMap&&this.aoMap.isTexture&&(n.aoMap=this.aoMap.toJSON(t).uuid,n.aoMapIntensity=this.aoMapIntensity),this.bumpMap&&this.bumpMap.isTexture&&(n.bumpMap=this.bumpMap.toJSON(t).uuid,n.bumpScale=this.bumpScale),this.normalMap&&this.normalMap.isTexture&&(n.normalMap=this.normalMap.toJSON(t).uuid,n.normalMapType=this.normalMapType,n.normalScale=this.normalScale.toArray()),this.displacementMap&&this.displacementMap.isTexture&&(n.displacementMap=this.displacementMap.toJSON(t).uuid,n.displacementScale=this.displacementScale,n.displacementBias=this.displacementBias),this.roughnessMap&&this.roughnessMap.isTexture&&(n.roughnessMap=this.roughnessMap.toJSON(t).uuid),this.metalnessMap&&this.metalnessMap.isTexture&&(n.metalnessMap=this.metalnessMap.toJSON(t).uuid),this.emissiveMap&&this.emissiveMap.isTexture&&(n.emissiveMap=this.emissiveMap.toJSON(t).uuid),this.specularMap&&this.specularMap.isTexture&&(n.specularMap=this.specularMap.toJSON(t).uuid),this.envMap&&this.envMap.isTexture&&(n.envMap=this.envMap.toJSON(t).uuid,void 0!==this.combine&&(n.combine=this.combine)),void 0!==this.envMapIntensity&&(n.envMapIntensity=this.envMapIntensity),void 0!==this.reflectivity&&(n.reflectivity=this.reflectivity),void 0!==this.refractionRatio&&(n.refractionRatio=this.refractionRatio),this.gradientMap&&this.gradientMap.isTexture&&(n.gradientMap=this.gradientMap.toJSON(t).uuid),void 0!==this.size&&(n.size=this.size),null!==this.shadowSide&&(n.shadowSide=this.shadowSide),void 0!==this.sizeAttenuation&&(n.sizeAttenuation=this.sizeAttenuation),1!==this.blending&&(n.blending=this.blending),0!==this.side&&(n.side=this.side),this.vertexColors&&(n.vertexColors=!0),this.opacity<1&&(n.opacity=this.opacity),!0===this.transparent&&(n.transparent=this.transparent),n.depthFunc=this.depthFunc,n.depthTest=this.depthTest,n.depthWrite=this.depthWrite,n.colorWrite=this.colorWrite,n.stencilWrite=this.stencilWrite,n.stencilWriteMask=this.stencilWriteMask,n.stencilFunc=this.stencilFunc,n.stencilRef=this.stencilRef,n.stencilFuncMask=this.stencilFuncMask,n.stencilFail=this.stencilFail,n.stencilZFail=this.stencilZFail,n.stencilZPass=this.stencilZPass,this.rotation&&0!==this.rotation&&(n.rotation=this.rotation),!0===this.polygonOffset&&(n.polygonOffset=!0),0!==this.polygonOffsetFactor&&(n.polygonOffsetFactor=this.polygonOffsetFactor),0!==this.polygonOffsetUnits&&(n.polygonOffsetUnits=this.polygonOffsetUnits),this.linewidth&&1!==this.linewidth&&(n.linewidth=this.linewidth),void 0!==this.dashSize&&(n.dashSize=this.dashSize),void 0!==this.gapSize&&(n.gapSize=this.gapSize),void 0!==this.scale&&(n.scale=this.scale),!0===this.dithering&&(n.dithering=!0),this.alphaTest>0&&(n.alphaTest=this.alphaTest),!0===this.alphaToCoverage&&(n.alphaToCoverage=this.alphaToCoverage),!0===this.premultipliedAlpha&&(n.premultipliedAlpha=this.premultipliedAlpha),!0===this.wireframe&&(n.wireframe=this.wireframe),this.wireframeLinewidth>1&&(n.wireframeLinewidth=this.wireframeLinewidth),"round"!==this.wireframeLinecap&&(n.wireframeLinecap=this.wireframeLinecap),"round"!==this.wireframeLinejoin&&(n.wireframeLinejoin=this.wireframeLinejoin),!0===this.morphTargets&&(n.morphTargets=!0),!0===this.morphNormals&&(n.morphNormals=!0),!0===this.skinning&&(n.skinning=!0),!0===this.flatShading&&(n.flatShading=this.flatShading),!1===this.visible&&(n.visible=!1),!1===this.toneMapped&&(n.toneMapped=!1),"{}"!==JSON.stringify(this.userData)&&(n.userData=this.userData),e){const e=i(t.textures),r=i(t.images);e.length>0&&(n.textures=e),r.length>0&&(n.images=r)}return n},clone:function(){return(new this.constructor).copy(this)},copy:function(t){this.name=t.name,this.fog=t.fog,this.blending=t.blending,this.side=t.side,this.vertexColors=t.vertexColors,this.opacity=t.opacity,this.transparent=t.transparent,this.blendSrc=t.blendSrc,this.blendDst=t.blendDst,this.blendEquation=t.blendEquation,this.blendSrcAlpha=t.blendSrcAlpha,this.blendDstAlpha=t.blendDstAlpha,this.blendEquationAlpha=t.blendEquationAlpha,this.depthFunc=t.depthFunc,this.depthTest=t.depthTest,this.depthWrite=t.depthWrite,this.stencilWriteMask=t.stencilWriteMask,this.stencilFunc=t.stencilFunc,this.stencilRef=t.stencilRef,this.stencilFuncMask=t.stencilFuncMask,this.stencilFail=t.stencilFail,this.stencilZFail=t.stencilZFail,this.stencilZPass=t.stencilZPass,this.stencilWrite=t.stencilWrite;const e=t.clippingPlanes;let n=null;if(null!==e){const t=e.length;n=new Array(t);for(let i=0;i!==t;++i)n[i]=e[i].clone()}return this.clippingPlanes=n,this.clipIntersection=t.clipIntersection,this.clipShadows=t.clipShadows,this.shadowSide=t.shadowSide,this.colorWrite=t.colorWrite,this.precision=t.precision,this.polygonOffset=t.polygonOffset,this.polygonOffsetFactor=t.polygonOffsetFactor,this.polygonOffsetUnits=t.polygonOffsetUnits,this.dithering=t.dithering,this.alphaTest=t.alphaTest,this.alphaToCoverage=t.alphaToCoverage,this.premultipliedAlpha=t.premultipliedAlpha,this.visible=t.visible,this.toneMapped=t.toneMapped,this.userData=JSON.parse(JSON.stringify(t.userData)),this},dispose:function(){this.dispatchEvent({type:"dispose"})}}),Object.defineProperty(Xe.prototype,"needsUpdate",{set:function(t){!0===t&&this.version++}});const Ye={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074},Ze={h:0,s:0,l:0},Je={h:0,s:0,l:0};function Qe(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n<1/6?t+6*(e-t)*n:n<.5?e:n<2/3?t+6*(e-t)*(2/3-n):t}function Ke(t){return t<.04045?.0773993808*t:Math.pow(.9478672986*t+.0521327014,2.4)}function $e(t){return t<.0031308?12.92*t:1.055*Math.pow(t,.41666)-.055}class tn{constructor(t,e,n){return void 0===e&&void 0===n?this.set(t):this.setRGB(t,e,n)}set(t){return t&&t.isColor?this.copy(t):"number"==typeof t?this.setHex(t):"string"==typeof t&&this.setStyle(t),this}setScalar(t){return this.r=t,this.g=t,this.b=t,this}setHex(t){return t=Math.floor(t),this.r=(t>>16&255)/255,this.g=(t>>8&255)/255,this.b=(255&t)/255,this}setRGB(t,e,n){return this.r=t,this.g=e,this.b=n,this}setHSL(t,e,n){if(t=ut(t,1),e=ht(e,0,1),n=ht(n,0,1),0===e)this.r=this.g=this.b=n;else{const i=n<=.5?n*(1+e):n+e-n*e,r=2*n-i;this.r=Qe(r,i,t+1/3),this.g=Qe(r,i,t),this.b=Qe(r,i,t-1/3)}return this}setStyle(t){function e(e){void 0!==e&&parseFloat(e)<1&&console.warn("THREE.Color: Alpha component of "+t+" will be ignored.")}let n;if(n=/^((?:rgb|hsl)a?)\(([^\)]*)\)/.exec(t)){let t;const i=n[1],r=n[2];switch(i){case"rgb":case"rgba":if(t=/^\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r))return this.r=Math.min(255,parseInt(t[1],10))/255,this.g=Math.min(255,parseInt(t[2],10))/255,this.b=Math.min(255,parseInt(t[3],10))/255,e(t[4]),this;if(t=/^\s*(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r))return this.r=Math.min(100,parseInt(t[1],10))/100,this.g=Math.min(100,parseInt(t[2],10))/100,this.b=Math.min(100,parseInt(t[3],10))/100,e(t[4]),this;break;case"hsl":case"hsla":if(t=/^\s*(\d*\.?\d+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r)){const n=parseFloat(t[1])/360,i=parseInt(t[2],10)/100,r=parseInt(t[3],10)/100;return e(t[4]),this.setHSL(n,i,r)}}}else if(n=/^\#([A-Fa-f\d]+)$/.exec(t)){const t=n[1],e=t.length;if(3===e)return this.r=parseInt(t.charAt(0)+t.charAt(0),16)/255,this.g=parseInt(t.charAt(1)+t.charAt(1),16)/255,this.b=parseInt(t.charAt(2)+t.charAt(2),16)/255,this;if(6===e)return this.r=parseInt(t.charAt(0)+t.charAt(1),16)/255,this.g=parseInt(t.charAt(2)+t.charAt(3),16)/255,this.b=parseInt(t.charAt(4)+t.charAt(5),16)/255,this}return t&&t.length>0?this.setColorName(t):this}setColorName(t){const e=Ye[t.toLowerCase()];return void 0!==e?this.setHex(e):console.warn("THREE.Color: Unknown color "+t),this}clone(){return new this.constructor(this.r,this.g,this.b)}copy(t){return this.r=t.r,this.g=t.g,this.b=t.b,this}copyGammaToLinear(t,e=2){return this.r=Math.pow(t.r,e),this.g=Math.pow(t.g,e),this.b=Math.pow(t.b,e),this}copyLinearToGamma(t,e=2){const n=e>0?1/e:1;return this.r=Math.pow(t.r,n),this.g=Math.pow(t.g,n),this.b=Math.pow(t.b,n),this}convertGammaToLinear(t){return this.copyGammaToLinear(this,t),this}convertLinearToGamma(t){return this.copyLinearToGamma(this,t),this}copySRGBToLinear(t){return this.r=Ke(t.r),this.g=Ke(t.g),this.b=Ke(t.b),this}copyLinearToSRGB(t){return this.r=$e(t.r),this.g=$e(t.g),this.b=$e(t.b),this}convertSRGBToLinear(){return this.copySRGBToLinear(this),this}convertLinearToSRGB(){return this.copyLinearToSRGB(this),this}getHex(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0}getHexString(){return("000000"+this.getHex().toString(16)).slice(-6)}getHSL(t){void 0===t&&(console.warn("THREE.Color: .getHSL() target is now required"),t={h:0,s:0,l:0});const e=this.r,n=this.g,i=this.b,r=Math.max(e,n,i),s=Math.min(e,n,i);let a,o;const l=(s+r)/2;if(s===r)a=0,o=0;else{const t=r-s;switch(o=l<=.5?t/(r+s):t/(2-r-s),r){case e:a=(n-i)/t+(n<i?6:0);break;case n:a=(i-e)/t+2;break;case i:a=(e-n)/t+4}a/=6}return t.h=a,t.s=o,t.l=l,t}getStyle(){return"rgb("+(255*this.r|0)+","+(255*this.g|0)+","+(255*this.b|0)+")"}offsetHSL(t,e,n){return this.getHSL(Ze),Ze.h+=t,Ze.s+=e,Ze.l+=n,this.setHSL(Ze.h,Ze.s,Ze.l),this}add(t){return this.r+=t.r,this.g+=t.g,this.b+=t.b,this}addColors(t,e){return this.r=t.r+e.r,this.g=t.g+e.g,this.b=t.b+e.b,this}addScalar(t){return this.r+=t,this.g+=t,this.b+=t,this}sub(t){return this.r=Math.max(0,this.r-t.r),this.g=Math.max(0,this.g-t.g),this.b=Math.max(0,this.b-t.b),this}multiply(t){return this.r*=t.r,this.g*=t.g,this.b*=t.b,this}multiplyScalar(t){return this.r*=t,this.g*=t,this.b*=t,this}lerp(t,e){return this.r+=(t.r-this.r)*e,this.g+=(t.g-this.g)*e,this.b+=(t.b-this.b)*e,this}lerpColors(t,e,n){return this.r=t.r+(e.r-t.r)*n,this.g=t.g+(e.g-t.g)*n,this.b=t.b+(e.b-t.b)*n,this}lerpHSL(t,e){this.getHSL(Ze),t.getHSL(Je);const n=dt(Ze.h,Je.h,e),i=dt(Ze.s,Je.s,e),r=dt(Ze.l,Je.l,e);return this.setHSL(n,i,r),this}equals(t){return t.r===this.r&&t.g===this.g&&t.b===this.b}fromArray(t,e=0){return this.r=t[e],this.g=t[e+1],this.b=t[e+2],this}toArray(t=[],e=0){return t[e]=this.r,t[e+1]=this.g,t[e+2]=this.b,t}fromBufferAttribute(t,e){return this.r=t.getX(e),this.g=t.getY(e),this.b=t.getZ(e),!0===t.normalized&&(this.r/=255,this.g/=255,this.b/=255),this}toJSON(){return this.getHex()}}tn.NAMES=Ye,tn.prototype.isColor=!0,tn.prototype.r=1,tn.prototype.g=1,tn.prototype.b=1;class en extends Xe{constructor(t){super(),this.type="MeshBasicMaterial",this.color=new tn(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.skinning=!1,this.morphTargets=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.specularMap=t.specularMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.combine=t.combine,this.reflectivity=t.reflectivity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this}}en.prototype.isMeshBasicMaterial=!0;const nn=new Lt,rn=new vt;class sn{constructor(t,e,n){if(Array.isArray(t))throw new TypeError("THREE.BufferAttribute: array should be a Typed Array.");this.name="",this.array=t,this.itemSize=e,this.count=void 0!==t?t.length/e:0,this.normalized=!0===n,this.usage=et,this.updateRange={offset:0,count:-1},this.version=0,this.onUploadCallback=function(){}}set needsUpdate(t){!0===t&&this.version++}setUsage(t){return this.usage=t,this}copy(t){return this.name=t.name,this.array=new t.array.constructor(t.array),this.itemSize=t.itemSize,this.count=t.count,this.normalized=t.normalized,this.usage=t.usage,this}copyAt(t,e,n){t*=this.itemSize,n*=e.itemSize;for(let i=0,r=this.itemSize;i<r;i++)this.array[t+i]=e.array[n+i];return this}copyArray(t){return this.array.set(t),this}copyColorsArray(t){const e=this.array;let n=0;for(let i=0,r=t.length;i<r;i++){let r=t[i];void 0===r&&(console.warn("THREE.BufferAttribute.copyColorsArray(): color is undefined",i),r=new tn),e[n++]=r.r,e[n++]=r.g,e[n++]=r.b}return this}copyVector2sArray(t){const e=this.array;let n=0;for(let i=0,r=t.length;i<r;i++){let r=t[i];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector2sArray(): vector is undefined",i),r=new vt),e[n++]=r.x,e[n++]=r.y}return this}copyVector3sArray(t){const e=this.array;let n=0;for(let i=0,r=t.length;i<r;i++){let r=t[i];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector3sArray(): vector is undefined",i),r=new Lt),e[n++]=r.x,e[n++]=r.y,e[n++]=r.z}return this}copyVector4sArray(t){const e=this.array;let n=0;for(let i=0,r=t.length;i<r;i++){let r=t[i];void 0===r&&(console.warn("THREE.BufferAttribute.copyVector4sArray(): vector is undefined",i),r=new St),e[n++]=r.x,e[n++]=r.y,e[n++]=r.z,e[n++]=r.w}return this}applyMatrix3(t){if(2===this.itemSize)for(let e=0,n=this.count;e<n;e++)rn.fromBufferAttribute(this,e),rn.applyMatrix3(t),this.setXY(e,rn.x,rn.y);else if(3===this.itemSize)for(let e=0,n=this.count;e<n;e++)nn.fromBufferAttribute(this,e),nn.applyMatrix3(t),this.setXYZ(e,nn.x,nn.y,nn.z);return this}applyMatrix4(t){for(let e=0,n=this.count;e<n;e++)nn.x=this.getX(e),nn.y=this.getY(e),nn.z=this.getZ(e),nn.applyMatrix4(t),this.setXYZ(e,nn.x,nn.y,nn.z);return this}applyNormalMatrix(t){for(let e=0,n=this.count;e<n;e++)nn.x=this.getX(e),nn.y=this.getY(e),nn.z=this.getZ(e),nn.applyNormalMatrix(t),this.setXYZ(e,nn.x,nn.y,nn.z);return this}transformDirection(t){for(let e=0,n=this.count;e<n;e++)nn.x=this.getX(e),nn.y=this.getY(e),nn.z=this.getZ(e),nn.transformDirection(t),this.setXYZ(e,nn.x,nn.y,nn.z);return this}set(t,e=0){return this.array.set(t,e),this}getX(t){return this.array[t*this.itemSize]}setX(t,e){return this.array[t*this.itemSize]=e,this}getY(t){return this.array[t*this.itemSize+1]}setY(t,e){return this.array[t*this.itemSize+1]=e,this}getZ(t){return this.array[t*this.itemSize+2]}setZ(t,e){return this.array[t*this.itemSize+2]=e,this}getW(t){return this.array[t*this.itemSize+3]}setW(t,e){return this.array[t*this.itemSize+3]=e,this}setXY(t,e,n){return t*=this.itemSize,this.array[t+0]=e,this.array[t+1]=n,this}setXYZ(t,e,n,i){return t*=this.itemSize,this.array[t+0]=e,this.array[t+1]=n,this.array[t+2]=i,this}setXYZW(t,e,n,i,r){return t*=this.itemSize,this.array[t+0]=e,this.array[t+1]=n,this.array[t+2]=i,this.array[t+3]=r,this}onUpload(t){return this.onUploadCallback=t,this}clone(){return new this.constructor(this.array,this.itemSize).copy(this)}toJSON(){const t={itemSize:this.itemSize,type:this.array.constructor.name,array:Array.prototype.slice.call(this.array),normalized:this.normalized};return""!==this.name&&(t.name=this.name),this.usage!==et&&(t.usage=this.usage),0===this.updateRange.offset&&-1===this.updateRange.count||(t.updateRange=this.updateRange),t}}sn.prototype.isBufferAttribute=!0;class an extends sn{constructor(t,e,n){super(new Int8Array(t),e,n)}}class on extends sn{constructor(t,e,n){super(new Uint8Array(t),e,n)}}class ln extends sn{constructor(t,e,n){super(new Uint8ClampedArray(t),e,n)}}class cn extends sn{constructor(t,e,n){super(new Int16Array(t),e,n)}}class hn extends sn{constructor(t,e,n){super(new Uint16Array(t),e,n)}}class un extends sn{constructor(t,e,n){super(new Int32Array(t),e,n)}}class dn extends sn{constructor(t,e,n){super(new Uint32Array(t),e,n)}}class pn extends sn{constructor(t,e,n){super(new Uint16Array(t),e,n)}}pn.prototype.isFloat16BufferAttribute=!0;class mn extends sn{constructor(t,e,n){super(new Float32Array(t),e,n)}}class fn extends sn{constructor(t,e,n){super(new Float64Array(t),e,n)}}function gn(t){if(0===t.length)return-1/0;let e=t[0];for(let n=1,i=t.length;n<i;++n)t[n]>e&&(e=t[n]);return e}const vn={Int8Array:Int8Array,Uint8Array:Uint8Array,Uint8ClampedArray:Uint8ClampedArray,Int16Array:Int16Array,Uint16Array:Uint16Array,Int32Array:Int32Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array};function yn(t,e){return new vn[t](e)}let xn=0;const _n=new se,wn=new Ce,bn=new Lt,Mn=new Pt,Sn=new Pt,Tn=new Lt;class En extends rt{constructor(){super(),Object.defineProperty(this,"id",{value:xn++}),this.uuid=ct(),this.name="",this.type="BufferGeometry",this.index=null,this.attributes={},this.morphAttributes={},this.morphTargetsRelative=!1,this.groups=[],this.boundingBox=null,this.boundingSphere=null,this.drawRange={start:0,count:1/0},this.userData={}}getIndex(){return this.index}setIndex(t){return Array.isArray(t)?this.index=new(gn(t)>65535?dn:hn)(t,1):this.index=t,this}getAttribute(t){return this.attributes[t]}setAttribute(t,e){return this.attributes[t]=e,this}deleteAttribute(t){return delete this.attributes[t],this}hasAttribute(t){return void 0!==this.attributes[t]}addGroup(t,e,n=0){this.groups.push({start:t,count:e,materialIndex:n})}clearGroups(){this.groups=[]}setDrawRange(t,e){this.drawRange.start=t,this.drawRange.count=e}applyMatrix4(t){const e=this.attributes.position;void 0!==e&&(e.applyMatrix4(t),e.needsUpdate=!0);const n=this.attributes.normal;if(void 0!==n){const e=(new yt).getNormalMatrix(t);n.applyNormalMatrix(e),n.needsUpdate=!0}const i=this.attributes.tangent;return void 0!==i&&(i.transformDirection(t),i.needsUpdate=!0),null!==this.boundingBox&&this.computeBoundingBox(),null!==this.boundingSphere&&this.computeBoundingSphere(),this}rotateX(t){return _n.makeRotationX(t),this.applyMatrix4(_n),this}rotateY(t){return _n.makeRotationY(t),this.applyMatrix4(_n),this}rotateZ(t){return _n.makeRotationZ(t),this.applyMatrix4(_n),this}translate(t,e,n){return _n.makeTranslation(t,e,n),this.applyMatrix4(_n),this}scale(t,e,n){return _n.makeScale(t,e,n),this.applyMatrix4(_n),this}lookAt(t){return wn.lookAt(t),wn.updateMatrix(),this.applyMatrix4(wn.matrix),this}center(){return this.computeBoundingBox(),this.boundingBox.getCenter(bn).negate(),this.translate(bn.x,bn.y,bn.z),this}setFromPoints(t){const e=[];for(let n=0,i=t.length;n<i;n++){const i=t[n];e.push(i.x,i.y,i.z||0)}return this.setAttribute("position",new mn(e,3)),this}computeBoundingBox(){null===this.boundingBox&&(this.boundingBox=new Pt);const t=this.attributes.position,e=this.morphAttributes.position;if(t&&t.isGLBufferAttribute)return console.error('THREE.BufferGeometry.computeBoundingBox(): GLBufferAttribute requires a manual bounding box. Alternatively set "mesh.frustumCulled" to "false".',this),void this.boundingBox.set(new Lt(-1/0,-1/0,-1/0),new Lt(1/0,1/0,1/0));if(void 0!==t){if(this.boundingBox.setFromBufferAttribute(t),e)for(let t=0,n=e.length;t<n;t++){const n=e[t];Mn.setFromBufferAttribute(n),this.morphTargetsRelative?(Tn.addVectors(this.boundingBox.min,Mn.min),this.boundingBox.expandByPoint(Tn),Tn.addVectors(this.boundingBox.max,Mn.max),this.boundingBox.expandByPoint(Tn)):(this.boundingBox.expandByPoint(Mn.min),this.boundingBox.expandByPoint(Mn.max))}}else this.boundingBox.makeEmpty();(isNaN(this.boundingBox.min.x)||isNaN(this.boundingBox.min.y)||isNaN(this.boundingBox.min.z))&&console.error('THREE.BufferGeometry.computeBoundingBox(): Computed min/max have NaN values. The "position" attribute is likely to have NaN values.',this)}computeBoundingSphere(){null===this.boundingSphere&&(this.boundingSphere=new Jt);const t=this.attributes.position,e=this.morphAttributes.position;if(t&&t.isGLBufferAttribute)return console.error('THREE.BufferGeometry.computeBoundingSphere(): GLBufferAttribute requires a manual bounding sphere. Alternatively set "mesh.frustumCulled" to "false".',this),void this.boundingSphere.set(new Lt,1/0);if(t){const n=this.boundingSphere.center;if(Mn.setFromBufferAttribute(t),e)for(let t=0,n=e.length;t<n;t++){const n=e[t];Sn.setFromBufferAttribute(n),this.morphTargetsRelative?(Tn.addVectors(Mn.min,Sn.min),Mn.expandByPoint(Tn),Tn.addVectors(Mn.max,Sn.max),Mn.expandByPoint(Tn)):(Mn.expandByPoint(Sn.min),Mn.expandByPoint(Sn.max))}Mn.getCenter(n);let i=0;for(let e=0,r=t.count;e<r;e++)Tn.fromBufferAttribute(t,e),i=Math.max(i,n.distanceToSquared(Tn));if(e)for(let r=0,s=e.length;r<s;r++){const s=e[r],a=this.morphTargetsRelative;for(let e=0,r=s.count;e<r;e++)Tn.fromBufferAttribute(s,e),a&&(bn.fromBufferAttribute(t,e),Tn.add(bn)),i=Math.max(i,n.distanceToSquared(Tn))}this.boundingSphere.radius=Math.sqrt(i),isNaN(this.boundingSphere.radius)&&console.error('THREE.BufferGeometry.computeBoundingSphere(): Computed radius is NaN. The "position" attribute is likely to have NaN values.',this)}}computeFaceNormals(){}computeTangents(){const t=this.index,e=this.attributes;if(null===t||void 0===e.position||void 0===e.normal||void 0===e.uv)return void console.error("THREE.BufferGeometry: .computeTangents() failed. Missing required attributes (index, position, normal or uv)");const n=t.array,i=e.position.array,r=e.normal.array,s=e.uv.array,a=i.length/3;void 0===e.tangent&&this.setAttribute("tangent",new sn(new Float32Array(4*a),4));const o=e.tangent.array,l=[],c=[];for(let t=0;t<a;t++)l[t]=new Lt,c[t]=new Lt;const h=new Lt,u=new Lt,d=new Lt,p=new vt,m=new vt,f=new vt,g=new Lt,v=new Lt;function y(t,e,n){h.fromArray(i,3*t),u.fromArray(i,3*e),d.fromArray(i,3*n),p.fromArray(s,2*t),m.fromArray(s,2*e),f.fromArray(s,2*n),u.sub(h),d.sub(h),m.sub(p),f.sub(p);const r=1/(m.x*f.y-f.x*m.y);isFinite(r)&&(g.copy(u).multiplyScalar(f.y).addScaledVector(d,-m.y).multiplyScalar(r),v.copy(d).multiplyScalar(m.x).addScaledVector(u,-f.x).multiplyScalar(r),l[t].add(g),l[e].add(g),l[n].add(g),c[t].add(v),c[e].add(v),c[n].add(v))}let x=this.groups;0===x.length&&(x=[{start:0,count:n.length}]);for(let t=0,e=x.length;t<e;++t){const e=x[t],i=e.start;for(let t=i,r=i+e.count;t<r;t+=3)y(n[t+0],n[t+1],n[t+2])}const _=new Lt,w=new Lt,b=new Lt,M=new Lt;function S(t){b.fromArray(r,3*t),M.copy(b);const e=l[t];_.copy(e),_.sub(b.multiplyScalar(b.dot(e))).normalize(),w.crossVectors(M,e);const n=w.dot(c[t])<0?-1:1;o[4*t]=_.x,o[4*t+1]=_.y,o[4*t+2]=_.z,o[4*t+3]=n}for(let t=0,e=x.length;t<e;++t){const e=x[t],i=e.start;for(let t=i,r=i+e.count;t<r;t+=3)S(n[t+0]),S(n[t+1]),S(n[t+2])}}computeVertexNormals(){const t=this.index,e=this.getAttribute("position");if(void 0!==e){let n=this.getAttribute("normal");if(void 0===n)n=new sn(new Float32Array(3*e.count),3),this.setAttribute("normal",n);else for(let t=0,e=n.count;t<e;t++)n.setXYZ(t,0,0,0);const i=new Lt,r=new Lt,s=new Lt,a=new Lt,o=new Lt,l=new Lt,c=new Lt,h=new Lt;if(t)for(let u=0,d=t.count;u<d;u+=3){const d=t.getX(u+0),p=t.getX(u+1),m=t.getX(u+2);i.fromBufferAttribute(e,d),r.fromBufferAttribute(e,p),s.fromBufferAttribute(e,m),c.subVectors(s,r),h.subVectors(i,r),c.cross(h),a.fromBufferAttribute(n,d),o.fromBufferAttribute(n,p),l.fromBufferAttribute(n,m),a.add(c),o.add(c),l.add(c),n.setXYZ(d,a.x,a.y,a.z),n.setXYZ(p,o.x,o.y,o.z),n.setXYZ(m,l.x,l.y,l.z)}else for(let t=0,a=e.count;t<a;t+=3)i.fromBufferAttribute(e,t+0),r.fromBufferAttribute(e,t+1),s.fromBufferAttribute(e,t+2),c.subVectors(s,r),h.subVectors(i,r),c.cross(h),n.setXYZ(t+0,c.x,c.y,c.z),n.setXYZ(t+1,c.x,c.y,c.z),n.setXYZ(t+2,c.x,c.y,c.z);this.normalizeNormals(),n.needsUpdate=!0}}merge(t,e){if(!t||!t.isBufferGeometry)return void console.error("THREE.BufferGeometry.merge(): geometry not an instance of THREE.BufferGeometry.",t);void 0===e&&(e=0,console.warn("THREE.BufferGeometry.merge(): Overwriting original geometry, starting at offset=0. Use BufferGeometryUtils.mergeBufferGeometries() for lossless merge."));const n=this.attributes;for(const i in n){if(void 0===t.attributes[i])continue;const r=n[i].array,s=t.attributes[i],a=s.array,o=s.itemSize*e,l=Math.min(a.length,r.length-o);for(let t=0,e=o;t<l;t++,e++)r[e]=a[t]}return this}normalizeNormals(){const t=this.attributes.normal;for(let e=0,n=t.count;e<n;e++)Tn.fromBufferAttribute(t,e),Tn.normalize(),t.setXYZ(e,Tn.x,Tn.y,Tn.z)}toNonIndexed(){function t(t,e){const n=t.array,i=t.itemSize,r=t.normalized,s=new n.constructor(e.length*i);let a=0,o=0;for(let t=0,r=e.length;t<r;t++){a=e[t]*i;for(let t=0;t<i;t++)s[o++]=n[a++]}return new sn(s,i,r)}if(null===this.index)return console.warn("THREE.BufferGeometry.toNonIndexed(): BufferGeometry is already non-indexed."),this;const e=new En,n=this.index.array,i=this.attributes;for(const r in i){const s=t(i[r],n);e.setAttribute(r,s)}const r=this.morphAttributes;for(const i in r){const s=[],a=r[i];for(let e=0,i=a.length;e<i;e++){const i=t(a[e],n);s.push(i)}e.morphAttributes[i]=s}e.morphTargetsRelative=this.morphTargetsRelative;const s=this.groups;for(let t=0,n=s.length;t<n;t++){const n=s[t];e.addGroup(n.start,n.count,n.materialIndex)}return e}toJSON(){const t={metadata:{version:4.5,type:"BufferGeometry",generator:"BufferGeometry.toJSON"}};if(t.uuid=this.uuid,t.type=this.type,""!==this.name&&(t.name=this.name),Object.keys(this.userData).length>0&&(t.userData=this.userData),void 0!==this.parameters){const e=this.parameters;for(const n in e)void 0!==e[n]&&(t[n]=e[n]);return t}t.data={attributes:{}};const e=this.index;null!==e&&(t.data.index={type:e.array.constructor.name,array:Array.prototype.slice.call(e.array)});const n=this.attributes;for(const e in n){const i=n[e];t.data.attributes[e]=i.toJSON(t.data)}const i={};let r=!1;for(const e in this.morphAttributes){const n=this.morphAttributes[e],s=[];for(let e=0,i=n.length;e<i;e++){const i=n[e];s.push(i.toJSON(t.data))}s.length>0&&(i[e]=s,r=!0)}r&&(t.data.morphAttributes=i,t.data.morphTargetsRelative=this.morphTargetsRelative);const s=this.groups;s.length>0&&(t.data.groups=JSON.parse(JSON.stringify(s)));const a=this.boundingSphere;return null!==a&&(t.data.boundingSphere={center:a.center.toArray(),radius:a.radius}),t}clone(){return(new En).copy(this)}copy(t){this.index=null,this.attributes={},this.morphAttributes={},this.groups=[],this.boundingBox=null,this.boundingSphere=null;const e={};this.name=t.name;const n=t.index;null!==n&&this.setIndex(n.clone(e));const i=t.attributes;for(const t in i){const n=i[t];this.setAttribute(t,n.clone(e))}const r=t.morphAttributes;for(const t in r){const n=[],i=r[t];for(let t=0,r=i.length;t<r;t++)n.push(i[t].clone(e));this.morphAttributes[t]=n}this.morphTargetsRelative=t.morphTargetsRelative;const s=t.groups;for(let t=0,e=s.length;t<e;t++){const e=s[t];this.addGroup(e.start,e.count,e.materialIndex)}const a=t.boundingBox;null!==a&&(this.boundingBox=a.clone());const o=t.boundingSphere;return null!==o&&(this.boundingSphere=o.clone()),this.drawRange.start=t.drawRange.start,this.drawRange.count=t.drawRange.count,this.userData=t.userData,this}dispose(){this.dispatchEvent({type:"dispose"})}}En.prototype.isBufferGeometry=!0;const An=new se,Ln=new re,Rn=new Jt,Cn=new Lt,Pn=new Lt,Dn=new Lt,In=new Lt,Nn=new Lt,Bn=new Lt,zn=new Lt,Fn=new Lt,On=new Lt,Hn=new vt,Gn=new vt,Un=new vt,kn=new Lt,Vn=new Lt;class Wn extends Ce{constructor(t=new En,e=new en){super(),this.type="Mesh",this.geometry=t,this.material=e,this.updateMorphTargets()}copy(t){return super.copy(t),void 0!==t.morphTargetInfluences&&(this.morphTargetInfluences=t.morphTargetInfluences.slice()),void 0!==t.morphTargetDictionary&&(this.morphTargetDictionary=Object.assign({},t.morphTargetDictionary)),this.material=t.material,this.geometry=t.geometry,this}updateMorphTargets(){const t=this.geometry;if(t.isBufferGeometry){const e=t.morphAttributes,n=Object.keys(e);if(n.length>0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e<n;e++){const n=t[e].name||String(e);this.morphTargetInfluences.push(0),this.morphTargetDictionary[n]=e}}}}else{const e=t.morphTargets;void 0!==e&&e.length>0&&console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}}raycast(t,e){const n=this.geometry,i=this.material,r=this.matrixWorld;if(void 0===i)return;if(null===n.boundingSphere&&n.computeBoundingSphere(),Rn.copy(n.boundingSphere),Rn.applyMatrix4(r),!1===t.ray.intersectsSphere(Rn))return;if(An.copy(r).invert(),Ln.copy(t.ray).applyMatrix4(An),null!==n.boundingBox&&!1===Ln.intersectsBox(n.boundingBox))return;let s;if(n.isBufferGeometry){const r=n.index,a=n.attributes.position,o=n.morphAttributes.position,l=n.morphTargetsRelative,c=n.attributes.uv,h=n.attributes.uv2,u=n.groups,d=n.drawRange;if(null!==r)if(Array.isArray(i))for(let n=0,p=u.length;n<p;n++){const p=u[n],m=i[p.materialIndex];for(let n=Math.max(p.start,d.start),i=Math.min(p.start+p.count,d.start+d.count);n<i;n+=3){const i=r.getX(n),u=r.getX(n+1),d=r.getX(n+2);s=jn(this,m,t,Ln,a,o,l,c,h,i,u,d),s&&(s.faceIndex=Math.floor(n/3),s.face.materialIndex=p.materialIndex,e.push(s))}}else{for(let n=Math.max(0,d.start),u=Math.min(r.count,d.start+d.count);n<u;n+=3){const u=r.getX(n),d=r.getX(n+1),p=r.getX(n+2);s=jn(this,i,t,Ln,a,o,l,c,h,u,d,p),s&&(s.faceIndex=Math.floor(n/3),e.push(s))}}else if(void 0!==a)if(Array.isArray(i))for(let n=0,r=u.length;n<r;n++){const r=u[n],p=i[r.materialIndex];for(let n=Math.max(r.start,d.start),i=Math.min(r.start+r.count,d.start+d.count);n<i;n+=3){s=jn(this,p,t,Ln,a,o,l,c,h,n,n+1,n+2),s&&(s.faceIndex=Math.floor(n/3),s.face.materialIndex=r.materialIndex,e.push(s))}}else{for(let n=Math.max(0,d.start),r=Math.min(a.count,d.start+d.count);n<r;n+=3){s=jn(this,i,t,Ln,a,o,l,c,h,n,n+1,n+2),s&&(s.faceIndex=Math.floor(n/3),e.push(s))}}}else n.isGeometry&&console.error("THREE.Mesh.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}}function jn(t,e,n,i,r,s,a,o,l,c,h,u){Cn.fromBufferAttribute(r,c),Pn.fromBufferAttribute(r,h),Dn.fromBufferAttribute(r,u);const d=t.morphTargetInfluences;if(e.morphTargets&&s&&d){zn.set(0,0,0),Fn.set(0,0,0),On.set(0,0,0);for(let t=0,e=s.length;t<e;t++){const e=d[t],n=s[t];0!==e&&(In.fromBufferAttribute(n,c),Nn.fromBufferAttribute(n,h),Bn.fromBufferAttribute(n,u),a?(zn.addScaledVector(In,e),Fn.addScaledVector(Nn,e),On.addScaledVector(Bn,e)):(zn.addScaledVector(In.sub(Cn),e),Fn.addScaledVector(Nn.sub(Pn),e),On.addScaledVector(Bn.sub(Dn),e)))}Cn.add(zn),Pn.add(Fn),Dn.add(On)}t.isSkinnedMesh&&e.skinning&&(t.boneTransform(c,Cn),t.boneTransform(h,Pn),t.boneTransform(u,Dn));const p=function(t,e,n,i,r,s,a,o){let l;if(l=1===e.side?i.intersectTriangle(a,s,r,!0,o):i.intersectTriangle(r,s,a,2!==e.side,o),null===l)return null;Vn.copy(o),Vn.applyMatrix4(t.matrixWorld);const c=n.ray.origin.distanceTo(Vn);return c<n.near||c>n.far?null:{distance:c,point:Vn.clone(),object:t}}(t,e,n,i,Cn,Pn,Dn,kn);if(p){o&&(Hn.fromBufferAttribute(o,c),Gn.fromBufferAttribute(o,h),Un.fromBufferAttribute(o,u),p.uv=je.getUV(kn,Cn,Pn,Dn,Hn,Gn,Un,new vt)),l&&(Hn.fromBufferAttribute(l,c),Gn.fromBufferAttribute(l,h),Un.fromBufferAttribute(l,u),p.uv2=je.getUV(kn,Cn,Pn,Dn,Hn,Gn,Un,new vt));const t={a:c,b:h,c:u,normal:new Lt,materialIndex:0};je.getNormal(Cn,Pn,Dn,t.normal),p.face=t}return p}Wn.prototype.isMesh=!0;class qn extends En{constructor(t=1,e=1,n=1,i=1,r=1,s=1){super(),this.type="BoxGeometry",this.parameters={width:t,height:e,depth:n,widthSegments:i,heightSegments:r,depthSegments:s};const a=this;i=Math.floor(i),r=Math.floor(r),s=Math.floor(s);const o=[],l=[],c=[],h=[];let u=0,d=0;function p(t,e,n,i,r,s,p,m,f,g,v){const y=s/f,x=p/g,_=s/2,w=p/2,b=m/2,M=f+1,S=g+1;let T=0,E=0;const A=new Lt;for(let s=0;s<S;s++){const a=s*x-w;for(let o=0;o<M;o++){const u=o*y-_;A[t]=u*i,A[e]=a*r,A[n]=b,l.push(A.x,A.y,A.z),A[t]=0,A[e]=0,A[n]=m>0?1:-1,c.push(A.x,A.y,A.z),h.push(o/f),h.push(1-s/g),T+=1}}for(let t=0;t<g;t++)for(let e=0;e<f;e++){const n=u+e+M*t,i=u+e+M*(t+1),r=u+(e+1)+M*(t+1),s=u+(e+1)+M*t;o.push(n,i,s),o.push(i,r,s),E+=6}a.addGroup(d,E,v),d+=E,u+=T}p("z","y","x",-1,-1,n,e,t,s,r,0),p("z","y","x",1,-1,n,e,-t,s,r,1),p("x","z","y",1,1,t,n,e,i,s,2),p("x","z","y",1,-1,t,n,-e,i,s,3),p("x","y","z",1,-1,t,e,n,i,r,4),p("x","y","z",-1,-1,t,e,-n,i,r,5),this.setIndex(o),this.setAttribute("position",new mn(l,3)),this.setAttribute("normal",new mn(c,3)),this.setAttribute("uv",new mn(h,2))}}function Xn(t){const e={};for(const n in t){e[n]={};for(const i in t[n]){const r=t[n][i];r&&(r.isColor||r.isMatrix3||r.isMatrix4||r.isVector2||r.isVector3||r.isVector4||r.isTexture||r.isQuaternion)?e[n][i]=r.clone():Array.isArray(r)?e[n][i]=r.slice():e[n][i]=r}}return e}function Yn(t){const e={};for(let n=0;n<t.length;n++){const i=Xn(t[n]);for(const t in i)e[t]=i[t]}return e}const Zn={clone:Xn,merge:Yn};class Jn extends Xe{constructor(t){super(),this.type="ShaderMaterial",this.defines={},this.uniforms={},this.vertexShader="void main() {\n\tgl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );\n}",this.fragmentShader="void main() {\n\tgl_FragColor = vec4( 1.0, 0.0, 0.0, 1.0 );\n}",this.linewidth=1,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.lights=!1,this.clipping=!1,this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.extensions={derivatives:!1,fragDepth:!1,drawBuffers:!1,shaderTextureLOD:!1},this.defaultAttributeValues={color:[1,1,1],uv:[0,0],uv2:[0,0]},this.index0AttributeName=void 0,this.uniformsNeedUpdate=!1,this.glslVersion=null,void 0!==t&&(void 0!==t.attributes&&console.error("THREE.ShaderMaterial: attributes should now be defined in THREE.BufferGeometry instead."),this.setValues(t))}copy(t){return super.copy(t),this.fragmentShader=t.fragmentShader,this.vertexShader=t.vertexShader,this.uniforms=Xn(t.uniforms),this.defines=Object.assign({},t.defines),this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.lights=t.lights,this.clipping=t.clipping,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this.extensions=Object.assign({},t.extensions),this.glslVersion=t.glslVersion,this}toJSON(t){const e=super.toJSON(t);e.glslVersion=this.glslVersion,e.uniforms={};for(const n in this.uniforms){const i=this.uniforms[n].value;i&&i.isTexture?e.uniforms[n]={type:"t",value:i.toJSON(t).uuid}:i&&i.isColor?e.uniforms[n]={type:"c",value:i.getHex()}:i&&i.isVector2?e.uniforms[n]={type:"v2",value:i.toArray()}:i&&i.isVector3?e.uniforms[n]={type:"v3",value:i.toArray()}:i&&i.isVector4?e.uniforms[n]={type:"v4",value:i.toArray()}:i&&i.isMatrix3?e.uniforms[n]={type:"m3",value:i.toArray()}:i&&i.isMatrix4?e.uniforms[n]={type:"m4",value:i.toArray()}:e.uniforms[n]={value:i}}Object.keys(this.defines).length>0&&(e.defines=this.defines),e.vertexShader=this.vertexShader,e.fragmentShader=this.fragmentShader;const n={};for(const t in this.extensions)!0===this.extensions[t]&&(n[t]=!0);return Object.keys(n).length>0&&(e.extensions=n),e}}Jn.prototype.isShaderMaterial=!0;class Qn extends Ce{constructor(){super(),this.type="Camera",this.matrixWorldInverse=new se,this.projectionMatrix=new se,this.projectionMatrixInverse=new se}copy(t,e){return super.copy(t,e),this.matrixWorldInverse.copy(t.matrixWorldInverse),this.projectionMatrix.copy(t.projectionMatrix),this.projectionMatrixInverse.copy(t.projectionMatrixInverse),this}getWorldDirection(t){void 0===t&&(console.warn("THREE.Camera: .getWorldDirection() target is now required"),t=new Lt),this.updateWorldMatrix(!0,!1);const e=this.matrixWorld.elements;return t.set(-e[8],-e[9],-e[10]).normalize()}updateMatrixWorld(t){super.updateMatrixWorld(t),this.matrixWorldInverse.copy(this.matrixWorld).invert()}updateWorldMatrix(t,e){super.updateWorldMatrix(t,e),this.matrixWorldInverse.copy(this.matrixWorld).invert()}clone(){return(new this.constructor).copy(this)}}Qn.prototype.isCamera=!0;class Kn extends Qn{constructor(t=50,e=1,n=.1,i=2e3){super(),this.type="PerspectiveCamera",this.fov=t,this.zoom=1,this.near=n,this.far=i,this.focus=10,this.aspect=e,this.view=null,this.filmGauge=35,this.filmOffset=0,this.updateProjectionMatrix()}copy(t,e){return super.copy(t,e),this.fov=t.fov,this.zoom=t.zoom,this.near=t.near,this.far=t.far,this.focus=t.focus,this.aspect=t.aspect,this.view=null===t.view?null:Object.assign({},t.view),this.filmGauge=t.filmGauge,this.filmOffset=t.filmOffset,this}setFocalLength(t){const e=.5*this.getFilmHeight()/t;this.fov=2*lt*Math.atan(e),this.updateProjectionMatrix()}getFocalLength(){const t=Math.tan(.5*ot*this.fov);return.5*this.getFilmHeight()/t}getEffectiveFOV(){return 2*lt*Math.atan(Math.tan(.5*ot*this.fov)/this.zoom)}getFilmWidth(){return this.filmGauge*Math.min(this.aspect,1)}getFilmHeight(){return this.filmGauge/Math.max(this.aspect,1)}setViewOffset(t,e,n,i,r,s){this.aspect=t/e,null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1}),this.view.enabled=!0,this.view.fullWidth=t,this.view.fullHeight=e,this.view.offsetX=n,this.view.offsetY=i,this.view.width=r,this.view.height=s,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const t=this.near;let e=t*Math.tan(.5*ot*this.fov)/this.zoom,n=2*e,i=this.aspect*n,r=-.5*i;const s=this.view;if(null!==this.view&&this.view.enabled){const t=s.fullWidth,a=s.fullHeight;r+=s.offsetX*i/t,e-=s.offsetY*n/a,i*=s.width/t,n*=s.height/a}const a=this.filmOffset;0!==a&&(r+=t*a/this.getFilmWidth()),this.projectionMatrix.makePerspective(r,r+i,e,e-n,t,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(t){const e=super.toJSON(t);return e.object.fov=this.fov,e.object.zoom=this.zoom,e.object.near=this.near,e.object.far=this.far,e.object.focus=this.focus,e.object.aspect=this.aspect,null!==this.view&&(e.object.view=Object.assign({},this.view)),e.object.filmGauge=this.filmGauge,e.object.filmOffset=this.filmOffset,e}}Kn.prototype.isPerspectiveCamera=!0;const $n=90;class ti extends Ce{constructor(t,e,n){if(super(),this.type="CubeCamera",!0!==n.isWebGLCubeRenderTarget)return void console.error("THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.");this.renderTarget=n;const i=new Kn($n,1,t,e);i.layers=this.layers,i.up.set(0,-1,0),i.lookAt(new Lt(1,0,0)),this.add(i);const r=new Kn($n,1,t,e);r.layers=this.layers,r.up.set(0,-1,0),r.lookAt(new Lt(-1,0,0)),this.add(r);const s=new Kn($n,1,t,e);s.layers=this.layers,s.up.set(0,0,1),s.lookAt(new Lt(0,1,0)),this.add(s);const a=new Kn($n,1,t,e);a.layers=this.layers,a.up.set(0,0,-1),a.lookAt(new Lt(0,-1,0)),this.add(a);const o=new Kn($n,1,t,e);o.layers=this.layers,o.up.set(0,-1,0),o.lookAt(new Lt(0,0,1)),this.add(o);const l=new Kn($n,1,t,e);l.layers=this.layers,l.up.set(0,-1,0),l.lookAt(new Lt(0,0,-1)),this.add(l)}update(t,e){null===this.parent&&this.updateMatrixWorld();const n=this.renderTarget,[i,r,s,a,o,l]=this.children,c=t.xr.enabled,h=t.getRenderTarget();t.xr.enabled=!1;const u=n.texture.generateMipmaps;n.texture.generateMipmaps=!1,t.setRenderTarget(n,0),t.render(e,i),t.setRenderTarget(n,1),t.render(e,r),t.setRenderTarget(n,2),t.render(e,s),t.setRenderTarget(n,3),t.render(e,a),t.setRenderTarget(n,4),t.render(e,o),n.texture.generateMipmaps=u,t.setRenderTarget(n,5),t.render(e,l),t.setRenderTarget(h),t.xr.enabled=c}}class ei extends bt{constructor(t,e,n,i,s,a,o,l,c,h){super(t=void 0!==t?t:[],e=void 0!==e?e:r,n,i,s,a,o=void 0!==o?o:T,l,c,h),this._needsFlipEnvMap=!0,this.flipY=!1}get images(){return this.image}set images(t){this.image=t}}ei.prototype.isCubeTexture=!0;class ni extends Tt{constructor(t,e,n){Number.isInteger(e)&&(console.warn("THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )"),e=n),super(t,t,e),e=e||{},this.texture=new ei(void 0,e.mapping,e.wrapS,e.wrapT,e.magFilter,e.minFilter,e.format,e.type,e.anisotropy,e.encoding),this.texture.generateMipmaps=void 0!==e.generateMipmaps&&e.generateMipmaps,this.texture.minFilter=void 0!==e.minFilter?e.minFilter:g,this.texture._needsFlipEnvMap=!1}fromEquirectangularTexture(t,e){this.texture.type=e.type,this.texture.format=E,this.texture.encoding=e.encoding,this.texture.generateMipmaps=e.generateMipmaps,this.texture.minFilter=e.minFilter,this.texture.magFilter=e.magFilter;const n={uniforms:{tEquirect:{value:null}},vertexShader:"\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 <begin_vertex>\n\t\t\t\t\t#include <project_vertex>\n\n\t\t\t\t}\n\t\t\t",fragmentShader:"\n\n\t\t\t\tuniform sampler2D tEquirect;\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\t#include <common>\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"},i=new qn(5,5,5),r=new Jn({name:"CubemapFromEquirect",uniforms:Xn(n.uniforms),vertexShader:n.vertexShader,fragmentShader:n.fragmentShader,side:1,blending:0});r.uniforms.tEquirect.value=e;const s=new Wn(i,r),a=e.minFilter;e.minFilter===y&&(e.minFilter=g);return new ti(1,10,this).update(t,s),e.minFilter=a,s.geometry.dispose(),s.material.dispose(),this}clear(t,e,n,i){const r=t.getRenderTarget();for(let r=0;r<6;r++)t.setRenderTarget(this,r),t.clear(e,n,i);t.setRenderTarget(r)}}ni.prototype.isWebGLCubeRenderTarget=!0;class ii extends bt{constructor(t,e,n,i,r,s,a,o,l,c,h,u){super(null,s,a,o,l,c,i,r,h,u),this.image={data:t||null,width:e||1,height:n||1},this.magFilter=void 0!==l?l:p,this.minFilter=void 0!==c?c:p,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}ii.prototype.isDataTexture=!0;const ri=new Jt,si=new Lt;class ai{constructor(t=new Ne,e=new Ne,n=new Ne,i=new Ne,r=new Ne,s=new Ne){this.planes=[t,e,n,i,r,s]}set(t,e,n,i,r,s){const a=this.planes;return a[0].copy(t),a[1].copy(e),a[2].copy(n),a[3].copy(i),a[4].copy(r),a[5].copy(s),this}copy(t){const e=this.planes;for(let n=0;n<6;n++)e[n].copy(t.planes[n]);return this}setFromProjectionMatrix(t){const e=this.planes,n=t.elements,i=n[0],r=n[1],s=n[2],a=n[3],o=n[4],l=n[5],c=n[6],h=n[7],u=n[8],d=n[9],p=n[10],m=n[11],f=n[12],g=n[13],v=n[14],y=n[15];return e[0].setComponents(a-i,h-o,m-u,y-f).normalize(),e[1].setComponents(a+i,h+o,m+u,y+f).normalize(),e[2].setComponents(a+r,h+l,m+d,y+g).normalize(),e[3].setComponents(a-r,h-l,m-d,y-g).normalize(),e[4].setComponents(a-s,h-c,m-p,y-v).normalize(),e[5].setComponents(a+s,h+c,m+p,y+v).normalize(),this}intersectsObject(t){const e=t.geometry;return null===e.boundingSphere&&e.computeBoundingSphere(),ri.copy(e.boundingSphere).applyMatrix4(t.matrixWorld),this.intersectsSphere(ri)}intersectsSprite(t){return ri.center.set(0,0,0),ri.radius=.7071067811865476,ri.applyMatrix4(t.matrixWorld),this.intersectsSphere(ri)}intersectsSphere(t){const e=this.planes,n=t.center,i=-t.radius;for(let t=0;t<6;t++){if(e[t].distanceToPoint(n)<i)return!1}return!0}intersectsBox(t){const e=this.planes;for(let n=0;n<6;n++){const i=e[n];if(si.x=i.normal.x>0?t.max.x:t.min.x,si.y=i.normal.y>0?t.max.y:t.min.y,si.z=i.normal.z>0?t.max.z:t.min.z,i.distanceToPoint(si)<0)return!1}return!0}containsPoint(t){const e=this.planes;for(let n=0;n<6;n++)if(e[n].distanceToPoint(t)<0)return!1;return!0}clone(){return(new this.constructor).copy(this)}}function oi(){let t=null,e=!1,n=null,i=null;function r(e,s){n(e,s),i=t.requestAnimationFrame(r)}return{start:function(){!0!==e&&null!==n&&(i=t.requestAnimationFrame(r),e=!0)},stop:function(){t.cancelAnimationFrame(i),e=!1},setAnimationLoop:function(t){n=t},setContext:function(e){t=e}}}function li(t,e){const n=e.isWebGL2,i=new WeakMap;return{get:function(t){return t.isInterleavedBufferAttribute&&(t=t.data),i.get(t)},remove:function(e){e.isInterleavedBufferAttribute&&(e=e.data);const n=i.get(e);n&&(t.deleteBuffer(n.buffer),i.delete(e))},update:function(e,r){if(e.isGLBufferAttribute){const t=i.get(e);return void((!t||t.version<e.version)&&i.set(e,{buffer:e.buffer,type:e.type,bytesPerElement:e.elementSize,version:e.version}))}e.isInterleavedBufferAttribute&&(e=e.data);const s=i.get(e);void 0===s?i.set(e,function(e,i){const r=e.array,s=e.usage,a=t.createBuffer();t.bindBuffer(i,a),t.bufferData(i,r,s),e.onUploadCallback();let o=5126;return r instanceof Float32Array?o=5126:r instanceof Float64Array?console.warn("THREE.WebGLAttributes: Unsupported data buffer format: Float64Array."):r instanceof Uint16Array?e.isFloat16BufferAttribute?n?o=5131:console.warn("THREE.WebGLAttributes: Usage of Float16BufferAttribute requires WebGL2."):o=5123:r instanceof Int16Array?o=5122:r instanceof Uint32Array?o=5125:r instanceof Int32Array?o=5124:r instanceof Int8Array?o=5120:r instanceof Uint8Array&&(o=5121),{buffer:a,type:o,bytesPerElement:r.BYTES_PER_ELEMENT,version:e.version}}(e,r)):s.version<e.version&&(!function(e,i,r){const s=i.array,a=i.updateRange;t.bindBuffer(r,e),-1===a.count?t.bufferSubData(r,0,s):(n?t.bufferSubData(r,a.offset*s.BYTES_PER_ELEMENT,s,a.offset,a.count):t.bufferSubData(r,a.offset*s.BYTES_PER_ELEMENT,s.subarray(a.offset,a.offset+a.count)),a.count=-1)}(s.buffer,e,r),s.version=e.version)}}}class ci extends En{constructor(t=1,e=1,n=1,i=1){super(),this.type="PlaneGeometry",this.parameters={width:t,height:e,widthSegments:n,heightSegments:i};const r=t/2,s=e/2,a=Math.floor(n),o=Math.floor(i),l=a+1,c=o+1,h=t/a,u=e/o,d=[],p=[],m=[],f=[];for(let t=0;t<c;t++){const e=t*u-s;for(let n=0;n<l;n++){const i=n*h-r;p.push(i,-e,0),m.push(0,0,1),f.push(n/a),f.push(1-t/o)}}for(let t=0;t<o;t++)for(let e=0;e<a;e++){const n=e+l*t,i=e+l*(t+1),r=e+1+l*(t+1),s=e+1+l*t;d.push(n,i,s),d.push(i,r,s)}this.setIndex(d),this.setAttribute("position",new mn(p,3)),this.setAttribute("normal",new mn(m,3)),this.setAttribute("uv",new mn(f,2))}}const hi={alphamap_fragment:"#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, vUv ).g;\n#endif",alphamap_pars_fragment:"#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif",alphatest_fragment:"#ifdef ALPHATEST\n\tif ( diffuseColor.a < ALPHATEST ) discard;\n#endif",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.specularRoughness );\n\t#endif\n#endif",aomap_pars_fragment:"#ifdef USE_AOMAP\n\tuniform sampler2D aoMap;\n\tuniform float aoMapIntensity;\n#endif",begin_vertex:"vec3 transformed = vec3( position );",beginnormal_vertex:"vec3 objectNormal = vec3( normal );\n#ifdef USE_TANGENT\n\tvec3 objectTangent = vec3( tangent.xyz );\n#endif",bsdfs:"vec2 integrateSpecularBRDF( const in float dotNV, const in float roughness ) {\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\treturn vec2( -1.04, 1.04 ) * a004 + r.zw;\n}\nfloat punctualLightIntensityToIrradianceFactor( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\tif( cutoffDistance > 0.0 ) {\n\t\tdistanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t}\n\treturn distanceFalloff;\n#else\n\tif( cutoffDistance > 0.0 && decayExponent > 0.0 ) {\n\t\treturn pow( saturate( -lightDistance / cutoffDistance + 1.0 ), decayExponent );\n\t}\n\treturn 1.0;\n#endif\n}\nvec3 BRDF_Diffuse_Lambert( const in vec3 diffuseColor ) {\n\treturn RECIPROCAL_PI * diffuseColor;\n}\nvec3 F_Schlick( const in vec3 specularColor, const in float dotLH ) {\n\tfloat fresnel = exp2( ( -5.55473 * dotLH - 6.98316 ) * dotLH );\n\treturn ( 1.0 - specularColor ) * fresnel + specularColor;\n}\nvec3 F_Schlick_RoughnessDependent( const in vec3 F0, const in float dotNV, const in float roughness ) {\n\tfloat fresnel = exp2( ( -5.55473 * dotNV - 6.98316 ) * dotNV );\n\tvec3 Fr = max( vec3( 1.0 - roughness ), F0 ) - F0;\n\treturn Fr * fresnel + F0;\n}\nfloat G_GGX_Smith( const in float alpha, const in float dotNL, const in float dotNV ) {\n\tfloat a2 = pow2( alpha );\n\tfloat gl = dotNL + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNL ) );\n\tfloat gv = dotNV + sqrt( a2 + ( 1.0 - a2 ) * pow2( dotNV ) );\n\treturn 1.0 / ( gl * gv );\n}\nfloat G_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_Specular_GGX( const in IncidentLight incidentLight, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) {\n\tfloat alpha = pow2( roughness );\n\tvec3 halfDir = normalize( incidentLight.direction + viewDir );\n\tfloat dotNL = saturate( dot( normal, incidentLight.direction ) );\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tfloat dotNH = saturate( dot( normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_GGX_SmithCorrelated( alpha, dotNL, dotNV );\n\tfloat D = D_GGX( alpha, dotNH );\n\treturn F * ( G * D );\n}\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}\nvec3 BRDF_Specular_GGX_Environment( const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float roughness ) {\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tvec2 brdf = integrateSpecularBRDF( dotNV, roughness );\n\treturn specularColor * brdf.x + brdf.y;\n}\nvoid BRDF_Specular_Multiscattering_Environment( const in GeometricContext geometry, const in vec3 specularColor, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\n\tfloat dotNV = saturate( dot( geometry.normal, geometry.viewDir ) );\n\tvec3 F = F_Schlick_RoughnessDependent( specularColor, dotNV, roughness );\n\tvec2 brdf = integrateSpecularBRDF( dotNV, roughness );\n\tvec3 FssEss = F * brdf.x + brdf.y;\n\tfloat Ess = brdf.x + brdf.y;\n\tfloat Ems = 1.0 - Ess;\n\tvec3 Favg = specularColor + ( 1.0 - specularColor ) * 0.047619;\tvec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg );\n\tsingleScatter += FssEss;\n\tmultiScatter += Fms * Ems;\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_Specular_BlinnPhong( const in IncidentLight incidentLight, const in GeometricContext geometry, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir = normalize( incidentLight.direction + geometry.viewDir );\n\tfloat dotNH = saturate( dot( geometry.normal, halfDir ) );\n\tfloat dotLH = saturate( dot( incidentLight.direction, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, dotLH );\n\tfloat G = G_BlinnPhong_Implicit( );\n\tfloat D = D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\nfloat GGXRoughnessToBlinnExponent( const in float ggxRoughness ) {\n\treturn ( 2.0 / pow2( ggxRoughness + 0.0001 ) - 2.0 );\n}\nfloat BlinnExponentToGGXRoughness( const in float blinnExponent ) {\n\treturn sqrt( 2.0 / ( blinnExponent + 2.0 ) );\n}\n#if defined( USE_SHEEN )\nfloat D_Charlie(float roughness, float NoH) {\n\tfloat invAlpha = 1.0 / roughness;\n\tfloat cos2h = NoH * NoH;\n\tfloat sin2h = max(1.0 - cos2h, 0.0078125);\treturn (2.0 + invAlpha) * pow(sin2h, invAlpha * 0.5) / (2.0 * PI);\n}\nfloat V_Neubelt(float NoV, float NoL) {\n\treturn saturate(1.0 / (4.0 * (NoL + NoV - NoL * NoV)));\n}\nvec3 BRDF_Specular_Sheen( const in float roughness, const in vec3 L, const in GeometricContext geometry, vec3 specularColor ) {\n\tvec3 N = geometry.normal;\n\tvec3 V = geometry.viewDir;\n\tvec3 H = normalize( V + L );\n\tfloat dotNH = saturate( dot( N, H ) );\n\treturn specularColor * D_Charlie( roughness, dotNH ) * V_Neubelt( dot(N, V), dot(N, L) );\n}\n#endif",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",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",clipping_planes_pars_fragment:"#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif",clipping_planes_pars_vertex:"#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n#endif",clipping_planes_vertex:"#if NUM_CLIPPING_PLANES > 0\n\tvClipPosition = - mvPosition.xyz;\n#endif",color_fragment:"#if defined( USE_COLOR_ALPHA )\n\tdiffuseColor *= vColor;\n#elif defined( USE_COLOR )\n\tdiffuseColor.rgb *= vColor;\n#endif",color_pars_fragment:"#if defined( USE_COLOR_ALPHA )\n\tvarying vec4 vColor;\n#elif defined( USE_COLOR )\n\tvarying vec3 vColor;\n#endif",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",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",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; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\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 max3( vec3 v ) { return max( max( v.x, v.y ), v.z ); }\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 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}\nvec3 projectOnPlane(in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\tfloat distance = dot( planeNormal, point - pointOnPlane );\n\treturn - distance * planeNormal + point;\n}\nfloat sideOfPlane( in vec3 point, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn sign( dot( point - pointOnPlane, planeNormal ) );\n}\nvec3 linePlaneIntersect( in vec3 pointOnLine, in vec3 lineDirection, in vec3 pointOnPlane, in vec3 planeNormal ) {\n\treturn lineDirection * ( dot( planeNormal, pointOnPlane - pointOnLine ) / dot( planeNormal, lineDirection ) ) + pointOnLine;\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}",cube_uv_reflection_fragment:"#ifdef ENVMAP_TYPE_CUBE_UV\n\t#define cubeUV_maxMipLevel 8.0\n\t#define cubeUV_minMipLevel 4.0\n\t#define cubeUV_maxTileSize 256.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\tfloat texelSize = 1.0 / ( 3.0 * cubeUV_maxTileSize );\n\t\tvec2 uv = getUV( direction, face ) * ( faceSize - 1.0 );\n\t\tvec2 f = fract( uv );\n\t\tuv += 0.5 - f;\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\tif ( mipInt < cubeUV_maxMipLevel ) {\n\t\t\tuv.y += 2.0 * cubeUV_maxTileSize;\n\t\t}\n\t\tuv.y += filterInt * 2.0 * cubeUV_minTileSize;\n\t\tuv.x += 3.0 * max( 0.0, cubeUV_maxTileSize - 2.0 * faceSize );\n\t\tuv *= texelSize;\n\t\tvec3 tl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x += texelSize;\n\t\tvec3 tr = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.y += texelSize;\n\t\tvec3 br = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x -= texelSize;\n\t\tvec3 bl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tvec3 tm = mix( tl, tr, f.x );\n\t\tvec3 bm = mix( bl, br, f.x );\n\t\treturn mix( tm, bm, f.y );\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_maxMipLevel );\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",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",displacementmap_pars_vertex:"#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif",displacementmap_vertex:"#ifdef USE_DISPLACEMENTMAP\n\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias );\n#endif",emissivemap_fragment:"#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\n\temissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *= emissiveColor.rgb;\n#endif",emissivemap_pars_fragment:"#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif",encodings_fragment:"gl_FragColor = linearToOutputTexel( gl_FragColor );",encodings_pars_fragment:"\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a );\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}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent = max( max( value.r, value.g ), value.b );\n\tfloat fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * value.a * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat M = clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM = ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat D = max( maxRange / maxRGB, 1.0 );\n\tD = clamp( floor( D ) / 255.0, 0.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value ) {\n\tvec3 Xp_Y_XYZp = cLogLuvM * value.rgb;\n\tXp_Y_XYZp = max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) );\n\tvec4 vResult;\n\tvResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w = fract( Le );\n\tvResult.z = ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le = value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y = exp2( ( Le - 127.0 ) / 2.0 );\n\tXp_Y_XYZp.z = Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x = value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB = cLogLuvInverseM * Xp_Y_XYZp.rgb;\n\treturn vec4( max( vRGB, 0.0 ), 1.0 );\n}",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#ifndef ENVMAP_TYPE_CUBE_UV\n\t\tenvColor = envMapTexelToLinear( envColor );\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",envmap_common_pars_fragment:"#ifdef USE_ENVMAP\n\tuniform float envMapIntensity;\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\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",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",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",envmap_physical_pars_fragment:"#if defined( USE_ENVMAP )\n\t#ifdef ENVMAP_MODE_REFRACTION\n\t\tuniform float refractionRatio;\n\t#endif\n\tvec3 getLightProbeIndirectIrradiance( const in GeometricContext geometry, const in int maxMIPLevel ) {\n\t\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryVec = vec3( flipEnvMap * worldNormal.x, worldNormal.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryVec, float( maxMIPLevel ) );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 );\n\t\t#else\n\t\t\tvec4 envMapColor = vec4( 0.0 );\n\t\t#endif\n\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t}\n\tfloat getSpecularMIPLevel( const in float roughness, const in int maxMIPLevel ) {\n\t\tfloat maxMIPLevelScalar = float( maxMIPLevel );\n\t\tfloat sigma = PI * roughness * roughness / ( 1.0 + roughness );\n\t\tfloat desiredMIPLevel = maxMIPLevelScalar + log2( sigma );\n\t\treturn clamp( desiredMIPLevel, 0.0, maxMIPLevelScalar );\n\t}\n\tvec3 getLightProbeIndirectRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness, const in int maxMIPLevel ) {\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec = reflect( -viewDir, normal );\n\t\t\treflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\n\t\t#else\n\t\t\tvec3 reflectVec = refract( -viewDir, normal, refractionRatio );\n\t\t#endif\n\t\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\n\t\tfloat specularMIPLevel = getSpecularMIPLevel( roughness, maxMIPLevel );\n\t\t#ifdef ENVMAP_TYPE_CUBE\n\t\t\tvec3 queryReflectVec = vec3( flipEnvMap * reflectVec.x, reflectVec.yz );\n\t\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\t\tvec4 envMapColor = textureCubeLodEXT( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#else\n\t\t\t\tvec4 envMapColor = textureCube( envMap, queryReflectVec, specularMIPLevel );\n\t\t\t#endif\n\t\t\tenvMapColor.rgb = envMapTexelToLinear( envMapColor ).rgb;\n\t\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness );\n\t\t#endif\n\t\treturn envMapColor.rgb * envMapIntensity;\n\t}\n#endif",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",fog_vertex:"#ifdef USE_FOG\n\tfogDepth = - mvPosition.z;\n#endif",fog_pars_vertex:"#ifdef USE_FOG\n\tvarying float fogDepth;\n#endif",fog_fragment:"#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor = 1.0 - exp( - fogDensity * fogDensity * fogDepth * fogDepth );\n\t#else\n\t\tfloat fogFactor = smoothstep( fogNear, fogFar, fogDepth );\n\t#endif\n\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif",fog_pars_fragment:"#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float fogDepth;\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",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 texture2D( gradientMap, coord ).rgb;\n\t#else\n\t\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t#endif\n}",lightmap_fragment:"#ifdef USE_LIGHTMAP\n\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\treflectedLight.indirectDiffuse += PI * lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n#endif",lightmap_pars_fragment:"#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif",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 );\n#ifdef DOUBLE_SIDED\n\tvIndirectBack += getAmbientLightIrradiance( ambientLightColor );\n\tvIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry );\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\tgetPointDirectLightIrradiance( pointLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * 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\tgetSpotDirectLightIrradiance( spotLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * 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\tgetDirectionalDirectLightIrradiance( directionalLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = PI * 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 );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry );\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif",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 GeometricContext geometry ) {\n\tvec3 worldNormal = inverseTransformDirection( geometry.normal, viewMatrix );\n\tvec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );\n\treturn irradiance;\n}\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance = ambientLightColor;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treturn irradiance;\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 getDirectionalDirectLightIrradiance( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tdirectLight.color = directionalLight.color;\n\t\tdirectLight.direction = directionalLight.direction;\n\t\tdirectLight.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 getPointDirectLightIrradiance( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = pointLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tdirectLight.color = pointLight.color;\n\t\tdirectLight.color *= punctualLightIntensityToIrradianceFactor( lightDistance, pointLight.distance, pointLight.decay );\n\t\tdirectLight.visible = ( directLight.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 getSpotDirectLightIrradiance( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight directLight ) {\n\t\tvec3 lVector = spotLight.position - geometry.position;\n\t\tdirectLight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tfloat angleCos = dot( directLight.direction, spotLight.direction );\n\t\tif ( angleCos > spotLight.coneCos ) {\n\t\t\tfloat spotEffect = smoothstep( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\t\tdirectLight.color = spotLight.color;\n\t\t\tdirectLight.color *= spotEffect * punctualLightIntensityToIrradianceFactor( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tdirectLight.visible = true;\n\t\t} else {\n\t\t\tdirectLight.color = vec3( 0.0 );\n\t\t\tdirectLight.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 GeometricContext geometry ) {\n\t\tfloat dotNL = dot( geometry.normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tirradiance *= PI;\n\t\t#endif\n\t\treturn irradiance;\n\t}\n#endif",lights_toon_fragment:"ToonMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;",lights_toon_pars_fragment:"varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\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\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_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_Diffuse_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)",lights_phong_fragment:"BlinnPhongMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;\nmaterial.specularColor = specular;\nmaterial.specularShininess = shininess;\nmaterial.specularStrength = specularStrength;",lights_phong_pars_fragment:"varying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\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\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\treflectedLight.directDiffuse += irradiance * BRDF_Diffuse_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular += irradiance * BRDF_Specular_BlinnPhong( directLight, geometry, 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_Diffuse_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)",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.specularRoughness = max( roughnessFactor, 0.0525 );material.specularRoughness += geometryRoughness;\nmaterial.specularRoughness = min( material.specularRoughness, 1.0 );\n#ifdef REFLECTIVITY\n\tmaterial.specularColor = mix( vec3( MAXIMUM_SPECULAR_COEFFICIENT * pow2( reflectivity ) ), diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor = mix( vec3( DEFAULT_SPECULAR_COEFFICIENT ), diffuseColor.rgb, metalnessFactor );\n#endif\n#ifdef CLEARCOAT\n\tmaterial.clearcoat = clearcoat;\n\tmaterial.clearcoatRoughness = clearcoatRoughness;\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_SHEEN\n\tmaterial.sheenColor = sheen;\n#endif",lights_physical_pars_fragment:"struct PhysicalMaterial {\n\tvec3 diffuseColor;\n\tfloat specularRoughness;\n\tvec3 specularColor;\n#ifdef CLEARCOAT\n\tfloat clearcoat;\n\tfloat clearcoatRoughness;\n#endif\n#ifdef USE_SHEEN\n\tvec3 sheenColor;\n#endif\n};\n#define MAXIMUM_SPECULAR_COEFFICIENT 0.16\n#define DEFAULT_SPECULAR_COEFFICIENT 0.04\nfloat clearcoatDHRApprox( const in float roughness, const in float dotNL ) {\n\treturn DEFAULT_SPECULAR_COEFFICIENT + ( 1.0 - DEFAULT_SPECULAR_COEFFICIENT ) * ( pow( 1.0 - dotNL, 5.0 ) * pow( 1.0 - roughness, 2.0 ) );\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.specularRoughness;\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#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tirradiance *= PI;\n\t#endif\n\t#ifdef CLEARCOAT\n\t\tfloat ccDotNL = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\n\t\tvec3 ccIrradiance = ccDotNL * directLight.color;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tccIrradiance *= PI;\n\t\t#endif\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t\treflectedLight.directSpecular += ccIrradiance * material.clearcoat * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\t#ifdef USE_SHEEN\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_Sheen(\n\t\t\tmaterial.specularRoughness,\n\t\t\tdirectLight.direction,\n\t\t\tgeometry,\n\t\t\tmaterial.sheenColor\n\t\t);\n\t#else\n\t\treflectedLight.directSpecular += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Specular_GGX( directLight, geometry.viewDir, geometry.normal, material.specularColor, material.specularRoughness);\n\t#endif\n\treflectedLight.directDiffuse += ( 1.0 - clearcoatDHR ) * irradiance * BRDF_Diffuse_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_Diffuse_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 CLEARCOAT\n\t\tfloat ccDotNV = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\n\t\treflectedLight.indirectSpecular += clearcoatRadiance * material.clearcoat * BRDF_Specular_GGX_Environment( geometry.viewDir, geometry.clearcoatNormal, vec3( DEFAULT_SPECULAR_COEFFICIENT ), material.clearcoatRoughness );\n\t\tfloat ccDotNL = ccDotNV;\n\t\tfloat clearcoatDHR = material.clearcoat * clearcoatDHRApprox( material.clearcoatRoughness, ccDotNL );\n\t#else\n\t\tfloat clearcoatDHR = 0.0;\n\t#endif\n\tfloat clearcoatInv = 1.0 - clearcoatDHR;\n\tvec3 singleScattering = vec3( 0.0 );\n\tvec3 multiScattering = vec3( 0.0 );\n\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\n\tBRDF_Specular_Multiscattering_Environment( geometry, material.specularColor, material.specularRoughness, singleScattering, multiScattering );\n\tvec3 diffuse = material.diffuseColor * ( 1.0 - ( singleScattering + multiScattering ) );\n\treflectedLight.indirectSpecular += clearcoatInv * 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}",lights_fragment_begin:"\nGeometricContext geometry;\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n#ifdef CLEARCOAT\n\tgeometry.clearcoatNormal = clearcoatNormal;\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\tgetPointDirectLightIrradiance( 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\tgetSpotDirectLightIrradiance( 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\tgetDirectionalDirectLightIrradiance( 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 );\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 );\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",lights_fragment_maps:"#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\tvec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *= PI;\n\t\t#endif\n\t\tirradiance += lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\n\t\tiblIrradiance += getLightProbeIndirectIrradiance( geometry, maxMipLevel );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\tradiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.normal, material.specularRoughness, maxMipLevel );\n\t#ifdef CLEARCOAT\n\t\tclearcoatRadiance += getLightProbeIndirectRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness, maxMipLevel );\n\t#endif\n#endif",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",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",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",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",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",map_fragment:"#ifdef USE_MAP\n\tvec4 texelColor = texture2D( map, vUv );\n\ttexelColor = mapTexelToLinear( texelColor );\n\tdiffuseColor *= texelColor;\n#endif",map_pars_fragment:"#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif",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\tvec4 mapTexel = texture2D( map, uv );\n\tdiffuseColor *= mapTexelToLinear( mapTexel );\n#endif\n#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\n#endif",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",metalnessmap_fragment:"float metalnessFactor = metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\n\tmetalnessFactor *= texelMetalness.b;\n#endif",metalnessmap_pars_fragment:"#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif",morphnormal_vertex:"#ifdef USE_MORPHNORMALS\n\tobjectNormal *= morphTargetBaseInfluence;\n\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\n\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\n\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\n\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\n#endif",morphtarget_pars_vertex:"#ifdef USE_MORPHTARGETS\n\tuniform float morphTargetBaseInfluence;\n\t#ifndef USE_MORPHNORMALS\n\t\tuniform float morphTargetInfluences[ 8 ];\n\t#else\n\t\tuniform float morphTargetInfluences[ 4 ];\n\t#endif\n#endif",morphtarget_vertex:"#ifdef USE_MORPHTARGETS\n\ttransformed *= morphTargetBaseInfluence;\n\ttransformed += morphTarget0 * morphTargetInfluences[ 0 ];\n\ttransformed += morphTarget1 * morphTargetInfluences[ 1 ];\n\ttransformed += morphTarget2 * morphTargetInfluences[ 2 ];\n\ttransformed += morphTarget3 * morphTargetInfluences[ 3 ];\n\t#ifndef USE_MORPHNORMALS\n\t\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\n\t\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\n\t\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\n\t\ttransformed += morphTarget7 * morphTargetInfluences[ 7 ];\n\t#endif\n#endif",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;",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",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",clearcoat_normal_fragment_begin:"#ifdef CLEARCOAT\n\tvec3 clearcoatNormal = geometryNormal;\n#endif",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",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",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}",premultiplied_alpha_fragment:"#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *= gl_FragColor.a;\n#endif",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;",dithering_fragment:"#ifdef DITHERING\n\tgl_FragColor.rgb = dithering( gl_FragColor.rgb );\n#endif",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",roughnessmap_fragment:"float roughnessFactor = roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\n\troughnessFactor *= texelRoughness.g;\n#endif",roughnessmap_pars_fragment:"#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif",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",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",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",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}",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",skinning_pars_vertex:"#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform highp sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j = i * 4.0;\n\t\t\tfloat x = mod( j, float( boneTextureSize ) );\n\t\t\tfloat y = floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx = 1.0 / float( boneTextureSize );\n\t\t\tfloat dy = 1.0 / float( boneTextureSize );\n\t\t\ty = dy * ( y + 0.5 );\n\t\t\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone = mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone = boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif",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",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",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",specularmap_pars_fragment:"#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif",tonemapping_fragment:"#if defined( TONE_MAPPING )\n\tgl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\n#endif",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; }",transmissionmap_fragment:"#ifdef USE_TRANSMISSIONMAP\n\ttotalTransmission *= texture2D( transmissionMap, vUv ).r;\n#endif",transmissionmap_pars_fragment:"#ifdef USE_TRANSMISSIONMAP\n\tuniform sampler2D transmissionMap;\n#endif",uv_pars_fragment:"#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) )\n\tvarying vec2 vUv;\n#endif",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",uv_vertex:"#ifdef USE_UV\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif",uv2_pars_fragment:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif",uv2_pars_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n\tuniform mat3 uv2Transform;\n#endif",uv2_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;\n#endif",worldpos_vertex:"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP )\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",background_frag:"uniform sampler2D t2D;\nvarying vec2 vUv;\nvoid main() {\n\tvec4 texColor = texture2D( t2D, vUv );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n}",background_vert:"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}",cube_frag:"#include <envmap_common_pars_fragment>\nuniform float opacity;\nvarying vec3 vWorldDirection;\n#include <cube_uv_reflection_fragment>\nvoid main() {\n\tvec3 vReflect = vWorldDirection;\n\t#include <envmap_fragment>\n\tgl_FragColor = envColor;\n\tgl_FragColor.a *= opacity;\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n}",cube_vert:"varying vec3 vWorldDirection;\n#include <common>\nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\tgl_Position.z = gl_Position.w;\n}",depth_frag:"#if DEPTH_PACKING == 3200\n\tuniform float opacity;\n#endif\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#if DEPTH_PACKING == 3200\n\t\tdiffuseColor.a = opacity;\n\t#endif\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <logdepthbuf_fragment>\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}",depth_vert:"#include <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvHighPrecisionZW = gl_Position.zw;\n}",distanceRGBA_frag:"#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include <common>\n#include <packing>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main () {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( 1.0 );\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\tfloat dist = length( vWorldPosition - referencePosition );\n\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist = saturate( dist );\n\tgl_FragColor = packDepthToRGBA( dist );\n}",distanceRGBA_vert:"#define DISTANCE\nvarying vec3 vWorldPosition;\n#include <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include <beginnormal_vertex>\n\t\t#include <morphnormal_vertex>\n\t\t#include <skinnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\tvWorldPosition = worldPosition.xyz;\n}",equirect_frag:"uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include <common>\nvoid main() {\n\tvec3 direction = normalize( vWorldDirection );\n\tvec2 sampleUV = equirectUv( direction );\n\tvec4 texColor = texture2D( tEquirect, sampleUV );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n}",equirect_vert:"varying vec3 vWorldDirection;\n#include <common>\nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include <begin_vertex>\n\t#include <project_vertex>\n}",linedashed_frag:"uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <color_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n}",linedashed_vert:"uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\tvLineDistance = scale * lineDistance;\n\t#include <color_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n}",meshbasic_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <fog_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\treflectedLight.indirectDiffuse += lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse += vec3( 1.0 );\n\t#endif\n\t#include <aomap_fragment>\n\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\n\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshbasic_vert:"#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <skinbase_vertex>\n\t#ifdef USE_ENVMAP\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <worldpos_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <envmap_vertex>\n\t#include <fog_vertex>\n}",meshlambert_frag:"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 <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <fog_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <emissivemap_fragment>\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 <lightmap_fragment>\n\treflectedLight.indirectDiffuse *= BRDF_Diffuse_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_Diffuse_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshlambert_vert:"#define LAMBERT\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <envmap_pars_vertex>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <lights_lambert_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",meshmatcap_frag:"#define MATCAP\nuniform vec3 diffuse;\nuniform float opacity;\nuniform sampler2D matcap;\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\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\tmatcapColor = matcapTexelToLinear( matcapColor );\n\t#else\n\t\tvec4 matcapColor = vec4( 1.0 );\n\t#endif\n\tvec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshmatcap_vert:"#define MATCAP\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <color_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#ifndef FLAT_SHADED\n\t\tvNormal = normalize( transformedNormal );\n\t#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n\tvViewPosition = - mvPosition.xyz;\n}",meshtoon_frag:"#define TOON\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <gradientmap_pars_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_toon_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_toon_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshtoon_vert:"#define TOON\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",meshphong_frag:"#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_pars_fragment>\n#include <cube_uv_reflection_fragment>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <lights_phong_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <specularmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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 <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <specularmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <lights_phong_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include <envmap_fragment>\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshphong_vert:"#define PHONG\nvarying vec3 vViewPosition;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <envmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n#endif\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <envmap_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",meshphysical_frag:"#define STANDARD\n#ifdef PHYSICAL\n\t#define REFLECTIVITY\n\t#define CLEARCOAT\n\t#define TRANSMISSION\n#endif\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifdef TRANSMISSION\n\tuniform float transmission;\n#endif\n#ifdef REFLECTIVITY\n\tuniform float reflectivity;\n#endif\n#ifdef CLEARCOAT\n\tuniform float clearcoat;\n\tuniform float clearcoatRoughness;\n#endif\n#ifdef USE_SHEEN\n\tuniform vec3 sheen;\n#endif\nvarying vec3 vViewPosition;\n#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#include <common>\n#include <packing>\n#include <dithering_pars_fragment>\n#include <color_pars_fragment>\n#include <uv_pars_fragment>\n#include <uv2_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <aomap_pars_fragment>\n#include <lightmap_pars_fragment>\n#include <emissivemap_pars_fragment>\n#include <transmissionmap_pars_fragment>\n#include <bsdfs>\n#include <cube_uv_reflection_fragment>\n#include <envmap_common_pars_fragment>\n#include <envmap_physical_pars_fragment>\n#include <fog_pars_fragment>\n#include <lights_pars_begin>\n#include <lights_physical_pars_fragment>\n#include <shadowmap_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <clearcoat_pars_fragment>\n#include <roughnessmap_pars_fragment>\n#include <metalnessmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\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#ifdef TRANSMISSION\n\t\tfloat totalTransmission = transmission;\n\t#endif\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <color_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\t#include <roughnessmap_fragment>\n\t#include <metalnessmap_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\t#include <clearcoat_normal_fragment_begin>\n\t#include <clearcoat_normal_fragment_maps>\n\t#include <emissivemap_fragment>\n\t#include <transmissionmap_fragment>\n\t#include <lights_physical_fragment>\n\t#include <lights_fragment_begin>\n\t#include <lights_fragment_maps>\n\t#include <lights_fragment_end>\n\t#include <aomap_fragment>\n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#ifdef TRANSMISSION\n\t\tdiffuseColor.a *= mix( saturate( 1. - totalTransmission + linearToRelativeLuminance( reflectedLight.directSpecular + reflectedLight.indirectSpecular ) ), 1.0, metalness );\n\t#endif\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n\t#include <dithering_fragment>\n}",meshphysical_vert:"#define STANDARD\nvarying vec3 vViewPosition;\n#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#include <common>\n#include <uv_pars_vertex>\n#include <uv2_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <shadowmap_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <uv2_vertex>\n\t#include <color_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#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\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\tvViewPosition = - mvPosition.xyz;\n\t#include <worldpos_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",normal_frag:"#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#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#include <packing>\n#include <uv_pars_fragment>\n#include <bumpmap_pars_fragment>\n#include <normalmap_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\t#include <logdepthbuf_fragment>\n\t#include <normal_fragment_begin>\n\t#include <normal_fragment_maps>\n\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\n}",normal_vert:"#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#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#include <common>\n#include <uv_pars_vertex>\n#include <displacementmap_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <skinning_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n#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\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <skinning_vertex>\n\t#include <displacementmap_vertex>\n\t#include <project_vertex>\n\t#include <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvViewPosition = - mvPosition.xyz;\n#endif\n}",points_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include <common>\n#include <color_pars_fragment>\n#include <map_particle_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_particle_fragment>\n\t#include <color_fragment>\n\t#include <alphatest_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n\t#include <premultiplied_alpha_fragment>\n}",points_vert:"uniform float size;\nuniform float scale;\n#include <common>\n#include <color_pars_vertex>\n#include <fog_pars_vertex>\n#include <morphtarget_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <color_vertex>\n\t#include <begin_vertex>\n\t#include <morphtarget_vertex>\n\t#include <project_vertex>\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 <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <worldpos_vertex>\n\t#include <fog_vertex>\n}",shadow_frag:"uniform vec3 color;\nuniform float opacity;\n#include <common>\n#include <packing>\n#include <fog_pars_fragment>\n#include <bsdfs>\n#include <lights_pars_begin>\n#include <shadowmap_pars_fragment>\n#include <shadowmask_pars_fragment>\nvoid main() {\n\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}",shadow_vert:"#include <common>\n#include <fog_pars_vertex>\n#include <shadowmap_pars_vertex>\nvoid main() {\n\t#include <begin_vertex>\n\t#include <project_vertex>\n\t#include <worldpos_vertex>\n\t#include <beginnormal_vertex>\n\t#include <morphnormal_vertex>\n\t#include <skinbase_vertex>\n\t#include <skinnormal_vertex>\n\t#include <defaultnormal_vertex>\n\t#include <shadowmap_vertex>\n\t#include <fog_vertex>\n}",sprite_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include <common>\n#include <uv_pars_fragment>\n#include <map_pars_fragment>\n#include <alphamap_pars_fragment>\n#include <fog_pars_fragment>\n#include <logdepthbuf_pars_fragment>\n#include <clipping_planes_pars_fragment>\nvoid main() {\n\t#include <clipping_planes_fragment>\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include <logdepthbuf_fragment>\n\t#include <map_fragment>\n\t#include <alphamap_fragment>\n\t#include <alphatest_fragment>\n\toutgoingLight = diffuseColor.rgb;\n\tgl_FragColor = vec4( outgoingLight, diffuseColor.a );\n\t#include <tonemapping_fragment>\n\t#include <encodings_fragment>\n\t#include <fog_fragment>\n}",sprite_vert:"uniform float rotation;\nuniform vec2 center;\n#include <common>\n#include <uv_pars_vertex>\n#include <fog_pars_vertex>\n#include <logdepthbuf_pars_vertex>\n#include <clipping_planes_pars_vertex>\nvoid main() {\n\t#include <uv_vertex>\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 <logdepthbuf_vertex>\n\t#include <clipping_planes_vertex>\n\t#include <fog_vertex>\n}"},ui={common:{diffuse:{value:new tn(15658734)},opacity:{value:1},map:{value:null},uvTransform:{value:new yt},uv2Transform:{value:new yt},alphaMap:{value:null}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1},refractionRatio:{value:.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new vt(1,1)}},displacementmap:{displacementMap:{value:null},displacementScale:{value:1},displacementBias:{value:0}},roughnessmap:{roughnessMap:{value:null}},metalnessmap:{metalnessMap:{value:null}},gradientmap:{gradientMap:{value:null}},fog:{fogDensity:{value:25e-5},fogNear:{value:1},fogFar:{value:2e3},fogColor:{value:new tn(16777215)}},lights:{ambientLightColor:{value:[]},lightProbe:{value:[]},directionalLights:{value:[],properties:{direction:{},color:{}}},directionalLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{}}},directionalShadowMap:{value:[]},directionalShadowMatrix:{value:[]},spotLights:{value:[],properties:{color:{},position:{},direction:{},distance:{},coneCos:{},penumbraCos:{},decay:{}}},spotLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{}}},spotShadowMap:{value:[]},spotShadowMatrix:{value:[]},pointLights:{value:[],properties:{color:{},position:{},decay:{},distance:{}}},pointLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{},shadowCameraNear:{},shadowCameraFar:{}}},pointShadowMap:{value:[]},pointShadowMatrix:{value:[]},hemisphereLights:{value:[],properties:{direction:{},skyColor:{},groundColor:{}}},rectAreaLights:{value:[],properties:{color:{},position:{},width:{},height:{}}},ltc_1:{value:null},ltc_2:{value:null}},points:{diffuse:{value:new tn(15658734)},opacity:{value:1},size:{value:1},scale:{value:1},map:{value:null},alphaMap:{value:null},uvTransform:{value:new yt}},sprite:{diffuse:{value:new tn(15658734)},opacity:{value:1},center:{value:new vt(.5,.5)},rotation:{value:0},map:{value:null},alphaMap:{value:null},uvTransform:{value:new yt}}},di={basic:{uniforms:Yn([ui.common,ui.specularmap,ui.envmap,ui.aomap,ui.lightmap,ui.fog]),vertexShader:hi.meshbasic_vert,fragmentShader:hi.meshbasic_frag},lambert:{uniforms:Yn([ui.common,ui.specularmap,ui.envmap,ui.aomap,ui.lightmap,ui.emissivemap,ui.fog,ui.lights,{emissive:{value:new tn(0)}}]),vertexShader:hi.meshlambert_vert,fragmentShader:hi.meshlambert_frag},phong:{uniforms:Yn([ui.common,ui.specularmap,ui.envmap,ui.aomap,ui.lightmap,ui.emissivemap,ui.bumpmap,ui.normalmap,ui.displacementmap,ui.fog,ui.lights,{emissive:{value:new tn(0)},specular:{value:new tn(1118481)},shininess:{value:30}}]),vertexShader:hi.meshphong_vert,fragmentShader:hi.meshphong_frag},standard:{uniforms:Yn([ui.common,ui.envmap,ui.aomap,ui.lightmap,ui.emissivemap,ui.bumpmap,ui.normalmap,ui.displacementmap,ui.roughnessmap,ui.metalnessmap,ui.fog,ui.lights,{emissive:{value:new tn(0)},roughness:{value:1},metalness:{value:0},envMapIntensity:{value:1}}]),vertexShader:hi.meshphysical_vert,fragmentShader:hi.meshphysical_frag},toon:{uniforms:Yn([ui.common,ui.aomap,ui.lightmap,ui.emissivemap,ui.bumpmap,ui.normalmap,ui.displacementmap,ui.gradientmap,ui.fog,ui.lights,{emissive:{value:new tn(0)}}]),vertexShader:hi.meshtoon_vert,fragmentShader:hi.meshtoon_frag},matcap:{uniforms:Yn([ui.common,ui.bumpmap,ui.normalmap,ui.displacementmap,ui.fog,{matcap:{value:null}}]),vertexShader:hi.meshmatcap_vert,fragmentShader:hi.meshmatcap_frag},points:{uniforms:Yn([ui.points,ui.fog]),vertexShader:hi.points_vert,fragmentShader:hi.points_frag},dashed:{uniforms:Yn([ui.common,ui.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:hi.linedashed_vert,fragmentShader:hi.linedashed_frag},depth:{uniforms:Yn([ui.common,ui.displacementmap]),vertexShader:hi.depth_vert,fragmentShader:hi.depth_frag},normal:{uniforms:Yn([ui.common,ui.bumpmap,ui.normalmap,ui.displacementmap,{opacity:{value:1}}]),vertexShader:hi.normal_vert,fragmentShader:hi.normal_frag},sprite:{uniforms:Yn([ui.sprite,ui.fog]),vertexShader:hi.sprite_vert,fragmentShader:hi.sprite_frag},background:{uniforms:{uvTransform:{value:new yt},t2D:{value:null}},vertexShader:hi.background_vert,fragmentShader:hi.background_frag},cube:{uniforms:Yn([ui.envmap,{opacity:{value:1}}]),vertexShader:hi.cube_vert,fragmentShader:hi.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:hi.equirect_vert,fragmentShader:hi.equirect_frag},distanceRGBA:{uniforms:Yn([ui.common,ui.displacementmap,{referencePosition:{value:new Lt},nearDistance:{value:1},farDistance:{value:1e3}}]),vertexShader:hi.distanceRGBA_vert,fragmentShader:hi.distanceRGBA_frag},shadow:{uniforms:Yn([ui.lights,ui.fog,{color:{value:new tn(0)},opacity:{value:1}}]),vertexShader:hi.shadow_vert,fragmentShader:hi.shadow_frag}};function pi(t,e,n,i,r){const s=new tn(0);let a,o,c=0,h=null,u=0,d=null;function p(t,e){n.buffers.color.setClear(t.r,t.g,t.b,e,r)}return{getClearColor:function(){return s},setClearColor:function(t,e=1){s.set(t),c=e,p(s,c)},getClearAlpha:function(){return c},setClearAlpha:function(t){c=t,p(s,c)},render:function(n,r,m,f){let g=!0===r.isScene?r.background:null;g&&g.isTexture&&(g=e.get(g));const v=t.xr,y=v.getSession&&v.getSession();y&&"additive"===y.environmentBlendMode&&(g=null),null===g?p(s,c):g&&g.isColor&&(p(g,1),f=!0),(t.autoClear||f)&&t.clear(t.autoClearColor,t.autoClearDepth,t.autoClearStencil),g&&(g.isCubeTexture||g.mapping===l)?(void 0===o&&(o=new Wn(new qn(1,1,1),new Jn({name:"BackgroundCubeMaterial",uniforms:Xn(di.cube.uniforms),vertexShader:di.cube.vertexShader,fragmentShader:di.cube.fragmentShader,side:1,depthTest:!1,depthWrite:!1,fog:!1})),o.geometry.deleteAttribute("normal"),o.geometry.deleteAttribute("uv"),o.onBeforeRender=function(t,e,n){this.matrixWorld.copyPosition(n.matrixWorld)},Object.defineProperty(o.material,"envMap",{get:function(){return this.uniforms.envMap.value}}),i.update(o)),o.material.uniforms.envMap.value=g,o.material.uniforms.flipEnvMap.value=g.isCubeTexture&&g._needsFlipEnvMap?-1:1,h===g&&u===g.version&&d===t.toneMapping||(o.material.needsUpdate=!0,h=g,u=g.version,d=t.toneMapping),n.unshift(o,o.geometry,o.material,0,0,null)):g&&g.isTexture&&(void 0===a&&(a=new Wn(new ci(2,2),new Jn({name:"BackgroundMaterial",uniforms:Xn(di.background.uniforms),vertexShader:di.background.vertexShader,fragmentShader:di.background.fragmentShader,side:0,depthTest:!1,depthWrite:!1,fog:!1})),a.geometry.deleteAttribute("normal"),Object.defineProperty(a.material,"map",{get:function(){return this.uniforms.t2D.value}}),i.update(a)),a.material.uniforms.t2D.value=g,!0===g.matrixAutoUpdate&&g.updateMatrix(),a.material.uniforms.uvTransform.value.copy(g.matrix),h===g&&u===g.version&&d===t.toneMapping||(a.material.needsUpdate=!0,h=g,u=g.version,d=t.toneMapping),n.unshift(a,a.geometry,a.material,0,0,null))}}}function mi(t,e,n,i){const r=t.getParameter(34921),s=i.isWebGL2?null:e.get("OES_vertex_array_object"),a=i.isWebGL2||null!==s,o={},l=d(null);let c=l;function h(e){return i.isWebGL2?t.bindVertexArray(e):s.bindVertexArrayOES(e)}function u(e){return i.isWebGL2?t.deleteVertexArray(e):s.deleteVertexArrayOES(e)}function d(t){const e=[],n=[],i=[];for(let t=0;t<r;t++)e[t]=0,n[t]=0,i[t]=0;return{geometry:null,program:null,wireframe:!1,newAttributes:e,enabledAttributes:n,attributeDivisors:i,object:t,attributes:{},index:null}}function p(){const t=c.newAttributes;for(let e=0,n=t.length;e<n;e++)t[e]=0}function m(t){f(t,0)}function f(n,r){const s=c.newAttributes,a=c.enabledAttributes,o=c.attributeDivisors;if(s[n]=1,0===a[n]&&(t.enableVertexAttribArray(n),a[n]=1),o[n]!==r){(i.isWebGL2?t:e.get("ANGLE_instanced_arrays"))[i.isWebGL2?"vertexAttribDivisor":"vertexAttribDivisorANGLE"](n,r),o[n]=r}}function g(){const e=c.newAttributes,n=c.enabledAttributes;for(let i=0,r=n.length;i<r;i++)n[i]!==e[i]&&(t.disableVertexAttribArray(i),n[i]=0)}function v(e,n,r,s,a,o){!0!==i.isWebGL2||5124!==r&&5125!==r?t.vertexAttribPointer(e,n,r,s,a,o):t.vertexAttribIPointer(e,n,r,a,o)}function y(){x(),c!==l&&(c=l,h(c.object))}function x(){l.geometry=null,l.program=null,l.wireframe=!1}return{setup:function(r,l,u,y,x){let _=!1;if(a){const e=function(e,n,r){const a=!0===r.wireframe;let l=o[e.id];void 0===l&&(l={},o[e.id]=l);let c=l[n.id];void 0===c&&(c={},l[n.id]=c);let h=c[a];void 0===h&&(h=d(i.isWebGL2?t.createVertexArray():s.createVertexArrayOES()),c[a]=h);return h}(y,u,l);c!==e&&(c=e,h(c.object)),_=function(t,e){const n=c.attributes,i=t.attributes;let r=0;for(const t in i){const e=n[t],s=i[t];if(void 0===e)return!0;if(e.attribute!==s)return!0;if(e.data!==s.data)return!0;r++}return c.attributesNum!==r||c.index!==e}(y,x),_&&function(t,e){const n={},i=t.attributes;let r=0;for(const t in i){const e=i[t],s={};s.attribute=e,e.data&&(s.data=e.data),n[t]=s,r++}c.attributes=n,c.attributesNum=r,c.index=e}(y,x)}else{const t=!0===l.wireframe;c.geometry===y.id&&c.program===u.id&&c.wireframe===t||(c.geometry=y.id,c.program=u.id,c.wireframe=t,_=!0)}!0===r.isInstancedMesh&&(_=!0),null!==x&&n.update(x,34963),_&&(!function(r,s,a,o){if(!1===i.isWebGL2&&(r.isInstancedMesh||o.isInstancedBufferGeometry)&&null===e.get("ANGLE_instanced_arrays"))return;p();const l=o.attributes,c=a.getAttributes(),h=s.defaultAttributeValues;for(const e in c){const i=c[e];if(i>=0){const s=l[e];if(void 0!==s){const e=s.normalized,r=s.itemSize,a=n.get(s);if(void 0===a)continue;const l=a.buffer,c=a.type,h=a.bytesPerElement;if(s.isInterleavedBufferAttribute){const n=s.data,a=n.stride,u=s.offset;n&&n.isInstancedInterleavedBuffer?(f(i,n.meshPerAttribute),void 0===o._maxInstanceCount&&(o._maxInstanceCount=n.meshPerAttribute*n.count)):m(i),t.bindBuffer(34962,l),v(i,r,c,e,a*h,u*h)}else s.isInstancedBufferAttribute?(f(i,s.meshPerAttribute),void 0===o._maxInstanceCount&&(o._maxInstanceCount=s.meshPerAttribute*s.count)):m(i),t.bindBuffer(34962,l),v(i,r,c,e,0,0)}else if("instanceMatrix"===e){const e=n.get(r.instanceMatrix);if(void 0===e)continue;const s=e.buffer,a=e.type;f(i+0,1),f(i+1,1),f(i+2,1),f(i+3,1),t.bindBuffer(34962,s),t.vertexAttribPointer(i+0,4,a,!1,64,0),t.vertexAttribPointer(i+1,4,a,!1,64,16),t.vertexAttribPointer(i+2,4,a,!1,64,32),t.vertexAttribPointer(i+3,4,a,!1,64,48)}else if("instanceColor"===e){const e=n.get(r.instanceColor);if(void 0===e)continue;const s=e.buffer,a=e.type;f(i,1),t.bindBuffer(34962,s),t.vertexAttribPointer(i,3,a,!1,12,0)}else if(void 0!==h){const n=h[e];if(void 0!==n)switch(n.length){case 2:t.vertexAttrib2fv(i,n);break;case 3:t.vertexAttrib3fv(i,n);break;case 4:t.vertexAttrib4fv(i,n);break;default:t.vertexAttrib1fv(i,n)}}}}g()}(r,l,u,y),null!==x&&t.bindBuffer(34963,n.get(x).buffer))},reset:y,resetDefaultState:x,dispose:function(){y();for(const t in o){const e=o[t];for(const t in e){const n=e[t];for(const t in n)u(n[t].object),delete n[t];delete e[t]}delete o[t]}},releaseStatesOfGeometry:function(t){if(void 0===o[t.id])return;const e=o[t.id];for(const t in e){const n=e[t];for(const t in n)u(n[t].object),delete n[t];delete e[t]}delete o[t.id]},releaseStatesOfProgram:function(t){for(const e in o){const n=o[e];if(void 0===n[t.id])continue;const i=n[t.id];for(const t in i)u(i[t].object),delete i[t];delete n[t.id]}},initAttributes:p,enableAttribute:m,disableUnusedAttributes:g}}function fi(t,e,n,i){const r=i.isWebGL2;let s;this.setMode=function(t){s=t},this.render=function(e,i){t.drawArrays(s,e,i),n.update(i,s,1)},this.renderInstances=function(i,a,o){if(0===o)return;let l,c;if(r)l=t,c="drawArraysInstanced";else if(l=e.get("ANGLE_instanced_arrays"),c="drawArraysInstancedANGLE",null===l)return void console.error("THREE.WebGLBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");l[c](s,i,a,o),n.update(a,s,o)}}function gi(t,e,n){let i;function r(e){if("highp"===e){if(t.getShaderPrecisionFormat(35633,36338).precision>0&&t.getShaderPrecisionFormat(35632,36338).precision>0)return"highp";e="mediump"}return"mediump"===e&&t.getShaderPrecisionFormat(35633,36337).precision>0&&t.getShaderPrecisionFormat(35632,36337).precision>0?"mediump":"lowp"}const s="undefined"!=typeof WebGL2RenderingContext&&t instanceof WebGL2RenderingContext||"undefined"!=typeof WebGL2ComputeRenderingContext&&t instanceof WebGL2ComputeRenderingContext;let a=void 0!==n.precision?n.precision:"highp";const o=r(a);o!==a&&(console.warn("THREE.WebGLRenderer:",a,"not supported, using",o,"instead."),a=o);const l=!0===n.logarithmicDepthBuffer,c=t.getParameter(34930),h=t.getParameter(35660),u=t.getParameter(3379),d=t.getParameter(34076),p=t.getParameter(34921),m=t.getParameter(36347),f=t.getParameter(36348),g=t.getParameter(36349),v=h>0,y=s||e.has("OES_texture_float");return{isWebGL2:s,getMaxAnisotropy:function(){if(void 0!==i)return i;if(!0===e.has("EXT_texture_filter_anisotropic")){const n=e.get("EXT_texture_filter_anisotropic");i=t.getParameter(n.MAX_TEXTURE_MAX_ANISOTROPY_EXT)}else i=0;return i},getMaxPrecision:r,precision:a,logarithmicDepthBuffer:l,maxTextures:c,maxVertexTextures:h,maxTextureSize:u,maxCubemapSize:d,maxAttributes:p,maxVertexUniforms:m,maxVaryings:f,maxFragmentUniforms:g,vertexTextures:v,floatFragmentTextures:y,floatVertexTextures:v&&y,maxSamples:s?t.getParameter(36183):0}}function vi(t){const e=this;let n=null,i=0,r=!1,s=!1;const a=new Ne,o=new yt,l={value:null,needsUpdate:!1};function c(){l.value!==n&&(l.value=n,l.needsUpdate=i>0),e.numPlanes=i,e.numIntersection=0}function h(t,n,i,r){const s=null!==t?t.length:0;let c=null;if(0!==s){if(c=l.value,!0!==r||null===c){const e=i+4*s,r=n.matrixWorldInverse;o.getNormalMatrix(r),(null===c||c.length<e)&&(c=new Float32Array(e));for(let e=0,n=i;e!==s;++e,n+=4)a.copy(t[e]).applyMatrix4(r,o),a.normal.toArray(c,n),c[n+3]=a.constant}l.value=c,l.needsUpdate=!0}return e.numPlanes=s,e.numIntersection=0,c}this.uniform=l,this.numPlanes=0,this.numIntersection=0,this.init=function(t,e,s){const a=0!==t.length||e||0!==i||r;return r=e,n=h(t,s,0),i=t.length,a},this.beginShadows=function(){s=!0,h(null)},this.endShadows=function(){s=!1,c()},this.setState=function(e,a,o){const u=e.clippingPlanes,d=e.clipIntersection,p=e.clipShadows,m=t.get(e);if(!r||null===u||0===u.length||s&&!p)s?h(null):c();else{const t=s?0:i,e=4*t;let r=m.clippingState||null;l.value=r,r=h(u,a,e,o);for(let t=0;t!==e;++t)r[t]=n[t];m.clippingState=r,this.numIntersection=d?this.numPlanes:0,this.numPlanes+=t}}}function yi(t){let e=new WeakMap;function n(t,e){return e===a?t.mapping=r:e===o&&(t.mapping=s),t}function i(t){const n=t.target;n.removeEventListener("dispose",i);const r=e.get(n);void 0!==r&&(e.delete(n),r.dispose())}return{get:function(r){if(r&&r.isTexture){const s=r.mapping;if(s===a||s===o){if(e.has(r)){return n(e.get(r).texture,r.mapping)}{const s=r.image;if(s&&s.height>0){const a=t.getRenderTarget(),o=new ni(s.height/2);return o.fromEquirectangularTexture(t,r),e.set(r,o),t.setRenderTarget(a),r.addEventListener("dispose",i),n(o.texture,r.mapping)}return null}}}return r},dispose:function(){e=new WeakMap}}}function xi(t){const e={};function n(n){if(void 0!==e[n])return e[n];let i;switch(n){case"WEBGL_depth_texture":i=t.getExtension("WEBGL_depth_texture")||t.getExtension("MOZ_WEBGL_depth_texture")||t.getExtension("WEBKIT_WEBGL_depth_texture");break;case"EXT_texture_filter_anisotropic":i=t.getExtension("EXT_texture_filter_anisotropic")||t.getExtension("MOZ_EXT_texture_filter_anisotropic")||t.getExtension("WEBKIT_EXT_texture_filter_anisotropic");break;case"WEBGL_compressed_texture_s3tc":i=t.getExtension("WEBGL_compressed_texture_s3tc")||t.getExtension("MOZ_WEBGL_compressed_texture_s3tc")||t.getExtension("WEBKIT_WEBGL_compressed_texture_s3tc");break;case"WEBGL_compressed_texture_pvrtc":i=t.getExtension("WEBGL_compressed_texture_pvrtc")||t.getExtension("WEBKIT_WEBGL_compressed_texture_pvrtc");break;default:i=t.getExtension(n)}return e[n]=i,i}return{has:function(t){return null!==n(t)},init:function(t){t.isWebGL2?n("EXT_color_buffer_float"):(n("WEBGL_depth_texture"),n("OES_texture_float"),n("OES_texture_half_float"),n("OES_texture_half_float_linear"),n("OES_standard_derivatives"),n("OES_element_index_uint"),n("OES_vertex_array_object"),n("ANGLE_instanced_arrays")),n("OES_texture_float_linear"),n("EXT_color_buffer_half_float")},get:function(t){const e=n(t);return null===e&&console.warn("THREE.WebGLRenderer: "+t+" extension not supported."),e}}}function _i(t,e,n,i){const r={},s=new WeakMap;function a(t){const o=t.target;null!==o.index&&e.remove(o.index);for(const t in o.attributes)e.remove(o.attributes[t]);o.removeEventListener("dispose",a),delete r[o.id];const l=s.get(o);l&&(e.remove(l),s.delete(o)),i.releaseStatesOfGeometry(o),!0===o.isInstancedBufferGeometry&&delete o._maxInstanceCount,n.memory.geometries--}function o(t){const n=[],i=t.index,r=t.attributes.position;let a=0;if(null!==i){const t=i.array;a=i.version;for(let e=0,i=t.length;e<i;e+=3){const i=t[e+0],r=t[e+1],s=t[e+2];n.push(i,r,r,s,s,i)}}else{const t=r.array;a=r.version;for(let e=0,i=t.length/3-1;e<i;e+=3){const t=e+0,i=e+1,r=e+2;n.push(t,i,i,r,r,t)}}const o=new(gn(n)>65535?dn:hn)(n,1);o.version=a;const l=s.get(t);l&&e.remove(l),s.set(t,o)}return{get:function(t,e){return!0===r[e.id]||(e.addEventListener("dispose",a),r[e.id]=!0,n.memory.geometries++),e},update:function(t){const n=t.attributes;for(const t in n)e.update(n[t],34962);const i=t.morphAttributes;for(const t in i){const n=i[t];for(let t=0,i=n.length;t<i;t++)e.update(n[t],34962)}},getWireframeAttribute:function(t){const e=s.get(t);if(e){const n=t.index;null!==n&&e.version<n.version&&o(t)}else o(t);return s.get(t)}}}function wi(t,e,n,i){const r=i.isWebGL2;let s,a,o;this.setMode=function(t){s=t},this.setIndex=function(t){a=t.type,o=t.bytesPerElement},this.render=function(e,i){t.drawElements(s,i,a,e*o),n.update(i,s,1)},this.renderInstances=function(i,l,c){if(0===c)return;let h,u;if(r)h=t,u="drawElementsInstanced";else if(h=e.get("ANGLE_instanced_arrays"),u="drawElementsInstancedANGLE",null===h)return void console.error("THREE.WebGLIndexedBufferRenderer: using THREE.InstancedBufferGeometry but hardware does not support extension ANGLE_instanced_arrays.");h[u](s,l,a,i*o,c),n.update(l,s,c)}}function bi(t){const e={frame:0,calls:0,triangles:0,points:0,lines:0};return{memory:{geometries:0,textures:0},render:e,programs:null,autoReset:!0,reset:function(){e.frame++,e.calls=0,e.triangles=0,e.points=0,e.lines=0},update:function(t,n,i){switch(e.calls++,n){case 4:e.triangles+=i*(t/3);break;case 1:e.lines+=i*(t/2);break;case 3:e.lines+=i*(t-1);break;case 2:e.lines+=i*t;break;case 0:e.points+=i*t;break;default:console.error("THREE.WebGLInfo: Unknown draw mode:",n)}}}}function Mi(t,e){return t[0]-e[0]}function Si(t,e){return Math.abs(e[1])-Math.abs(t[1])}function Ti(t){const e={},n=new Float32Array(8),i=[];for(let t=0;t<8;t++)i[t]=[t,0];return{update:function(r,s,a,o){const l=r.morphTargetInfluences,c=void 0===l?0:l.length;let h=e[s.id];if(void 0===h){h=[];for(let t=0;t<c;t++)h[t]=[t,0];e[s.id]=h}for(let t=0;t<c;t++){const e=h[t];e[0]=t,e[1]=l[t]}h.sort(Si);for(let t=0;t<8;t++)t<c&&h[t][1]?(i[t][0]=h[t][0],i[t][1]=h[t][1]):(i[t][0]=Number.MAX_SAFE_INTEGER,i[t][1]=0);i.sort(Mi);const u=a.morphTargets&&s.morphAttributes.position,d=a.morphNormals&&s.morphAttributes.normal;let p=0;for(let t=0;t<8;t++){const e=i[t],r=e[0],a=e[1];r!==Number.MAX_SAFE_INTEGER&&a?(u&&s.getAttribute("morphTarget"+t)!==u[r]&&s.setAttribute("morphTarget"+t,u[r]),d&&s.getAttribute("morphNormal"+t)!==d[r]&&s.setAttribute("morphNormal"+t,d[r]),n[t]=a,p+=a):(u&&!0===s.hasAttribute("morphTarget"+t)&&s.deleteAttribute("morphTarget"+t),d&&!0===s.hasAttribute("morphNormal"+t)&&s.deleteAttribute("morphNormal"+t),n[t]=0)}const m=s.morphTargetsRelative?1:1-p;o.getUniforms().setValue(t,"morphTargetBaseInfluence",m),o.getUniforms().setValue(t,"morphTargetInfluences",n)}}}function Ei(t,e,n,i){let r=new WeakMap;function s(t){const e=t.target;e.removeEventListener("dispose",s),n.remove(e.instanceMatrix),null!==e.instanceColor&&n.remove(e.instanceColor)}return{update:function(t){const a=i.render.frame,o=t.geometry,l=e.get(t,o);return r.get(l)!==a&&(e.update(l),r.set(l,a)),t.isInstancedMesh&&(!1===t.hasEventListener("dispose",s)&&t.addEventListener("dispose",s),n.update(t.instanceMatrix,34962),null!==t.instanceColor&&n.update(t.instanceColor,34962)),l},dispose:function(){r=new WeakMap}}}di.physical={uniforms:Yn([di.standard.uniforms,{clearcoat:{value:0},clearcoatMap:{value:null},clearcoatRoughness:{value:0},clearcoatRoughnessMap:{value:null},clearcoatNormalScale:{value:new vt(1,1)},clearcoatNormalMap:{value:null},sheen:{value:new tn(0)},transmission:{value:0},transmissionMap:{value:null}}]),vertexShader:hi.meshphysical_vert,fragmentShader:hi.meshphysical_frag};class Ai extends bt{constructor(t=null,e=1,n=1,i=1){super(null),this.image={data:t,width:e,height:n,depth:i},this.magFilter=p,this.minFilter=p,this.wrapR=u,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}Ai.prototype.isDataTexture2DArray=!0;class Li extends bt{constructor(t=null,e=1,n=1,i=1){super(null),this.image={data:t,width:e,height:n,depth:i},this.magFilter=p,this.minFilter=p,this.wrapR=u,this.generateMipmaps=!1,this.flipY=!1,this.unpackAlignment=1,this.needsUpdate=!0}}Li.prototype.isDataTexture3D=!0;const Ri=new bt,Ci=new Ai,Pi=new Li,Di=new ei,Ii=[],Ni=[],Bi=new Float32Array(16),zi=new Float32Array(9),Fi=new Float32Array(4);function Oi(t,e,n){const i=t[0];if(i<=0||i>0)return t;const r=e*n;let s=Ii[r];if(void 0===s&&(s=new Float32Array(r),Ii[r]=s),0!==e){i.toArray(s,0);for(let i=1,r=0;i!==e;++i)r+=n,t[i].toArray(s,r)}return s}function Hi(t,e){if(t.length!==e.length)return!1;for(let n=0,i=t.length;n<i;n++)if(t[n]!==e[n])return!1;return!0}function Gi(t,e){for(let n=0,i=e.length;n<i;n++)t[n]=e[n]}function Ui(t,e){let n=Ni[e];void 0===n&&(n=new Int32Array(e),Ni[e]=n);for(let i=0;i!==e;++i)n[i]=t.allocateTextureUnit();return n}function ki(t,e){const n=this.cache;n[0]!==e&&(t.uniform1f(this.addr,e),n[0]=e)}function Vi(t,e){const n=this.cache;if(void 0!==e.x)n[0]===e.x&&n[1]===e.y||(t.uniform2f(this.addr,e.x,e.y),n[0]=e.x,n[1]=e.y);else{if(Hi(n,e))return;t.uniform2fv(this.addr,e),Gi(n,e)}}function Wi(t,e){const n=this.cache;if(void 0!==e.x)n[0]===e.x&&n[1]===e.y&&n[2]===e.z||(t.uniform3f(this.addr,e.x,e.y,e.z),n[0]=e.x,n[1]=e.y,n[2]=e.z);else if(void 0!==e.r)n[0]===e.r&&n[1]===e.g&&n[2]===e.b||(t.uniform3f(this.addr,e.r,e.g,e.b),n[0]=e.r,n[1]=e.g,n[2]=e.b);else{if(Hi(n,e))return;t.uniform3fv(this.addr,e),Gi(n,e)}}function ji(t,e){const n=this.cache;if(void 0!==e.x)n[0]===e.x&&n[1]===e.y&&n[2]===e.z&&n[3]===e.w||(t.uniform4f(this.addr,e.x,e.y,e.z,e.w),n[0]=e.x,n[1]=e.y,n[2]=e.z,n[3]=e.w);else{if(Hi(n,e))return;t.uniform4fv(this.addr,e),Gi(n,e)}}function qi(t,e){const n=this.cache,i=e.elements;if(void 0===i){if(Hi(n,e))return;t.uniformMatrix2fv(this.addr,!1,e),Gi(n,e)}else{if(Hi(n,i))return;Fi.set(i),t.uniformMatrix2fv(this.addr,!1,Fi),Gi(n,i)}}function Xi(t,e){const n=this.cache,i=e.elements;if(void 0===i){if(Hi(n,e))return;t.uniformMatrix3fv(this.addr,!1,e),Gi(n,e)}else{if(Hi(n,i))return;zi.set(i),t.uniformMatrix3fv(this.addr,!1,zi),Gi(n,i)}}function Yi(t,e){const n=this.cache,i=e.elements;if(void 0===i){if(Hi(n,e))return;t.uniformMatrix4fv(this.addr,!1,e),Gi(n,e)}else{if(Hi(n,i))return;Bi.set(i),t.uniformMatrix4fv(this.addr,!1,Bi),Gi(n,i)}}function Zi(t,e){const n=this.cache;n[0]!==e&&(t.uniform1i(this.addr,e),n[0]=e)}function Ji(t,e){const n=this.cache;Hi(n,e)||(t.uniform2iv(this.addr,e),Gi(n,e))}function Qi(t,e){const n=this.cache;Hi(n,e)||(t.uniform3iv(this.addr,e),Gi(n,e))}function Ki(t,e){const n=this.cache;Hi(n,e)||(t.uniform4iv(this.addr,e),Gi(n,e))}function $i(t,e){const n=this.cache;n[0]!==e&&(t.uniform1ui(this.addr,e),n[0]=e)}function tr(t,e){const n=this.cache;Hi(n,e)||(t.uniform2uiv(this.addr,e),Gi(n,e))}function er(t,e){const n=this.cache;Hi(n,e)||(t.uniform3uiv(this.addr,e),Gi(n,e))}function nr(t,e){const n=this.cache;Hi(n,e)||(t.uniform4uiv(this.addr,e),Gi(n,e))}function ir(t,e,n){const i=this.cache,r=n.allocateTextureUnit();i[0]!==r&&(t.uniform1i(this.addr,r),i[0]=r),n.safeSetTexture2D(e||Ri,r)}function rr(t,e,n){const i=this.cache,r=n.allocateTextureUnit();i[0]!==r&&(t.uniform1i(this.addr,r),i[0]=r),n.setTexture3D(e||Pi,r)}function sr(t,e,n){const i=this.cache,r=n.allocateTextureUnit();i[0]!==r&&(t.uniform1i(this.addr,r),i[0]=r),n.safeSetTextureCube(e||Di,r)}function ar(t,e,n){const i=this.cache,r=n.allocateTextureUnit();i[0]!==r&&(t.uniform1i(this.addr,r),i[0]=r),n.setTexture2DArray(e||Ci,r)}function or(t,e){t.uniform1fv(this.addr,e)}function lr(t,e){const n=Oi(e,this.size,2);t.uniform2fv(this.addr,n)}function cr(t,e){const n=Oi(e,this.size,3);t.uniform3fv(this.addr,n)}function hr(t,e){const n=Oi(e,this.size,4);t.uniform4fv(this.addr,n)}function ur(t,e){const n=Oi(e,this.size,4);t.uniformMatrix2fv(this.addr,!1,n)}function dr(t,e){const n=Oi(e,this.size,9);t.uniformMatrix3fv(this.addr,!1,n)}function pr(t,e){const n=Oi(e,this.size,16);t.uniformMatrix4fv(this.addr,!1,n)}function mr(t,e){t.uniform1iv(this.addr,e)}function fr(t,e){t.uniform2iv(this.addr,e)}function gr(t,e){t.uniform3iv(this.addr,e)}function vr(t,e){t.uniform4iv(this.addr,e)}function yr(t,e){t.uniform1uiv(this.addr,e)}function xr(t,e){t.uniform2uiv(this.addr,e)}function _r(t,e){t.uniform3uiv(this.addr,e)}function wr(t,e){t.uniform4uiv(this.addr,e)}function br(t,e,n){const i=e.length,r=Ui(n,i);t.uniform1iv(this.addr,r);for(let t=0;t!==i;++t)n.safeSetTexture2D(e[t]||Ri,r[t])}function Mr(t,e,n){const i=e.length,r=Ui(n,i);t.uniform1iv(this.addr,r);for(let t=0;t!==i;++t)n.safeSetTextureCube(e[t]||Di,r[t])}function Sr(t,e,n){this.id=t,this.addr=n,this.cache=[],this.setValue=function(t){switch(t){case 5126:return ki;case 35664:return Vi;case 35665:return Wi;case 35666:return ji;case 35674:return qi;case 35675:return Xi;case 35676:return Yi;case 5124:case 35670:return Zi;case 35667:case 35671:return Ji;case 35668:case 35672:return Qi;case 35669:case 35673:return Ki;case 5125:return $i;case 36294:return tr;case 36295:return er;case 36296:return nr;case 35678:case 36198:case 36298:case 36306:case 35682:return ir;case 35679:case 36299:case 36307:return rr;case 35680:case 36300:case 36308:case 36293:return sr;case 36289:case 36303:case 36311:case 36292:return ar}}(e.type)}function Tr(t,e,n){this.id=t,this.addr=n,this.cache=[],this.size=e.size,this.setValue=function(t){switch(t){case 5126:return or;case 35664:return lr;case 35665:return cr;case 35666:return hr;case 35674:return ur;case 35675:return dr;case 35676:return pr;case 5124:case 35670:return mr;case 35667:case 35671:return fr;case 35668:case 35672:return gr;case 35669:case 35673:return vr;case 5125:return yr;case 36294:return xr;case 36295:return _r;case 36296:return wr;case 35678:case 36198:case 36298:case 36306:case 35682:return br;case 35680:case 36300:case 36308:case 36293:return Mr}}(e.type)}function Er(t){this.id=t,this.seq=[],this.map={}}Tr.prototype.updateCache=function(t){const e=this.cache;t instanceof Float32Array&&e.length!==t.length&&(this.cache=new Float32Array(t.length)),Gi(e,t)},Er.prototype.setValue=function(t,e,n){const i=this.seq;for(let r=0,s=i.length;r!==s;++r){const s=i[r];s.setValue(t,e[s.id],n)}};const Ar=/(\w+)(\])?(\[|\.)?/g;function Lr(t,e){t.seq.push(e),t.map[e.id]=e}function Rr(t,e,n){const i=t.name,r=i.length;for(Ar.lastIndex=0;;){const s=Ar.exec(i),a=Ar.lastIndex;let o=s[1];const l="]"===s[2],c=s[3];if(l&&(o|=0),void 0===c||"["===c&&a+2===r){Lr(n,void 0===c?new Sr(o,t,e):new Tr(o,t,e));break}{let t=n.map[o];void 0===t&&(t=new Er(o),Lr(n,t)),n=t}}}function Cr(t,e){this.seq=[],this.map={};const n=t.getProgramParameter(e,35718);for(let i=0;i<n;++i){const n=t.getActiveUniform(e,i);Rr(n,t.getUniformLocation(e,n.name),this)}}function Pr(t,e,n){const i=t.createShader(e);return t.shaderSource(i,n),t.compileShader(i),i}Cr.prototype.setValue=function(t,e,n,i){const r=this.map[e];void 0!==r&&r.setValue(t,n,i)},Cr.prototype.setOptional=function(t,e,n){const i=e[n];void 0!==i&&this.setValue(t,n,i)},Cr.upload=function(t,e,n,i){for(let r=0,s=e.length;r!==s;++r){const s=e[r],a=n[s.id];!1!==a.needsUpdate&&s.setValue(t,a.value,i)}},Cr.seqWithValue=function(t,e){const n=[];for(let i=0,r=t.length;i!==r;++i){const r=t[i];r.id in e&&n.push(r)}return n};let Dr=0;function Ir(t){switch(t){case X:return["Linear","( value )"];case Y:return["sRGB","( value )"];case J:return["RGBE","( value )"];case Q:return["RGBM","( value, 7.0 )"];case K:return["RGBM","( value, 16.0 )"];case $:return["RGBD","( value, 256.0 )"];case Z:return["Gamma","( value, float( GAMMA_FACTOR ) )"];case 3003:return["LogLuv","( value )"];default:return console.warn("THREE.WebGLProgram: Unsupported encoding:",t),["Linear","( value )"]}}function Nr(t,e,n){const i=t.getShaderParameter(e,35713),r=t.getShaderInfoLog(e).trim();if(i&&""===r)return"";return"THREE.WebGLShader: gl.getShaderInfoLog() "+n+"\n"+r+function(t){const e=t.split("\n");for(let t=0;t<e.length;t++)e[t]=t+1+": "+e[t];return e.join("\n")}(t.getShaderSource(e))}function Br(t,e){const n=Ir(e);return"vec4 "+t+"( vec4 value ) { return "+n[0]+"ToLinear"+n[1]+"; }"}function zr(t,e){const n=Ir(e);return"vec4 "+t+"( vec4 value ) { return LinearTo"+n[0]+n[1]+"; }"}function Fr(t,e){let n;switch(e){case 1:n="Linear";break;case 2:n="Reinhard";break;case 3:n="OptimizedCineon";break;case 4:n="ACESFilmic";break;case 5:n="Custom";break;default:console.warn("THREE.WebGLProgram: Unsupported toneMapping:",e),n="Linear"}return"vec3 "+t+"( vec3 color ) { return "+n+"ToneMapping( color ); }"}function Or(t){return""!==t}function Hr(t,e){return t.replace(/NUM_DIR_LIGHTS/g,e.numDirLights).replace(/NUM_SPOT_LIGHTS/g,e.numSpotLights).replace(/NUM_RECT_AREA_LIGHTS/g,e.numRectAreaLights).replace(/NUM_POINT_LIGHTS/g,e.numPointLights).replace(/NUM_HEMI_LIGHTS/g,e.numHemiLights).replace(/NUM_DIR_LIGHT_SHADOWS/g,e.numDirLightShadows).replace(/NUM_SPOT_LIGHT_SHADOWS/g,e.numSpotLightShadows).replace(/NUM_POINT_LIGHT_SHADOWS/g,e.numPointLightShadows)}function Gr(t,e){return t.replace(/NUM_CLIPPING_PLANES/g,e.numClippingPlanes).replace(/UNION_CLIPPING_PLANES/g,e.numClippingPlanes-e.numClipIntersection)}const Ur=/^[ \t]*#include +<([\w\d./]+)>/gm;function kr(t){return t.replace(Ur,Vr)}function Vr(t,e){const n=hi[e];if(void 0===n)throw new Error("Can not resolve #include <"+e+">");return kr(n)}const Wr=/#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g,jr=/#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;function qr(t){return t.replace(jr,Yr).replace(Wr,Xr)}function Xr(t,e,n,i){return console.warn("WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead."),Yr(t,e,n,i)}function Yr(t,e,n,i){let r="";for(let t=parseInt(e);t<parseInt(n);t++)r+=i.replace(/\[\s*i\s*\]/g,"[ "+t+" ]").replace(/UNROLLED_LOOP_INDEX/g,t);return r}function Zr(t){let e="precision "+t.precision+" float;\nprecision "+t.precision+" int;";return"highp"===t.precision?e+="\n#define HIGH_PRECISION":"mediump"===t.precision?e+="\n#define MEDIUM_PRECISION":"lowp"===t.precision&&(e+="\n#define LOW_PRECISION"),e}function Jr(t,e,n,i){const a=t.getContext(),o=n.defines;let h=n.vertexShader,u=n.fragmentShader;const d=function(t){let e="SHADOWMAP_TYPE_BASIC";return 1===t.shadowMapType?e="SHADOWMAP_TYPE_PCF":2===t.shadowMapType?e="SHADOWMAP_TYPE_PCF_SOFT":3===t.shadowMapType&&(e="SHADOWMAP_TYPE_VSM"),e}(n),p=function(t){let e="ENVMAP_TYPE_CUBE";if(t.envMap)switch(t.envMapMode){case r:case s:e="ENVMAP_TYPE_CUBE";break;case l:case c:e="ENVMAP_TYPE_CUBE_UV"}return e}(n),m=function(t){let e="ENVMAP_MODE_REFLECTION";if(t.envMap)switch(t.envMapMode){case s:case c:e="ENVMAP_MODE_REFRACTION"}return e}(n),f=function(t){let e="ENVMAP_BLENDING_NONE";if(t.envMap)switch(t.combine){case 0:e="ENVMAP_BLENDING_MULTIPLY";break;case 1:e="ENVMAP_BLENDING_MIX";break;case 2:e="ENVMAP_BLENDING_ADD"}return e}(n),g=t.gammaFactor>0?t.gammaFactor:1,v=n.isWebGL2?"":function(t){return[t.extensionDerivatives||t.envMapCubeUV||t.bumpMap||t.tangentSpaceNormalMap||t.clearcoatNormalMap||t.flatShading||"physical"===t.shaderID?"#extension GL_OES_standard_derivatives : enable":"",(t.extensionFragDepth||t.logarithmicDepthBuffer)&&t.rendererExtensionFragDepth?"#extension GL_EXT_frag_depth : enable":"",t.extensionDrawBuffers&&t.rendererExtensionDrawBuffers?"#extension GL_EXT_draw_buffers : require":"",(t.extensionShaderTextureLOD||t.envMap)&&t.rendererExtensionShaderTextureLod?"#extension GL_EXT_shader_texture_lod : enable":""].filter(Or).join("\n")}(n),y=function(t){const e=[];for(const n in t){const i=t[n];!1!==i&&e.push("#define "+n+" "+i)}return e.join("\n")}(o),x=a.createProgram();let _,w,b=n.glslVersion?"#version "+n.glslVersion+"\n":"";n.isRawShaderMaterial?(_=[y].filter(Or).join("\n"),_.length>0&&(_+="\n"),w=[v,y].filter(Or).join("\n"),w.length>0&&(w+="\n")):(_=[Zr(n),"#define SHADER_NAME "+n.shaderName,y,n.instancing?"#define USE_INSTANCING":"",n.instancingColor?"#define USE_INSTANCING_COLOR":"",n.supportsVertexTextures?"#define VERTEX_TEXTURES":"","#define GAMMA_FACTOR "+g,"#define MAX_BONES "+n.maxBones,n.useFog&&n.fog?"#define USE_FOG":"",n.useFog&&n.fogExp2?"#define FOG_EXP2":"",n.map?"#define USE_MAP":"",n.envMap?"#define USE_ENVMAP":"",n.envMap?"#define "+m:"",n.lightMap?"#define USE_LIGHTMAP":"",n.aoMap?"#define USE_AOMAP":"",n.emissiveMap?"#define USE_EMISSIVEMAP":"",n.bumpMap?"#define USE_BUMPMAP":"",n.normalMap?"#define USE_NORMALMAP":"",n.normalMap&&n.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",n.normalMap&&n.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",n.clearcoatMap?"#define USE_CLEARCOATMAP":"",n.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",n.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",n.displacementMap&&n.supportsVertexTextures?"#define USE_DISPLACEMENTMAP":"",n.specularMap?"#define USE_SPECULARMAP":"",n.roughnessMap?"#define USE_ROUGHNESSMAP":"",n.metalnessMap?"#define USE_METALNESSMAP":"",n.alphaMap?"#define USE_ALPHAMAP":"",n.transmissionMap?"#define USE_TRANSMISSIONMAP":"",n.vertexTangents?"#define USE_TANGENT":"",n.vertexColors?"#define USE_COLOR":"",n.vertexAlphas?"#define USE_COLOR_ALPHA":"",n.vertexUvs?"#define USE_UV":"",n.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",n.flatShading?"#define FLAT_SHADED":"",n.skinning?"#define USE_SKINNING":"",n.useVertexTexture?"#define BONE_TEXTURE":"",n.morphTargets?"#define USE_MORPHTARGETS":"",n.morphNormals&&!1===n.flatShading?"#define USE_MORPHNORMALS":"",n.doubleSided?"#define DOUBLE_SIDED":"",n.flipSided?"#define FLIP_SIDED":"",n.shadowMapEnabled?"#define USE_SHADOWMAP":"",n.shadowMapEnabled?"#define "+d:"",n.sizeAttenuation?"#define USE_SIZEATTENUATION":"",n.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",n.logarithmicDepthBuffer&&n.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","#ifdef USE_MORPHTARGETS","\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(Or).join("\n"),w=[v,Zr(n),"#define SHADER_NAME "+n.shaderName,y,n.alphaTest?"#define ALPHATEST "+n.alphaTest+(n.alphaTest%1?"":".0"):"","#define GAMMA_FACTOR "+g,n.useFog&&n.fog?"#define USE_FOG":"",n.useFog&&n.fogExp2?"#define FOG_EXP2":"",n.map?"#define USE_MAP":"",n.matcap?"#define USE_MATCAP":"",n.envMap?"#define USE_ENVMAP":"",n.envMap?"#define "+p:"",n.envMap?"#define "+m:"",n.envMap?"#define "+f:"",n.lightMap?"#define USE_LIGHTMAP":"",n.aoMap?"#define USE_AOMAP":"",n.emissiveMap?"#define USE_EMISSIVEMAP":"",n.bumpMap?"#define USE_BUMPMAP":"",n.normalMap?"#define USE_NORMALMAP":"",n.normalMap&&n.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",n.normalMap&&n.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",n.clearcoatMap?"#define USE_CLEARCOATMAP":"",n.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",n.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",n.specularMap?"#define USE_SPECULARMAP":"",n.roughnessMap?"#define USE_ROUGHNESSMAP":"",n.metalnessMap?"#define USE_METALNESSMAP":"",n.alphaMap?"#define USE_ALPHAMAP":"",n.sheen?"#define USE_SHEEN":"",n.transmissionMap?"#define USE_TRANSMISSIONMAP":"",n.vertexTangents?"#define USE_TANGENT":"",n.vertexColors||n.instancingColor?"#define USE_COLOR":"",n.vertexAlphas?"#define USE_COLOR_ALPHA":"",n.vertexUvs?"#define USE_UV":"",n.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",n.gradientMap?"#define USE_GRADIENTMAP":"",n.flatShading?"#define FLAT_SHADED":"",n.doubleSided?"#define DOUBLE_SIDED":"",n.flipSided?"#define FLIP_SIDED":"",n.shadowMapEnabled?"#define USE_SHADOWMAP":"",n.shadowMapEnabled?"#define "+d:"",n.premultipliedAlpha?"#define PREMULTIPLIED_ALPHA":"",n.physicallyCorrectLights?"#define PHYSICALLY_CORRECT_LIGHTS":"",n.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",n.logarithmicDepthBuffer&&n.rendererExtensionFragDepth?"#define USE_LOGDEPTHBUF_EXT":"",(n.extensionShaderTextureLOD||n.envMap)&&n.rendererExtensionShaderTextureLod?"#define TEXTURE_LOD_EXT":"","uniform mat4 viewMatrix;","uniform vec3 cameraPosition;","uniform bool isOrthographic;",0!==n.toneMapping?"#define TONE_MAPPING":"",0!==n.toneMapping?hi.tonemapping_pars_fragment:"",0!==n.toneMapping?Fr("toneMapping",n.toneMapping):"",n.dithering?"#define DITHERING":"",hi.encodings_pars_fragment,n.map?Br("mapTexelToLinear",n.mapEncoding):"",n.matcap?Br("matcapTexelToLinear",n.matcapEncoding):"",n.envMap?Br("envMapTexelToLinear",n.envMapEncoding):"",n.emissiveMap?Br("emissiveMapTexelToLinear",n.emissiveMapEncoding):"",n.lightMap?Br("lightMapTexelToLinear",n.lightMapEncoding):"",zr("linearToOutputTexel",n.outputEncoding),n.depthPacking?"#define DEPTH_PACKING "+n.depthPacking:"","\n"].filter(Or).join("\n")),h=kr(h),h=Hr(h,n),h=Gr(h,n),u=kr(u),u=Hr(u,n),u=Gr(u,n),h=qr(h),u=qr(u),n.isWebGL2&&!0!==n.isRawShaderMaterial&&(b="#version 300 es\n",_=["#define attribute in","#define varying out","#define texture2D texture"].join("\n")+"\n"+_,w=["#define varying in",n.glslVersion===it?"":"out highp vec4 pc_fragColor;",n.glslVersion===it?"":"#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"+w);const M=b+w+u,S=Pr(a,35633,b+_+h),T=Pr(a,35632,M);if(a.attachShader(x,S),a.attachShader(x,T),void 0!==n.index0AttributeName?a.bindAttribLocation(x,0,n.index0AttributeName):!0===n.morphTargets&&a.bindAttribLocation(x,0,"position"),a.linkProgram(x),t.debug.checkShaderErrors){const t=a.getProgramInfoLog(x).trim(),e=a.getShaderInfoLog(S).trim(),n=a.getShaderInfoLog(T).trim();let i=!0,r=!0;if(!1===a.getProgramParameter(x,35714)){i=!1;const e=Nr(a,S,"vertex"),n=Nr(a,T,"fragment");console.error("THREE.WebGLProgram: shader error: ",a.getError(),"35715",a.getProgramParameter(x,35715),"gl.getProgramInfoLog",t,e,n)}else""!==t?console.warn("THREE.WebGLProgram: gl.getProgramInfoLog()",t):""!==e&&""!==n||(r=!1);r&&(this.diagnostics={runnable:i,programLog:t,vertexShader:{log:e,prefix:_},fragmentShader:{log:n,prefix:w}})}let E,A;return a.deleteShader(S),a.deleteShader(T),this.getUniforms=function(){return void 0===E&&(E=new Cr(a,x)),E},this.getAttributes=function(){return void 0===A&&(A=function(t,e){const n={},i=t.getProgramParameter(e,35721);for(let r=0;r<i;r++){const i=t.getActiveAttrib(e,r).name;n[i]=t.getAttribLocation(e,i)}return n}(a,x)),A},this.destroy=function(){i.releaseStatesOfProgram(this),a.deleteProgram(x),this.program=void 0},this.name=n.shaderName,this.id=Dr++,this.cacheKey=e,this.usedTimes=1,this.program=x,this.vertexShader=S,this.fragmentShader=T,this}function Qr(t,e,n,i,r,s){const a=[],o=i.isWebGL2,h=i.logarithmicDepthBuffer,u=i.floatVertexTextures,d=i.maxVertexUniforms,p=i.vertexTextures;let m=i.precision;const f={MeshDepthMaterial:"depth",MeshDistanceMaterial:"distanceRGBA",MeshNormalMaterial:"normal",MeshBasicMaterial:"basic",MeshLambertMaterial:"lambert",MeshPhongMaterial:"phong",MeshToonMaterial:"toon",MeshStandardMaterial:"physical",MeshPhysicalMaterial:"physical",MeshMatcapMaterial:"matcap",LineBasicMaterial:"basic",LineDashedMaterial:"dashed",PointsMaterial:"points",ShadowMaterial:"shadow",SpriteMaterial:"sprite"},g=["precision","isWebGL2","supportsVertexTextures","outputEncoding","instancing","instancingColor","map","mapEncoding","matcap","matcapEncoding","envMap","envMapMode","envMapEncoding","envMapCubeUV","lightMap","lightMapEncoding","aoMap","emissiveMap","emissiveMapEncoding","bumpMap","normalMap","objectSpaceNormalMap","tangentSpaceNormalMap","clearcoatMap","clearcoatRoughnessMap","clearcoatNormalMap","displacementMap","specularMap","roughnessMap","metalnessMap","gradientMap","alphaMap","combine","vertexColors","vertexAlphas","vertexTangents","vertexUvs","uvsVertexOnly","fog","useFog","fogExp2","flatShading","sizeAttenuation","logarithmicDepthBuffer","skinning","maxBones","useVertexTexture","morphTargets","morphNormals","premultipliedAlpha","numDirLights","numPointLights","numSpotLights","numHemiLights","numRectAreaLights","numDirLightShadows","numPointLightShadows","numSpotLightShadows","shadowMapEnabled","shadowMapType","toneMapping","physicallyCorrectLights","alphaTest","doubleSided","flipSided","numClippingPlanes","numClipIntersection","depthPacking","dithering","sheen","transmissionMap"];function v(t){let e;return t&&t.isTexture?e=t.encoding:t&&t.isWebGLRenderTarget?(console.warn("THREE.WebGLPrograms.getTextureEncodingFromMap: don't use render targets as textures. Use their .texture property instead."),e=t.texture.encoding):e=X,e}return{getParameters:function(r,a,g,y,x){const _=y.fog,w=r.isMeshStandardMaterial?y.environment:null,b=e.get(r.envMap||w),M=f[r.type],S=x.isSkinnedMesh?function(t){const e=t.skeleton.bones;if(u)return 1024;{const t=d,n=Math.floor((t-20)/4),i=Math.min(n,e.length);return i<e.length?(console.warn("THREE.WebGLRenderer: Skeleton has "+e.length+" bones. This GPU supports "+i+"."),0):i}}(x):0;let T,E;if(null!==r.precision&&(m=i.getMaxPrecision(r.precision),m!==r.precision&&console.warn("THREE.WebGLProgram.getParameters:",r.precision,"not supported, using",m,"instead.")),M){const t=di[M];T=t.vertexShader,E=t.fragmentShader}else T=r.vertexShader,E=r.fragmentShader;const A=t.getRenderTarget();return{isWebGL2:o,shaderID:M,shaderName:r.type,vertexShader:T,fragmentShader:E,defines:r.defines,isRawShaderMaterial:!0===r.isRawShaderMaterial,glslVersion:r.glslVersion,precision:m,instancing:!0===x.isInstancedMesh,instancingColor:!0===x.isInstancedMesh&&null!==x.instanceColor,supportsVertexTextures:p,outputEncoding:null!==A?v(A.texture):t.outputEncoding,map:!!r.map,mapEncoding:v(r.map),matcap:!!r.matcap,matcapEncoding:v(r.matcap),envMap:!!b,envMapMode:b&&b.mapping,envMapEncoding:v(b),envMapCubeUV:!!b&&(b.mapping===l||b.mapping===c),lightMap:!!r.lightMap,lightMapEncoding:v(r.lightMap),aoMap:!!r.aoMap,emissiveMap:!!r.emissiveMap,emissiveMapEncoding:v(r.emissiveMap),bumpMap:!!r.bumpMap,normalMap:!!r.normalMap,objectSpaceNormalMap:1===r.normalMapType,tangentSpaceNormalMap:0===r.normalMapType,clearcoatMap:!!r.clearcoatMap,clearcoatRoughnessMap:!!r.clearcoatRoughnessMap,clearcoatNormalMap:!!r.clearcoatNormalMap,displacementMap:!!r.displacementMap,roughnessMap:!!r.roughnessMap,metalnessMap:!!r.metalnessMap,specularMap:!!r.specularMap,alphaMap:!!r.alphaMap,gradientMap:!!r.gradientMap,sheen:!!r.sheen,transmissionMap:!!r.transmissionMap,combine:r.combine,vertexTangents:r.normalMap&&r.vertexTangents,vertexColors:r.vertexColors,vertexAlphas:!0===r.vertexColors&&x.geometry&&x.geometry.attributes.color&&4===x.geometry.attributes.color.itemSize,vertexUvs:!!(r.map||r.bumpMap||r.normalMap||r.specularMap||r.alphaMap||r.emissiveMap||r.roughnessMap||r.metalnessMap||r.clearcoatMap||r.clearcoatRoughnessMap||r.clearcoatNormalMap||r.displacementMap||r.transmissionMap),uvsVertexOnly:!(r.map||r.bumpMap||r.normalMap||r.specularMap||r.alphaMap||r.emissiveMap||r.roughnessMap||r.metalnessMap||r.clearcoatNormalMap||r.transmissionMap||!r.displacementMap),fog:!!_,useFog:r.fog,fogExp2:_&&_.isFogExp2,flatShading:!!r.flatShading,sizeAttenuation:r.sizeAttenuation,logarithmicDepthBuffer:h,skinning:r.skinning&&S>0,maxBones:S,useVertexTexture:u,morphTargets:r.morphTargets,morphNormals:r.morphNormals,numDirLights:a.directional.length,numPointLights:a.point.length,numSpotLights:a.spot.length,numRectAreaLights:a.rectArea.length,numHemiLights:a.hemi.length,numDirLightShadows:a.directionalShadowMap.length,numPointLightShadows:a.pointShadowMap.length,numSpotLightShadows:a.spotShadowMap.length,numClippingPlanes:s.numPlanes,numClipIntersection:s.numIntersection,dithering:r.dithering,shadowMapEnabled:t.shadowMap.enabled&&g.length>0,shadowMapType:t.shadowMap.type,toneMapping:r.toneMapped?t.toneMapping:0,physicallyCorrectLights:t.physicallyCorrectLights,premultipliedAlpha:r.premultipliedAlpha,alphaTest:r.alphaTest,doubleSided:2===r.side,flipSided:1===r.side,depthPacking:void 0!==r.depthPacking&&r.depthPacking,index0AttributeName:r.index0AttributeName,extensionDerivatives:r.extensions&&r.extensions.derivatives,extensionFragDepth:r.extensions&&r.extensions.fragDepth,extensionDrawBuffers:r.extensions&&r.extensions.drawBuffers,extensionShaderTextureLOD:r.extensions&&r.extensions.shaderTextureLOD,rendererExtensionFragDepth:o||n.has("EXT_frag_depth"),rendererExtensionDrawBuffers:o||n.has("WEBGL_draw_buffers"),rendererExtensionShaderTextureLod:o||n.has("EXT_shader_texture_lod"),customProgramCacheKey:r.customProgramCacheKey()}},getProgramCacheKey:function(e){const n=[];if(e.shaderID?n.push(e.shaderID):(n.push(e.fragmentShader),n.push(e.vertexShader)),void 0!==e.defines)for(const t in e.defines)n.push(t),n.push(e.defines[t]);if(!1===e.isRawShaderMaterial){for(let t=0;t<g.length;t++)n.push(e[g[t]]);n.push(t.outputEncoding),n.push(t.gammaFactor)}return n.push(e.customProgramCacheKey),n.join()},getUniforms:function(t){const e=f[t.type];let n;if(e){const t=di[e];n=Zn.clone(t.uniforms)}else n=t.uniforms;return n},acquireProgram:function(e,n){let i;for(let t=0,e=a.length;t<e;t++){const e=a[t];if(e.cacheKey===n){i=e,++i.usedTimes;break}}return void 0===i&&(i=new Jr(t,n,e,r),a.push(i)),i},releaseProgram:function(t){if(0==--t.usedTimes){const e=a.indexOf(t);a[e]=a[a.length-1],a.pop(),t.destroy()}},programs:a}}function Kr(){let t=new WeakMap;return{get:function(e){let n=t.get(e);return void 0===n&&(n={},t.set(e,n)),n},remove:function(e){t.delete(e)},update:function(e,n,i){t.get(e)[n]=i},dispose:function(){t=new WeakMap}}}function $r(t,e){return t.groupOrder!==e.groupOrder?t.groupOrder-e.groupOrder:t.renderOrder!==e.renderOrder?t.renderOrder-e.renderOrder:t.program!==e.program?t.program.id-e.program.id:t.material.id!==e.material.id?t.material.id-e.material.id:t.z!==e.z?t.z-e.z:t.id-e.id}function ts(t,e){return t.groupOrder!==e.groupOrder?t.groupOrder-e.groupOrder:t.renderOrder!==e.renderOrder?t.renderOrder-e.renderOrder:t.z!==e.z?e.z-t.z:t.id-e.id}function es(t){const e=[];let n=0;const i=[],r=[],s={id:-1};function a(i,r,a,o,l,c){let h=e[n];const u=t.get(a);return void 0===h?(h={id:i.id,object:i,geometry:r,material:a,program:u.program||s,groupOrder:o,renderOrder:i.renderOrder,z:l,group:c},e[n]=h):(h.id=i.id,h.object=i,h.geometry=r,h.material=a,h.program=u.program||s,h.groupOrder=o,h.renderOrder=i.renderOrder,h.z=l,h.group=c),n++,h}return{opaque:i,transparent:r,init:function(){n=0,i.length=0,r.length=0},push:function(t,e,n,s,o,l){const c=a(t,e,n,s,o,l);(!0===n.transparent?r:i).push(c)},unshift:function(t,e,n,s,o,l){const c=a(t,e,n,s,o,l);(!0===n.transparent?r:i).unshift(c)},finish:function(){for(let t=n,i=e.length;t<i;t++){const n=e[t];if(null===n.id)break;n.id=null,n.object=null,n.geometry=null,n.material=null,n.program=null,n.group=null}},sort:function(t,e){i.length>1&&i.sort(t||$r),r.length>1&&r.sort(e||ts)}}}function ns(t){let e=new WeakMap;return{get:function(n,i){let r;return!1===e.has(n)?(r=new es(t),e.set(n,[r])):i>=e.get(n).length?(r=new es(t),e.get(n).push(r)):r=e.get(n)[i],r},dispose:function(){e=new WeakMap}}}function is(){const t={};return{get:function(e){if(void 0!==t[e.id])return t[e.id];let n;switch(e.type){case"DirectionalLight":n={direction:new Lt,color:new tn};break;case"SpotLight":n={position:new Lt,direction:new Lt,color:new tn,distance:0,coneCos:0,penumbraCos:0,decay:0};break;case"PointLight":n={position:new Lt,color:new tn,distance:0,decay:0};break;case"HemisphereLight":n={direction:new Lt,skyColor:new tn,groundColor:new tn};break;case"RectAreaLight":n={color:new tn,position:new Lt,halfWidth:new Lt,halfHeight:new Lt}}return t[e.id]=n,n}}}let rs=0;function ss(t,e){return(e.castShadow?1:0)-(t.castShadow?1:0)}function as(t,e){const n=new is,i=function(){const t={};return{get:function(e){if(void 0!==t[e.id])return t[e.id];let n;switch(e.type){case"DirectionalLight":case"SpotLight":n={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new vt};break;case"PointLight":n={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new vt,shadowCameraNear:1,shadowCameraFar:1e3}}return t[e.id]=n,n}}}(),r={version:0,hash:{directionalLength:-1,pointLength:-1,spotLength:-1,rectAreaLength:-1,hemiLength:-1,numDirectionalShadows:-1,numPointShadows:-1,numSpotShadows:-1},ambient:[0,0,0],probe:[],directional:[],directionalShadow:[],directionalShadowMap:[],directionalShadowMatrix:[],spot:[],spotShadow:[],spotShadowMap:[],spotShadowMatrix:[],rectArea:[],rectAreaLTC1:null,rectAreaLTC2:null,point:[],pointShadow:[],pointShadowMap:[],pointShadowMatrix:[],hemi:[]};for(let t=0;t<9;t++)r.probe.push(new Lt);const s=new Lt,a=new se,o=new se;return{setup:function(s){let a=0,o=0,l=0;for(let t=0;t<9;t++)r.probe[t].set(0,0,0);let c=0,h=0,u=0,d=0,p=0,m=0,f=0,g=0;s.sort(ss);for(let t=0,e=s.length;t<e;t++){const e=s[t],v=e.color,y=e.intensity,x=e.distance,_=e.shadow&&e.shadow.map?e.shadow.map.texture:null;if(e.isAmbientLight)a+=v.r*y,o+=v.g*y,l+=v.b*y;else if(e.isLightProbe)for(let t=0;t<9;t++)r.probe[t].addScaledVector(e.sh.coefficients[t],y);else if(e.isDirectionalLight){const t=n.get(e);if(t.color.copy(e.color).multiplyScalar(e.intensity),e.castShadow){const t=e.shadow,n=i.get(e);n.shadowBias=t.bias,n.shadowNormalBias=t.normalBias,n.shadowRadius=t.radius,n.shadowMapSize=t.mapSize,r.directionalShadow[c]=n,r.directionalShadowMap[c]=_,r.directionalShadowMatrix[c]=e.shadow.matrix,m++}r.directional[c]=t,c++}else if(e.isSpotLight){const t=n.get(e);if(t.position.setFromMatrixPosition(e.matrixWorld),t.color.copy(v).multiplyScalar(y),t.distance=x,t.coneCos=Math.cos(e.angle),t.penumbraCos=Math.cos(e.angle*(1-e.penumbra)),t.decay=e.decay,e.castShadow){const t=e.shadow,n=i.get(e);n.shadowBias=t.bias,n.shadowNormalBias=t.normalBias,n.shadowRadius=t.radius,n.shadowMapSize=t.mapSize,r.spotShadow[u]=n,r.spotShadowMap[u]=_,r.spotShadowMatrix[u]=e.shadow.matrix,g++}r.spot[u]=t,u++}else if(e.isRectAreaLight){const t=n.get(e);t.color.copy(v).multiplyScalar(y),t.halfWidth.set(.5*e.width,0,0),t.halfHeight.set(0,.5*e.height,0),r.rectArea[d]=t,d++}else if(e.isPointLight){const t=n.get(e);if(t.color.copy(e.color).multiplyScalar(e.intensity),t.distance=e.distance,t.decay=e.decay,e.castShadow){const t=e.shadow,n=i.get(e);n.shadowBias=t.bias,n.shadowNormalBias=t.normalBias,n.shadowRadius=t.radius,n.shadowMapSize=t.mapSize,n.shadowCameraNear=t.camera.near,n.shadowCameraFar=t.camera.far,r.pointShadow[h]=n,r.pointShadowMap[h]=_,r.pointShadowMatrix[h]=e.shadow.matrix,f++}r.point[h]=t,h++}else if(e.isHemisphereLight){const t=n.get(e);t.skyColor.copy(e.color).multiplyScalar(y),t.groundColor.copy(e.groundColor).multiplyScalar(y),r.hemi[p]=t,p++}}d>0&&(e.isWebGL2||!0===t.has("OES_texture_float_linear")?(r.rectAreaLTC1=ui.LTC_FLOAT_1,r.rectAreaLTC2=ui.LTC_FLOAT_2):!0===t.has("OES_texture_half_float_linear")?(r.rectAreaLTC1=ui.LTC_HALF_1,r.rectAreaLTC2=ui.LTC_HALF_2):console.error("THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.")),r.ambient[0]=a,r.ambient[1]=o,r.ambient[2]=l;const v=r.hash;v.directionalLength===c&&v.pointLength===h&&v.spotLength===u&&v.rectAreaLength===d&&v.hemiLength===p&&v.numDirectionalShadows===m&&v.numPointShadows===f&&v.numSpotShadows===g||(r.directional.length=c,r.spot.length=u,r.rectArea.length=d,r.point.length=h,r.hemi.length=p,r.directionalShadow.length=m,r.directionalShadowMap.length=m,r.pointShadow.length=f,r.pointShadowMap.length=f,r.spotShadow.length=g,r.spotShadowMap.length=g,r.directionalShadowMatrix.length=m,r.pointShadowMatrix.length=f,r.spotShadowMatrix.length=g,v.directionalLength=c,v.pointLength=h,v.spotLength=u,v.rectAreaLength=d,v.hemiLength=p,v.numDirectionalShadows=m,v.numPointShadows=f,v.numSpotShadows=g,r.version=rs++)},setupView:function(t,e){let n=0,i=0,l=0,c=0,h=0;const u=e.matrixWorldInverse;for(let e=0,d=t.length;e<d;e++){const d=t[e];if(d.isDirectionalLight){const t=r.directional[n];t.direction.setFromMatrixPosition(d.matrixWorld),s.setFromMatrixPosition(d.target.matrixWorld),t.direction.sub(s),t.direction.transformDirection(u),n++}else if(d.isSpotLight){const t=r.spot[l];t.position.setFromMatrixPosition(d.matrixWorld),t.position.applyMatrix4(u),t.direction.setFromMatrixPosition(d.matrixWorld),s.setFromMatrixPosition(d.target.matrixWorld),t.direction.sub(s),t.direction.transformDirection(u),l++}else if(d.isRectAreaLight){const t=r.rectArea[c];t.position.setFromMatrixPosition(d.matrixWorld),t.position.applyMatrix4(u),o.identity(),a.copy(d.matrixWorld),a.premultiply(u),o.extractRotation(a),t.halfWidth.set(.5*d.width,0,0),t.halfHeight.set(0,.5*d.height,0),t.halfWidth.applyMatrix4(o),t.halfHeight.applyMatrix4(o),c++}else if(d.isPointLight){const t=r.point[i];t.position.setFromMatrixPosition(d.matrixWorld),t.position.applyMatrix4(u),i++}else if(d.isHemisphereLight){const t=r.hemi[h];t.direction.setFromMatrixPosition(d.matrixWorld),t.direction.transformDirection(u),t.direction.normalize(),h++}}},state:r}}function os(t,e){const n=new as(t,e),i=[],r=[];return{init:function(){i.length=0,r.length=0},state:{lightsArray:i,shadowsArray:r,lights:n},setupLights:function(){n.setup(i)},setupLightsView:function(t){n.setupView(i,t)},pushLight:function(t){i.push(t)},pushShadow:function(t){r.push(t)}}}function ls(t,e){let n=new WeakMap;return{get:function(i,r=0){let s;return!1===n.has(i)?(s=new os(t,e),n.set(i,[s])):r>=n.get(i).length?(s=new os(t,e),n.get(i).push(s)):s=n.get(i)[r],s},dispose:function(){n=new WeakMap}}}class cs extends Xe{constructor(t){super(),this.type="MeshDepthMaterial",this.depthPacking=3200,this.skinning=!1,this.morphTargets=!1,this.map=null,this.alphaMap=null,this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.setValues(t)}copy(t){return super.copy(t),this.depthPacking=t.depthPacking,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.map=t.map,this.alphaMap=t.alphaMap,this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this}}cs.prototype.isMeshDepthMaterial=!0;class hs extends Xe{constructor(t){super(),this.type="MeshDistanceMaterial",this.referencePosition=new Lt,this.nearDistance=1,this.farDistance=1e3,this.skinning=!1,this.morphTargets=!1,this.map=null,this.alphaMap=null,this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.fog=!1,this.setValues(t)}copy(t){return super.copy(t),this.referencePosition.copy(t.referencePosition),this.nearDistance=t.nearDistance,this.farDistance=t.farDistance,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.map=t.map,this.alphaMap=t.alphaMap,this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this}}hs.prototype.isMeshDistanceMaterial=!0;function us(t,e,n){let i=new ai;const r=new vt,s=new vt,a=new St,o=[],l=[],c={},h=n.maxTextureSize,u={0:1,1:0,2:2},d=new Jn({defines:{SAMPLE_RATE:2/8,HALF_SAMPLE_RATE:1/8},uniforms:{shadow_pass:{value:null},resolution:{value:new vt},radius:{value:4}},vertexShader:"void main() {\n\tgl_Position = vec4( position, 1.0 );\n}",fragmentShader:"uniform sampler2D shadow_pass;\nuniform vec2 resolution;\nuniform float radius;\n#include <packing>\nvoid main() {\n\tfloat mean = 0.0;\n\tfloat squared_mean = 0.0;\n\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy ) / resolution ) );\n\tfor ( float i = -1.0; i < 1.0 ; i += SAMPLE_RATE) {\n\t\t#ifdef HORIZONTAL_PASS\n\t\t\tvec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( i, 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, i ) * radius ) / resolution ) );\n\t\t\tmean += depth;\n\t\t\tsquared_mean += depth * depth;\n\t\t#endif\n\t}\n\tmean = mean * HALF_SAMPLE_RATE;\n\tsquared_mean = squared_mean * HALF_SAMPLE_RATE;\n\tfloat std_dev = sqrt( squared_mean - mean * mean );\n\tgl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\n}"}),m=d.clone();m.defines.HORIZONTAL_PASS=1;const f=new En;f.setAttribute("position",new sn(new Float32Array([-1,-1,.5,3,-1,.5,-1,3,.5]),3));const v=new Wn(f,d),y=this;function x(n,i){const r=e.update(v);d.uniforms.shadow_pass.value=n.map.texture,d.uniforms.resolution.value=n.mapSize,d.uniforms.radius.value=n.radius,t.setRenderTarget(n.mapPass),t.clear(),t.renderBufferDirect(i,null,r,d,v,null),m.uniforms.shadow_pass.value=n.mapPass.texture,m.uniforms.resolution.value=n.mapSize,m.uniforms.radius.value=n.radius,t.setRenderTarget(n.map),t.clear(),t.renderBufferDirect(i,null,r,m,v,null)}function _(t,e,n){const i=t<<0|e<<1|n<<2;let r=o[i];return void 0===r&&(r=new cs({depthPacking:3201,morphTargets:t,skinning:e}),o[i]=r),r}function w(t,e,n){const i=t<<0|e<<1|n<<2;let r=l[i];return void 0===r&&(r=new hs({morphTargets:t,skinning:e}),l[i]=r),r}function b(e,n,i,r,s,a,o){let l=null,h=_,d=e.customDepthMaterial;if(!0===r.isPointLight&&(h=w,d=e.customDistanceMaterial),void 0===d){let t=!1;!0===i.morphTargets&&(t=n.morphAttributes&&n.morphAttributes.position&&n.morphAttributes.position.length>0);let r=!1;!0===e.isSkinnedMesh&&(!0===i.skinning?r=!0:console.warn("THREE.WebGLShadowMap: THREE.SkinnedMesh with material.skinning set to false:",e));l=h(t,r,!0===e.isInstancedMesh)}else l=d;if(t.localClippingEnabled&&!0===i.clipShadows&&0!==i.clippingPlanes.length){const t=l.uuid,e=i.uuid;let n=c[t];void 0===n&&(n={},c[t]=n);let r=n[e];void 0===r&&(r=l.clone(),n[e]=r),l=r}return l.visible=i.visible,l.wireframe=i.wireframe,l.side=3===o?null!==i.shadowSide?i.shadowSide:i.side:null!==i.shadowSide?i.shadowSide:u[i.side],l.clipShadows=i.clipShadows,l.clippingPlanes=i.clippingPlanes,l.clipIntersection=i.clipIntersection,l.wireframeLinewidth=i.wireframeLinewidth,l.linewidth=i.linewidth,!0===r.isPointLight&&!0===l.isMeshDistanceMaterial&&(l.referencePosition.setFromMatrixPosition(r.matrixWorld),l.nearDistance=s,l.farDistance=a),l}function M(n,r,s,a,o){if(!1===n.visible)return;if(n.layers.test(r.layers)&&(n.isMesh||n.isLine||n.isPoints)&&(n.castShadow||n.receiveShadow&&3===o)&&(!n.frustumCulled||i.intersectsObject(n))){n.modelViewMatrix.multiplyMatrices(s.matrixWorldInverse,n.matrixWorld);const i=e.update(n),r=n.material;if(Array.isArray(r)){const e=i.groups;for(let l=0,c=e.length;l<c;l++){const c=e[l],h=r[c.materialIndex];if(h&&h.visible){const e=b(n,i,h,a,s.near,s.far,o);t.renderBufferDirect(s,null,i,e,n,c)}}}else if(r.visible){const e=b(n,i,r,a,s.near,s.far,o);t.renderBufferDirect(s,null,i,e,n,null)}}const l=n.children;for(let t=0,e=l.length;t<e;t++)M(l[t],r,s,a,o)}this.enabled=!1,this.autoUpdate=!0,this.needsUpdate=!1,this.type=1,this.render=function(e,n,o){if(!1===y.enabled)return;if(!1===y.autoUpdate&&!1===y.needsUpdate)return;if(0===e.length)return;const l=t.getRenderTarget(),c=t.getActiveCubeFace(),u=t.getActiveMipmapLevel(),d=t.state;d.setBlending(0),d.buffers.color.setClear(1,1,1,1),d.buffers.depth.setTest(!0),d.setScissorTest(!1);for(let l=0,c=e.length;l<c;l++){const c=e[l],u=c.shadow;if(void 0===u){console.warn("THREE.WebGLShadowMap:",c,"has no shadow.");continue}if(!1===u.autoUpdate&&!1===u.needsUpdate)continue;r.copy(u.mapSize);const m=u.getFrameExtents();if(r.multiply(m),s.copy(u.mapSize),(r.x>h||r.y>h)&&(r.x>h&&(s.x=Math.floor(h/m.x),r.x=s.x*m.x,u.mapSize.x=s.x),r.y>h&&(s.y=Math.floor(h/m.y),r.y=s.y*m.y,u.mapSize.y=s.y)),null===u.map&&!u.isPointLightShadow&&3===this.type){const t={minFilter:g,magFilter:g,format:E};u.map=new Tt(r.x,r.y,t),u.map.texture.name=c.name+".shadowMap",u.mapPass=new Tt(r.x,r.y,t),u.camera.updateProjectionMatrix()}if(null===u.map){const t={minFilter:p,magFilter:p,format:E};u.map=new Tt(r.x,r.y,t),u.map.texture.name=c.name+".shadowMap",u.camera.updateProjectionMatrix()}t.setRenderTarget(u.map),t.clear();const f=u.getViewportCount();for(let t=0;t<f;t++){const e=u.getViewport(t);a.set(s.x*e.x,s.y*e.y,s.x*e.z,s.y*e.w),d.viewport(a),u.updateMatrices(c,t),i=u.getFrustum(),M(n,o,u.camera,c,this.type)}u.isPointLightShadow||3!==this.type||x(u,o),u.needsUpdate=!1}y.needsUpdate=!1,t.setRenderTarget(l,c,u)}}function ds(t,e,i){const r=i.isWebGL2;const s=new function(){let e=!1;const n=new St;let i=null;const r=new St(0,0,0,0);return{setMask:function(n){i===n||e||(t.colorMask(n,n,n,n),i=n)},setLocked:function(t){e=t},setClear:function(e,i,s,a,o){!0===o&&(e*=a,i*=a,s*=a),n.set(e,i,s,a),!1===r.equals(n)&&(t.clearColor(e,i,s,a),r.copy(n))},reset:function(){e=!1,i=null,r.set(-1,0,0,0)}}},a=new function(){let e=!1,n=null,i=null,r=null;return{setTest:function(t){t?z(2929):F(2929)},setMask:function(i){n===i||e||(t.depthMask(i),n=i)},setFunc:function(e){if(i!==e){if(e)switch(e){case 0:t.depthFunc(512);break;case 1:t.depthFunc(519);break;case 2:t.depthFunc(513);break;case 3:t.depthFunc(515);break;case 4:t.depthFunc(514);break;case 5:t.depthFunc(518);break;case 6:t.depthFunc(516);break;case 7:t.depthFunc(517);break;default:t.depthFunc(515)}else t.depthFunc(515);i=e}},setLocked:function(t){e=t},setClear:function(e){r!==e&&(t.clearDepth(e),r=e)},reset:function(){e=!1,n=null,i=null,r=null}}},o=new function(){let e=!1,n=null,i=null,r=null,s=null,a=null,o=null,l=null,c=null;return{setTest:function(t){e||(t?z(2960):F(2960))},setMask:function(i){n===i||e||(t.stencilMask(i),n=i)},setFunc:function(e,n,a){i===e&&r===n&&s===a||(t.stencilFunc(e,n,a),i=e,r=n,s=a)},setOp:function(e,n,i){a===e&&o===n&&l===i||(t.stencilOp(e,n,i),a=e,o=n,l=i)},setLocked:function(t){e=t},setClear:function(e){c!==e&&(t.clearStencil(e),c=e)},reset:function(){e=!1,n=null,i=null,r=null,s=null,a=null,o=null,l=null,c=null}}};let l={},c=null,h={},u=null,d=!1,p=null,m=null,f=null,g=null,v=null,y=null,x=null,_=!1,w=null,b=null,M=null,S=null,T=null;const E=t.getParameter(35661);let A=!1,L=0;const R=t.getParameter(7938);-1!==R.indexOf("WebGL")?(L=parseFloat(/^WebGL (\d)/.exec(R)[1]),A=L>=1):-1!==R.indexOf("OpenGL ES")&&(L=parseFloat(/^OpenGL ES (\d)/.exec(R)[1]),A=L>=2);let C=null,P={};const D=new St(0,0,t.canvas.width,t.canvas.height),I=new St(0,0,t.canvas.width,t.canvas.height);function N(e,n,i){const r=new Uint8Array(4),s=t.createTexture();t.bindTexture(e,s),t.texParameteri(e,10241,9728),t.texParameteri(e,10240,9728);for(let e=0;e<i;e++)t.texImage2D(n+e,0,6408,1,1,0,6408,5121,r);return s}const B={};function z(e){!0!==l[e]&&(t.enable(e),l[e]=!0)}function F(e){!1!==l[e]&&(t.disable(e),l[e]=!1)}B[3553]=N(3553,3553,1),B[34067]=N(34067,34069,6),s.setClear(0,0,0,1),a.setClear(1),o.setClear(0),z(2929),a.setFunc(3),U(!1),k(1),z(2884),G(0);const O={[n]:32774,101:32778,102:32779};if(r)O[103]=32775,O[104]=32776;else{const t=e.get("EXT_blend_minmax");null!==t&&(O[103]=t.MIN_EXT,O[104]=t.MAX_EXT)}const H={200:0,201:1,202:768,204:770,210:776,208:774,206:772,203:769,205:771,209:775,207:773};function G(e,i,r,s,a,o,l,c){if(0!==e){if(!1===d&&(z(3042),d=!0),5===e)a=a||i,o=o||r,l=l||s,i===m&&a===v||(t.blendEquationSeparate(O[i],O[a]),m=i,v=a),r===f&&s===g&&o===y&&l===x||(t.blendFuncSeparate(H[r],H[s],H[o],H[l]),f=r,g=s,y=o,x=l),p=e,_=null;else if(e!==p||c!==_){if(m===n&&v===n||(t.blendEquation(32774),m=n,v=n),c)switch(e){case 1:t.blendFuncSeparate(1,771,1,771);break;case 2:t.blendFunc(1,1);break;case 3:t.blendFuncSeparate(0,0,769,771);break;case 4:t.blendFuncSeparate(0,768,0,770);break;default:console.error("THREE.WebGLState: Invalid blending: ",e)}else switch(e){case 1:t.blendFuncSeparate(770,771,1,771);break;case 2:t.blendFunc(770,1);break;case 3:t.blendFunc(0,769);break;case 4:t.blendFunc(0,768);break;default:console.error("THREE.WebGLState: Invalid blending: ",e)}f=null,g=null,y=null,x=null,p=e,_=c}}else!0===d&&(F(3042),d=!1)}function U(e){w!==e&&(e?t.frontFace(2304):t.frontFace(2305),w=e)}function k(e){0!==e?(z(2884),e!==b&&(1===e?t.cullFace(1029):2===e?t.cullFace(1028):t.cullFace(1032))):F(2884),b=e}function V(e,n,i){e?(z(32823),S===n&&T===i||(t.polygonOffset(n,i),S=n,T=i)):F(32823)}function W(e){void 0===e&&(e=33984+E-1),C!==e&&(t.activeTexture(e),C=e)}return{buffers:{color:s,depth:a,stencil:o},enable:z,disable:F,bindFramebuffer:function(e,n){null===n&&null!==c&&(n=c),h[e]!==n&&(t.bindFramebuffer(e,n),h[e]=n,r&&(36009===e&&(h[36160]=n),36160===e&&(h[36009]=n)))},bindXRFramebuffer:function(e){e!==c&&(t.bindFramebuffer(36160,e),c=e)},useProgram:function(e){return u!==e&&(t.useProgram(e),u=e,!0)},setBlending:G,setMaterial:function(t,e){2===t.side?F(2884):z(2884);let n=1===t.side;e&&(n=!n),U(n),1===t.blending&&!1===t.transparent?G(0):G(t.blending,t.blendEquation,t.blendSrc,t.blendDst,t.blendEquationAlpha,t.blendSrcAlpha,t.blendDstAlpha,t.premultipliedAlpha),a.setFunc(t.depthFunc),a.setTest(t.depthTest),a.setMask(t.depthWrite),s.setMask(t.colorWrite);const i=t.stencilWrite;o.setTest(i),i&&(o.setMask(t.stencilWriteMask),o.setFunc(t.stencilFunc,t.stencilRef,t.stencilFuncMask),o.setOp(t.stencilFail,t.stencilZFail,t.stencilZPass)),V(t.polygonOffset,t.polygonOffsetFactor,t.polygonOffsetUnits),!0===t.alphaToCoverage?z(32926):F(32926)},setFlipSided:U,setCullFace:k,setLineWidth:function(e){e!==M&&(A&&t.lineWidth(e),M=e)},setPolygonOffset:V,setScissorTest:function(t){t?z(3089):F(3089)},activeTexture:W,bindTexture:function(e,n){null===C&&W();let i=P[C];void 0===i&&(i={type:void 0,texture:void 0},P[C]=i),i.type===e&&i.texture===n||(t.bindTexture(e,n||B[e]),i.type=e,i.texture=n)},unbindTexture:function(){const e=P[C];void 0!==e&&void 0!==e.type&&(t.bindTexture(e.type,null),e.type=void 0,e.texture=void 0)},compressedTexImage2D:function(){try{t.compressedTexImage2D.apply(t,arguments)}catch(t){console.error("THREE.WebGLState:",t)}},texImage2D:function(){try{t.texImage2D.apply(t,arguments)}catch(t){console.error("THREE.WebGLState:",t)}},texImage3D:function(){try{t.texImage3D.apply(t,arguments)}catch(t){console.error("THREE.WebGLState:",t)}},scissor:function(e){!1===D.equals(e)&&(t.scissor(e.x,e.y,e.z,e.w),D.copy(e))},viewport:function(e){!1===I.equals(e)&&(t.viewport(e.x,e.y,e.z,e.w),I.copy(e))},reset:function(){t.disable(3042),t.disable(2884),t.disable(2929),t.disable(32823),t.disable(3089),t.disable(2960),t.disable(32926),t.blendEquation(32774),t.blendFunc(1,0),t.blendFuncSeparate(1,0,1,0),t.colorMask(!0,!0,!0,!0),t.clearColor(0,0,0,0),t.depthMask(!0),t.depthFunc(513),t.clearDepth(1),t.stencilMask(4294967295),t.stencilFunc(519,0,4294967295),t.stencilOp(7680,7680,7680),t.clearStencil(0),t.cullFace(1029),t.frontFace(2305),t.polygonOffset(0,0),t.activeTexture(33984),t.bindFramebuffer(36160,null),!0===r&&(t.bindFramebuffer(36009,null),t.bindFramebuffer(36008,null)),t.useProgram(null),t.lineWidth(1),t.scissor(0,0,t.canvas.width,t.canvas.height),t.viewport(0,0,t.canvas.width,t.canvas.height),l={},C=null,P={},c=null,h={},u=null,d=!1,p=null,m=null,f=null,g=null,v=null,y=null,x=null,_=!1,w=null,b=null,M=null,S=null,T=null,D.set(0,0,t.canvas.width,t.canvas.height),I.set(0,0,t.canvas.width,t.canvas.height),s.reset(),a.reset(),o.reset()}}}function ps(t,e,n,i,r,s,a){const o=r.isWebGL2,l=r.maxTextures,c=r.maxCubemapSize,x=r.maxTextureSize,R=r.maxSamples,C=new WeakMap;let P,D=!1;try{D="undefined"!=typeof OffscreenCanvas&&null!==new OffscreenCanvas(1,1).getContext("2d")}catch(t){}function I(t,e){return D?new OffscreenCanvas(t,e):document.createElementNS("http://www.w3.org/1999/xhtml","canvas")}function N(t,e,n,i){let r=1;if((t.width>i||t.height>i)&&(r=i/Math.max(t.width,t.height)),r<1||!0===e){if("undefined"!=typeof HTMLImageElement&&t instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&t instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&t instanceof ImageBitmap){const i=e?ft:Math.floor,s=i(r*t.width),a=i(r*t.height);void 0===P&&(P=I(s,a));const o=n?I(s,a):P;o.width=s,o.height=a;return o.getContext("2d").drawImage(t,0,0,s,a),console.warn("THREE.WebGLRenderer: Texture has been resized from ("+t.width+"x"+t.height+") to ("+s+"x"+a+")."),o}return"data"in t&&console.warn("THREE.WebGLRenderer: Image in DataTexture is too big ("+t.width+"x"+t.height+")."),t}return t}function B(t){return pt(t.width)&&pt(t.height)}function z(t,e){return t.generateMipmaps&&e&&t.minFilter!==p&&t.minFilter!==g}function F(e,n,r,s){t.generateMipmap(e);i.get(n).__maxMipLevel=Math.log2(Math.max(r,s))}function O(n,i,r){if(!1===o)return i;if(null!==n){if(void 0!==t[n])return t[n];console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '"+n+"'")}let s=i;return 6403===i&&(5126===r&&(s=33326),5131===r&&(s=33325),5121===r&&(s=33321)),6407===i&&(5126===r&&(s=34837),5131===r&&(s=34843),5121===r&&(s=32849)),6408===i&&(5126===r&&(s=34836),5131===r&&(s=34842),5121===r&&(s=32856)),33325!==s&&33326!==s&&34842!==s&&34836!==s||e.get("EXT_color_buffer_float"),s}function H(t){return t===p||t===m||t===f?9728:9729}function G(e){const n=e.target;n.removeEventListener("dispose",G),function(e){const n=i.get(e);if(void 0===n.__webglInit)return;t.deleteTexture(n.__webglTexture),i.remove(e)}(n),n.isVideoTexture&&C.delete(n),a.memory.textures--}function U(e){const n=e.target;n.removeEventListener("dispose",U),function(e){const n=e.texture,r=i.get(e),s=i.get(n);if(!e)return;void 0!==s.__webglTexture&&t.deleteTexture(s.__webglTexture);e.depthTexture&&e.depthTexture.dispose();if(e.isWebGLCubeRenderTarget)for(let e=0;e<6;e++)t.deleteFramebuffer(r.__webglFramebuffer[e]),r.__webglDepthbuffer&&t.deleteRenderbuffer(r.__webglDepthbuffer[e]);else t.deleteFramebuffer(r.__webglFramebuffer),r.__webglDepthbuffer&&t.deleteRenderbuffer(r.__webglDepthbuffer),r.__webglMultisampledFramebuffer&&t.deleteFramebuffer(r.__webglMultisampledFramebuffer),r.__webglColorRenderbuffer&&t.deleteRenderbuffer(r.__webglColorRenderbuffer),r.__webglDepthRenderbuffer&&t.deleteRenderbuffer(r.__webglDepthRenderbuffer);i.remove(n),i.remove(e)}(n),a.memory.textures--}let k=0;function V(t,e){const r=i.get(t);if(t.isVideoTexture&&function(t){const e=a.render.frame;C.get(t)!==e&&(C.set(t,e),t.update())}(t),t.version>0&&r.__version!==t.version){const n=t.image;if(void 0===n)console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined");else{if(!1!==n.complete)return void Z(r,t,e);console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete")}}n.activeTexture(33984+e),n.bindTexture(3553,r.__webglTexture)}function W(e,r){const a=i.get(e);e.version>0&&a.__version!==e.version?function(e,i,r){if(6!==i.image.length)return;Y(e,i),n.activeTexture(33984+r),n.bindTexture(34067,e.__webglTexture),t.pixelStorei(37440,i.flipY),t.pixelStorei(37441,i.premultiplyAlpha),t.pixelStorei(3317,i.unpackAlignment),t.pixelStorei(37443,0);const a=i&&(i.isCompressedTexture||i.image[0].isCompressedTexture),l=i.image[0]&&i.image[0].isDataTexture,h=[];for(let t=0;t<6;t++)h[t]=a||l?l?i.image[t].image:i.image[t]:N(i.image[t],!1,!0,c);const u=h[0],d=B(u)||o,p=s.convert(i.format),m=s.convert(i.type),f=O(i.internalFormat,p,m);let g;if(X(34067,i,d),a){for(let t=0;t<6;t++){g=h[t].mipmaps;for(let e=0;e<g.length;e++){const r=g[e];i.format!==E&&i.format!==T?null!==p?n.compressedTexImage2D(34069+t,e,f,r.width,r.height,0,r.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .setTextureCube()"):n.texImage2D(34069+t,e,f,r.width,r.height,0,p,m,r.data)}}e.__maxMipLevel=g.length-1}else{g=i.mipmaps;for(let t=0;t<6;t++)if(l){n.texImage2D(34069+t,0,f,h[t].width,h[t].height,0,p,m,h[t].data);for(let e=0;e<g.length;e++){const i=g[e].image[t].image;n.texImage2D(34069+t,e+1,f,i.width,i.height,0,p,m,i.data)}}else{n.texImage2D(34069+t,0,f,p,m,h[t]);for(let e=0;e<g.length;e++){const i=g[e];n.texImage2D(34069+t,e+1,f,p,m,i.image[t])}}e.__maxMipLevel=g.length}z(i,d)&&F(34067,i,u.width,u.height);e.__version=i.version,i.onUpdate&&i.onUpdate(i)}(a,e,r):(n.activeTexture(33984+r),n.bindTexture(34067,a.__webglTexture))}const j={[h]:10497,[u]:33071,[d]:33648},q={[p]:9728,[m]:9984,[f]:9986,[g]:9729,[v]:9985,[y]:9987};function X(n,s,a){if(a?(t.texParameteri(n,10242,j[s.wrapS]),t.texParameteri(n,10243,j[s.wrapT]),32879!==n&&35866!==n||t.texParameteri(n,32882,j[s.wrapR]),t.texParameteri(n,10240,q[s.magFilter]),t.texParameteri(n,10241,q[s.minFilter])):(t.texParameteri(n,10242,33071),t.texParameteri(n,10243,33071),32879!==n&&35866!==n||t.texParameteri(n,32882,33071),s.wrapS===u&&s.wrapT===u||console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.wrapS and Texture.wrapT should be set to THREE.ClampToEdgeWrapping."),t.texParameteri(n,10240,H(s.magFilter)),t.texParameteri(n,10241,H(s.minFilter)),s.minFilter!==p&&s.minFilter!==g&&console.warn("THREE.WebGLRenderer: Texture is not power of two. Texture.minFilter should be set to THREE.NearestFilter or THREE.LinearFilter.")),!0===e.has("EXT_texture_filter_anisotropic")){const a=e.get("EXT_texture_filter_anisotropic");if(s.type===b&&!1===e.has("OES_texture_float_linear"))return;if(!1===o&&s.type===M&&!1===e.has("OES_texture_half_float_linear"))return;(s.anisotropy>1||i.get(s).__currentAnisotropy)&&(t.texParameterf(n,a.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(s.anisotropy,r.getMaxAnisotropy())),i.get(s).__currentAnisotropy=s.anisotropy)}}function Y(e,n){void 0===e.__webglInit&&(e.__webglInit=!0,n.addEventListener("dispose",G),e.__webglTexture=t.createTexture(),a.memory.textures++)}function Z(e,i,r){let a=3553;i.isDataTexture2DArray&&(a=35866),i.isDataTexture3D&&(a=32879),Y(e,i),n.activeTexture(33984+r),n.bindTexture(a,e.__webglTexture),t.pixelStorei(37440,i.flipY),t.pixelStorei(37441,i.premultiplyAlpha),t.pixelStorei(3317,i.unpackAlignment),t.pixelStorei(37443,0);const l=function(t){return!o&&(t.wrapS!==u||t.wrapT!==u||t.minFilter!==p&&t.minFilter!==g)}(i)&&!1===B(i.image),c=N(i.image,l,!1,x),h=B(c)||o,d=s.convert(i.format);let m,f=s.convert(i.type),v=O(i.internalFormat,d,f);X(a,i,h);const y=i.mipmaps;if(i.isDepthTexture)v=6402,o?v=i.type===b?36012:i.type===w?33190:i.type===S?35056:33189:i.type===b&&console.error("WebGLRenderer: Floating point depth texture requires WebGL2."),i.format===A&&6402===v&&i.type!==_&&i.type!==w&&(console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."),i.type=_,f=s.convert(i.type)),i.format===L&&6402===v&&(v=34041,i.type!==S&&(console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."),i.type=S,f=s.convert(i.type))),n.texImage2D(3553,0,v,c.width,c.height,0,d,f,null);else if(i.isDataTexture)if(y.length>0&&h){for(let t=0,e=y.length;t<e;t++)m=y[t],n.texImage2D(3553,t,v,m.width,m.height,0,d,f,m.data);i.generateMipmaps=!1,e.__maxMipLevel=y.length-1}else n.texImage2D(3553,0,v,c.width,c.height,0,d,f,c.data),e.__maxMipLevel=0;else if(i.isCompressedTexture){for(let t=0,e=y.length;t<e;t++)m=y[t],i.format!==E&&i.format!==T?null!==d?n.compressedTexImage2D(3553,t,v,m.width,m.height,0,m.data):console.warn("THREE.WebGLRenderer: Attempt to load unsupported compressed texture format in .uploadTexture()"):n.texImage2D(3553,t,v,m.width,m.height,0,d,f,m.data);e.__maxMipLevel=y.length-1}else if(i.isDataTexture2DArray)n.texImage3D(35866,0,v,c.width,c.height,c.depth,0,d,f,c.data),e.__maxMipLevel=0;else if(i.isDataTexture3D)n.texImage3D(32879,0,v,c.width,c.height,c.depth,0,d,f,c.data),e.__maxMipLevel=0;else if(y.length>0&&h){for(let t=0,e=y.length;t<e;t++)m=y[t],n.texImage2D(3553,t,v,d,f,m);i.generateMipmaps=!1,e.__maxMipLevel=y.length-1}else n.texImage2D(3553,0,v,d,f,c),e.__maxMipLevel=0;z(i,h)&&F(a,i,c.width,c.height),e.__version=i.version,i.onUpdate&&i.onUpdate(i)}function J(e,r,a,o){const l=r.texture,c=s.convert(l.format),h=s.convert(l.type),u=O(l.internalFormat,c,h);32879===o||35866===o?n.texImage3D(o,0,u,r.width,r.height,r.depth,0,c,h,null):n.texImage2D(o,0,u,r.width,r.height,0,c,h,null),n.bindFramebuffer(36160,e),t.framebufferTexture2D(36160,a,o,i.get(l).__webglTexture,0),n.bindFramebuffer(36160,null)}function Q(e,n,i){if(t.bindRenderbuffer(36161,e),n.depthBuffer&&!n.stencilBuffer){let r=33189;if(i){const e=n.depthTexture;e&&e.isDepthTexture&&(e.type===b?r=36012:e.type===w&&(r=33190));const i=$(n);t.renderbufferStorageMultisample(36161,i,r,n.width,n.height)}else t.renderbufferStorage(36161,r,n.width,n.height);t.framebufferRenderbuffer(36160,36096,36161,e)}else if(n.depthBuffer&&n.stencilBuffer){if(i){const e=$(n);t.renderbufferStorageMultisample(36161,e,35056,n.width,n.height)}else t.renderbufferStorage(36161,34041,n.width,n.height);t.framebufferRenderbuffer(36160,33306,36161,e)}else{const e=n.texture,r=s.convert(e.format),a=s.convert(e.type),o=O(e.internalFormat,r,a);if(i){const e=$(n);t.renderbufferStorageMultisample(36161,e,o,n.width,n.height)}else t.renderbufferStorage(36161,o,n.width,n.height)}t.bindRenderbuffer(36161,null)}function K(e){const r=i.get(e),s=!0===e.isWebGLCubeRenderTarget;if(e.depthTexture){if(s)throw new Error("target.depthTexture not supported in Cube render targets");!function(e,r){if(r&&r.isWebGLCubeRenderTarget)throw new Error("Depth Texture with cube render targets is not supported");if(n.bindFramebuffer(36160,e),!r.depthTexture||!r.depthTexture.isDepthTexture)throw new Error("renderTarget.depthTexture must be an instance of THREE.DepthTexture");i.get(r.depthTexture).__webglTexture&&r.depthTexture.image.width===r.width&&r.depthTexture.image.height===r.height||(r.depthTexture.image.width=r.width,r.depthTexture.image.height=r.height,r.depthTexture.needsUpdate=!0),V(r.depthTexture,0);const s=i.get(r.depthTexture).__webglTexture;if(r.depthTexture.format===A)t.framebufferTexture2D(36160,36096,3553,s,0);else{if(r.depthTexture.format!==L)throw new Error("Unknown depthTexture format");t.framebufferTexture2D(36160,33306,3553,s,0)}}(r.__webglFramebuffer,e)}else if(s){r.__webglDepthbuffer=[];for(let i=0;i<6;i++)n.bindFramebuffer(36160,r.__webglFramebuffer[i]),r.__webglDepthbuffer[i]=t.createRenderbuffer(),Q(r.__webglDepthbuffer[i],e,!1)}else n.bindFramebuffer(36160,r.__webglFramebuffer),r.__webglDepthbuffer=t.createRenderbuffer(),Q(r.__webglDepthbuffer,e,!1);n.bindFramebuffer(36160,null)}function $(t){return o&&t.isWebGLMultisampleRenderTarget?Math.min(R,t.samples):0}let tt=!1,et=!1;this.allocateTextureUnit=function(){const t=k;return t>=l&&console.warn("THREE.WebGLTextures: Trying to use "+t+" texture units while this GPU supports only "+l),k+=1,t},this.resetTextureUnits=function(){k=0},this.setTexture2D=V,this.setTexture2DArray=function(t,e){const r=i.get(t);t.version>0&&r.__version!==t.version?Z(r,t,e):(n.activeTexture(33984+e),n.bindTexture(35866,r.__webglTexture))},this.setTexture3D=function(t,e){const r=i.get(t);t.version>0&&r.__version!==t.version?Z(r,t,e):(n.activeTexture(33984+e),n.bindTexture(32879,r.__webglTexture))},this.setTextureCube=W,this.setupRenderTarget=function(e){const r=e.texture,l=i.get(e),c=i.get(r);e.addEventListener("dispose",U),c.__webglTexture=t.createTexture(),c.__version=r.version,a.memory.textures++;const h=!0===e.isWebGLCubeRenderTarget,u=!0===e.isWebGLMultisampleRenderTarget,d=r.isDataTexture3D||r.isDataTexture2DArray,p=B(e)||o;if(!o||r.format!==T||r.type!==b&&r.type!==M||(r.format=E,console.warn("THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.")),h){l.__webglFramebuffer=[];for(let e=0;e<6;e++)l.__webglFramebuffer[e]=t.createFramebuffer()}else if(l.__webglFramebuffer=t.createFramebuffer(),u)if(o){l.__webglMultisampledFramebuffer=t.createFramebuffer(),l.__webglColorRenderbuffer=t.createRenderbuffer(),t.bindRenderbuffer(36161,l.__webglColorRenderbuffer);const i=s.convert(r.format),a=s.convert(r.type),o=O(r.internalFormat,i,a),c=$(e);t.renderbufferStorageMultisample(36161,c,o,e.width,e.height),n.bindFramebuffer(36160,l.__webglMultisampledFramebuffer),t.framebufferRenderbuffer(36160,36064,36161,l.__webglColorRenderbuffer),t.bindRenderbuffer(36161,null),e.depthBuffer&&(l.__webglDepthRenderbuffer=t.createRenderbuffer(),Q(l.__webglDepthRenderbuffer,e,!0)),n.bindFramebuffer(36160,null)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.");if(h){n.bindTexture(34067,c.__webglTexture),X(34067,r,p);for(let t=0;t<6;t++)J(l.__webglFramebuffer[t],e,36064,34069+t);z(r,p)&&F(34067,r,e.width,e.height),n.bindTexture(34067,null)}else{let t=3553;if(d)if(o){t=r.isDataTexture3D?32879:35866}else console.warn("THREE.DataTexture3D and THREE.DataTexture2DArray only supported with WebGL2.");n.bindTexture(t,c.__webglTexture),X(t,r,p),J(l.__webglFramebuffer,e,36064,t),z(r,p)&&F(3553,r,e.width,e.height),n.bindTexture(3553,null)}e.depthBuffer&&K(e)},this.updateRenderTargetMipmap=function(t){const e=t.texture;if(z(e,B(t)||o)){const r=t.isWebGLCubeRenderTarget?34067:3553,s=i.get(e).__webglTexture;n.bindTexture(r,s),F(r,e,t.width,t.height),n.bindTexture(r,null)}},this.updateMultisampleRenderTarget=function(e){if(e.isWebGLMultisampleRenderTarget)if(o){const r=e.width,s=e.height;let a=16384;e.depthBuffer&&(a|=256),e.stencilBuffer&&(a|=1024);const o=i.get(e);n.bindFramebuffer(36008,o.__webglMultisampledFramebuffer),n.bindFramebuffer(36009,o.__webglFramebuffer),t.blitFramebuffer(0,0,r,s,0,0,r,s,a,9728),n.bindFramebuffer(36008,null),n.bindFramebuffer(36009,o.__webglMultisampledFramebuffer)}else console.warn("THREE.WebGLRenderer: WebGLMultisampleRenderTarget can only be used with WebGL2.")},this.safeSetTexture2D=function(t,e){t&&t.isWebGLRenderTarget&&(!1===tt&&(console.warn("THREE.WebGLTextures.safeSetTexture2D: don't use render targets as textures. Use their .texture property instead."),tt=!0),t=t.texture),V(t,e)},this.safeSetTextureCube=function(t,e){t&&t.isWebGLCubeRenderTarget&&(!1===et&&(console.warn("THREE.WebGLTextures.safeSetTextureCube: don't use cube render targets as textures. Use their .texture property instead."),et=!0),t=t.texture),W(t,e)}}function ms(t,e,n){const i=n.isWebGL2;return{convert:function(t){let n;if(t===x)return 5121;if(1017===t)return 32819;if(1018===t)return 32820;if(1019===t)return 33635;if(1010===t)return 5120;if(1011===t)return 5122;if(t===_)return 5123;if(1013===t)return 5124;if(t===w)return 5125;if(t===b)return 5126;if(t===M)return i?5131:(n=e.get("OES_texture_half_float"),null!==n?n.HALF_FLOAT_OES:null);if(1021===t)return 6406;if(t===T)return 6407;if(t===E)return 6408;if(1024===t)return 6409;if(1025===t)return 6410;if(t===A)return 6402;if(t===L)return 34041;if(1028===t)return 6403;if(1029===t)return 36244;if(1030===t)return 33319;if(1031===t)return 33320;if(1032===t)return 36248;if(1033===t)return 36249;if(t===R||t===C||t===P||t===D){if(n=e.get("WEBGL_compressed_texture_s3tc"),null===n)return null;if(t===R)return n.COMPRESSED_RGB_S3TC_DXT1_EXT;if(t===C)return n.COMPRESSED_RGBA_S3TC_DXT1_EXT;if(t===P)return n.COMPRESSED_RGBA_S3TC_DXT3_EXT;if(t===D)return n.COMPRESSED_RGBA_S3TC_DXT5_EXT}if(t===I||t===N||t===B||t===z){if(n=e.get("WEBGL_compressed_texture_pvrtc"),null===n)return null;if(t===I)return n.COMPRESSED_RGB_PVRTC_4BPPV1_IMG;if(t===N)return n.COMPRESSED_RGB_PVRTC_2BPPV1_IMG;if(t===B)return n.COMPRESSED_RGBA_PVRTC_4BPPV1_IMG;if(t===z)return n.COMPRESSED_RGBA_PVRTC_2BPPV1_IMG}if(36196===t)return n=e.get("WEBGL_compressed_texture_etc1"),null!==n?n.COMPRESSED_RGB_ETC1_WEBGL:null;if((t===F||t===O)&&(n=e.get("WEBGL_compressed_texture_etc"),null!==n)){if(t===F)return n.COMPRESSED_RGB8_ETC2;if(t===O)return n.COMPRESSED_RGBA8_ETC2_EAC}return 37808===t||37809===t||37810===t||37811===t||37812===t||37813===t||37814===t||37815===t||37816===t||37817===t||37818===t||37819===t||37820===t||37821===t||37840===t||37841===t||37842===t||37843===t||37844===t||37845===t||37846===t||37847===t||37848===t||37849===t||37850===t||37851===t||37852===t||37853===t?(n=e.get("WEBGL_compressed_texture_astc"),null!==n?t:null):36492===t?(n=e.get("EXT_texture_compression_bptc"),null!==n?t:null):t===S?i?34042:(n=e.get("WEBGL_depth_texture"),null!==n?n.UNSIGNED_INT_24_8_WEBGL:null):void 0}}}class fs extends Kn{constructor(t=[]){super(),this.cameras=t}}fs.prototype.isArrayCamera=!0;class gs extends Ce{constructor(){super(),this.type="Group"}}gs.prototype.isGroup=!0;const vs={type:"move"};class ys{constructor(){this._targetRay=null,this._grip=null,this._hand=null}getHandSpace(){return null===this._hand&&(this._hand=new gs,this._hand.matrixAutoUpdate=!1,this._hand.visible=!1,this._hand.joints={},this._hand.inputState={pinching:!1}),this._hand}getTargetRaySpace(){return null===this._targetRay&&(this._targetRay=new gs,this._targetRay.matrixAutoUpdate=!1,this._targetRay.visible=!1,this._targetRay.hasLinearVelocity=!1,this._targetRay.linearVelocity=new Lt,this._targetRay.hasAngularVelocity=!1,this._targetRay.angularVelocity=new Lt),this._targetRay}getGripSpace(){return null===this._grip&&(this._grip=new gs,this._grip.matrixAutoUpdate=!1,this._grip.visible=!1,this._grip.hasLinearVelocity=!1,this._grip.linearVelocity=new Lt,this._grip.hasAngularVelocity=!1,this._grip.angularVelocity=new Lt),this._grip}dispatchEvent(t){return null!==this._targetRay&&this._targetRay.dispatchEvent(t),null!==this._grip&&this._grip.dispatchEvent(t),null!==this._hand&&this._hand.dispatchEvent(t),this}disconnect(t){return this.dispatchEvent({type:"disconnected",data:t}),null!==this._targetRay&&(this._targetRay.visible=!1),null!==this._grip&&(this._grip.visible=!1),null!==this._hand&&(this._hand.visible=!1),this}update(t,e,n){let i=null,r=null,s=null;const a=this._targetRay,o=this._grip,l=this._hand;if(t&&"visible-blurred"!==e.session.visibilityState)if(null!==a&&(i=e.getPose(t.targetRaySpace,n),null!==i&&(a.matrix.fromArray(i.transform.matrix),a.matrix.decompose(a.position,a.rotation,a.scale),i.linearVelocity?(a.hasLinearVelocity=!0,a.linearVelocity.copy(i.linearVelocity)):a.hasLinearVelocity=!1,i.angularVelocity?(a.hasAngularVelocity=!0,a.angularVelocity.copy(i.angularVelocity)):a.hasAngularVelocity=!1,this.dispatchEvent(vs))),l&&t.hand){s=!0;for(const i of t.hand.values()){const t=e.getJointPose(i,n);if(void 0===l.joints[i.jointName]){const t=new gs;t.matrixAutoUpdate=!1,t.visible=!1,l.joints[i.jointName]=t,l.add(t)}const r=l.joints[i.jointName];null!==t&&(r.matrix.fromArray(t.transform.matrix),r.matrix.decompose(r.position,r.rotation,r.scale),r.jointRadius=t.radius),r.visible=null!==t}const i=l.joints["index-finger-tip"],r=l.joints["thumb-tip"],a=i.position.distanceTo(r.position),o=.02,c=.005;l.inputState.pinching&&a>o+c?(l.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!l.inputState.pinching&&a<=o-c&&(l.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else null!==o&&t.gripSpace&&(r=e.getPose(t.gripSpace,n),null!==r&&(o.matrix.fromArray(r.transform.matrix),o.matrix.decompose(o.position,o.rotation,o.scale),r.linearVelocity?(o.hasLinearVelocity=!0,o.linearVelocity.copy(r.linearVelocity)):o.hasLinearVelocity=!1,r.angularVelocity?(o.hasAngularVelocity=!0,o.angularVelocity.copy(r.angularVelocity)):o.hasAngularVelocity=!1));return null!==a&&(a.visible=null!==i),null!==o&&(o.visible=null!==r),null!==l&&(l.visible=null!==s),this}}class xs extends rt{constructor(t,e){super();const n=this,i=t.state;let r=null,s=1,a=null,o="local-floor",l=null;const c=[],h=new Map,u=new Kn;u.layers.enable(1),u.viewport=new St;const d=new Kn;d.layers.enable(2),d.viewport=new St;const p=[u,d],m=new fs;m.layers.enable(1),m.layers.enable(2);let f=null,g=null;function v(t){const e=h.get(t.inputSource);e&&e.dispatchEvent({type:t.type,data:t.inputSource})}function y(){h.forEach((function(t,e){t.disconnect(e)})),h.clear(),f=null,g=null,i.bindXRFramebuffer(null),t.setRenderTarget(t.getRenderTarget()),S.stop(),n.isPresenting=!1,n.dispatchEvent({type:"sessionend"})}function x(t){const e=r.inputSources;for(let t=0;t<c.length;t++)h.set(e[t],c[t]);for(let e=0;e<t.removed.length;e++){const n=t.removed[e],i=h.get(n);i&&(i.dispatchEvent({type:"disconnected",data:n}),h.delete(n))}for(let e=0;e<t.added.length;e++){const n=t.added[e],i=h.get(n);i&&i.dispatchEvent({type:"connected",data:n})}}this.enabled=!1,this.isPresenting=!1,this.getController=function(t){let e=c[t];return void 0===e&&(e=new ys,c[t]=e),e.getTargetRaySpace()},this.getControllerGrip=function(t){let e=c[t];return void 0===e&&(e=new ys,c[t]=e),e.getGripSpace()},this.getHand=function(t){let e=c[t];return void 0===e&&(e=new ys,c[t]=e),e.getHandSpace()},this.setFramebufferScaleFactor=function(t){s=t,!0===n.isPresenting&&console.warn("THREE.WebXRManager: Cannot change framebuffer scale while presenting.")},this.setReferenceSpaceType=function(t){o=t,!0===n.isPresenting&&console.warn("THREE.WebXRManager: Cannot change reference space type while presenting.")},this.getReferenceSpace=function(){return a},this.getSession=function(){return r},this.setSession=async function(t){if(r=t,null!==r){r.addEventListener("select",v),r.addEventListener("selectstart",v),r.addEventListener("selectend",v),r.addEventListener("squeeze",v),r.addEventListener("squeezestart",v),r.addEventListener("squeezeend",v),r.addEventListener("end",y),r.addEventListener("inputsourceschange",x);const t=e.getContextAttributes();!0!==t.xrCompatible&&await e.makeXRCompatible();const i={antialias:t.antialias,alpha:t.alpha,depth:t.depth,stencil:t.stencil,framebufferScaleFactor:s},l=new XRWebGLLayer(r,e,i);r.updateRenderState({baseLayer:l}),a=await r.requestReferenceSpace(o),S.setContext(r),S.start(),n.isPresenting=!0,n.dispatchEvent({type:"sessionstart"})}};const _=new Lt,w=new Lt;function b(t,e){null===e?t.matrixWorld.copy(t.matrix):t.matrixWorld.multiplyMatrices(e.matrixWorld,t.matrix),t.matrixWorldInverse.copy(t.matrixWorld).invert()}this.getCamera=function(t){m.near=d.near=u.near=t.near,m.far=d.far=u.far=t.far,f===m.near&&g===m.far||(r.updateRenderState({depthNear:m.near,depthFar:m.far}),f=m.near,g=m.far);const e=t.parent,n=m.cameras;b(m,e);for(let t=0;t<n.length;t++)b(n[t],e);t.matrixWorld.copy(m.matrixWorld),t.matrix.copy(m.matrix),t.matrix.decompose(t.position,t.quaternion,t.scale);const i=t.children;for(let t=0,e=i.length;t<e;t++)i[t].updateMatrixWorld(!0);return 2===n.length?function(t,e,n){_.setFromMatrixPosition(e.matrixWorld),w.setFromMatrixPosition(n.matrixWorld);const i=_.distanceTo(w),r=e.projectionMatrix.elements,s=n.projectionMatrix.elements,a=r[14]/(r[10]-1),o=r[14]/(r[10]+1),l=(r[9]+1)/r[5],c=(r[9]-1)/r[5],h=(r[8]-1)/r[0],u=(s[8]+1)/s[0],d=a*h,p=a*u,m=i/(-h+u),f=m*-h;e.matrixWorld.decompose(t.position,t.quaternion,t.scale),t.translateX(f),t.translateZ(m),t.matrixWorld.compose(t.position,t.quaternion,t.scale),t.matrixWorldInverse.copy(t.matrixWorld).invert();const g=a+m,v=o+m,y=d-f,x=p+(i-f),b=l*o/v*g,M=c*o/v*g;t.projectionMatrix.makePerspective(y,x,b,M,g,v)}(m,u,d):m.projectionMatrix.copy(u.projectionMatrix),m};let M=null;const S=new oi;S.setAnimationLoop((function(t,e){if(l=e.getViewerPose(a),null!==l){const t=l.views,e=r.renderState.baseLayer;i.bindXRFramebuffer(e.framebuffer);let n=!1;t.length!==m.cameras.length&&(m.cameras.length=0,n=!0);for(let i=0;i<t.length;i++){const r=t[i],s=e.getViewport(r),a=p[i];a.matrix.fromArray(r.transform.matrix),a.projectionMatrix.fromArray(r.projectionMatrix),a.viewport.set(s.x,s.y,s.width,s.height),0===i&&m.matrix.copy(a.matrix),!0===n&&m.cameras.push(a)}}const n=r.inputSources;for(let t=0;t<c.length;t++){const i=c[t],r=n[t];i.update(r,e,a)}M&&M(t,e)})),this.setAnimationLoop=function(t){M=t},this.dispose=function(){}}}function _s(t){function e(e,n){e.opacity.value=n.opacity,n.color&&e.diffuse.value.copy(n.color),n.emissive&&e.emissive.value.copy(n.emissive).multiplyScalar(n.emissiveIntensity),n.map&&(e.map.value=n.map),n.alphaMap&&(e.alphaMap.value=n.alphaMap),n.specularMap&&(e.specularMap.value=n.specularMap);const i=t.get(n).envMap;if(i){e.envMap.value=i,e.flipEnvMap.value=i.isCubeTexture&&i._needsFlipEnvMap?-1:1,e.reflectivity.value=n.reflectivity,e.refractionRatio.value=n.refractionRatio;const r=t.get(i).__maxMipLevel;void 0!==r&&(e.maxMipLevel.value=r)}let r,s;n.lightMap&&(e.lightMap.value=n.lightMap,e.lightMapIntensity.value=n.lightMapIntensity),n.aoMap&&(e.aoMap.value=n.aoMap,e.aoMapIntensity.value=n.aoMapIntensity),n.map?r=n.map:n.specularMap?r=n.specularMap:n.displacementMap?r=n.displacementMap:n.normalMap?r=n.normalMap:n.bumpMap?r=n.bumpMap:n.roughnessMap?r=n.roughnessMap:n.metalnessMap?r=n.metalnessMap:n.alphaMap?r=n.alphaMap:n.emissiveMap?r=n.emissiveMap:n.clearcoatMap?r=n.clearcoatMap:n.clearcoatNormalMap?r=n.clearcoatNormalMap:n.clearcoatRoughnessMap&&(r=n.clearcoatRoughnessMap),void 0!==r&&(r.isWebGLRenderTarget&&(r=r.texture),!0===r.matrixAutoUpdate&&r.updateMatrix(),e.uvTransform.value.copy(r.matrix)),n.aoMap?s=n.aoMap:n.lightMap&&(s=n.lightMap),void 0!==s&&(s.isWebGLRenderTarget&&(s=s.texture),!0===s.matrixAutoUpdate&&s.updateMatrix(),e.uv2Transform.value.copy(s.matrix))}function n(e,n){e.roughness.value=n.roughness,e.metalness.value=n.metalness,n.roughnessMap&&(e.roughnessMap.value=n.roughnessMap),n.metalnessMap&&(e.metalnessMap.value=n.metalnessMap),n.emissiveMap&&(e.emissiveMap.value=n.emissiveMap),n.bumpMap&&(e.bumpMap.value=n.bumpMap,e.bumpScale.value=n.bumpScale,1===n.side&&(e.bumpScale.value*=-1)),n.normalMap&&(e.normalMap.value=n.normalMap,e.normalScale.value.copy(n.normalScale),1===n.side&&e.normalScale.value.negate()),n.displacementMap&&(e.displacementMap.value=n.displacementMap,e.displacementScale.value=n.displacementScale,e.displacementBias.value=n.displacementBias);t.get(n).envMap&&(e.envMapIntensity.value=n.envMapIntensity)}return{refreshFogUniforms:function(t,e){t.fogColor.value.copy(e.color),e.isFog?(t.fogNear.value=e.near,t.fogFar.value=e.far):e.isFogExp2&&(t.fogDensity.value=e.density)},refreshMaterialUniforms:function(t,i,r,s){i.isMeshBasicMaterial?e(t,i):i.isMeshLambertMaterial?(e(t,i),function(t,e){e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap)}(t,i)):i.isMeshToonMaterial?(e(t,i),function(t,e){e.gradientMap&&(t.gradientMap.value=e.gradientMap);e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshPhongMaterial?(e(t,i),function(t,e){t.specular.value.copy(e.specular),t.shininess.value=Math.max(e.shininess,1e-4),e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshStandardMaterial?(e(t,i),i.isMeshPhysicalMaterial?function(t,e){n(t,e),t.reflectivity.value=e.reflectivity,t.clearcoat.value=e.clearcoat,t.clearcoatRoughness.value=e.clearcoatRoughness,e.sheen&&t.sheen.value.copy(e.sheen);e.clearcoatMap&&(t.clearcoatMap.value=e.clearcoatMap);e.clearcoatRoughnessMap&&(t.clearcoatRoughnessMap.value=e.clearcoatRoughnessMap);e.clearcoatNormalMap&&(t.clearcoatNormalScale.value.copy(e.clearcoatNormalScale),t.clearcoatNormalMap.value=e.clearcoatNormalMap,1===e.side&&t.clearcoatNormalScale.value.negate());t.transmission.value=e.transmission,e.transmissionMap&&(t.transmissionMap.value=e.transmissionMap)}(t,i):n(t,i)):i.isMeshMatcapMaterial?(e(t,i),function(t,e){e.matcap&&(t.matcap.value=e.matcap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshDepthMaterial?(e(t,i),function(t,e){e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshDistanceMaterial?(e(t,i),function(t,e){e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias);t.referencePosition.value.copy(e.referencePosition),t.nearDistance.value=e.nearDistance,t.farDistance.value=e.farDistance}(t,i)):i.isMeshNormalMaterial?(e(t,i),function(t,e){e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isLineBasicMaterial?(function(t,e){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity}(t,i),i.isLineDashedMaterial&&function(t,e){t.dashSize.value=e.dashSize,t.totalSize.value=e.dashSize+e.gapSize,t.scale.value=e.scale}(t,i)):i.isPointsMaterial?function(t,e,n,i){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity,t.size.value=e.size*n,t.scale.value=.5*i,e.map&&(t.map.value=e.map);e.alphaMap&&(t.alphaMap.value=e.alphaMap);let r;e.map?r=e.map:e.alphaMap&&(r=e.alphaMap);void 0!==r&&(!0===r.matrixAutoUpdate&&r.updateMatrix(),t.uvTransform.value.copy(r.matrix))}(t,i,r,s):i.isSpriteMaterial?function(t,e){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity,t.rotation.value=e.rotation,e.map&&(t.map.value=e.map);e.alphaMap&&(t.alphaMap.value=e.alphaMap);let n;e.map?n=e.map:e.alphaMap&&(n=e.alphaMap);void 0!==n&&(!0===n.matrixAutoUpdate&&n.updateMatrix(),t.uvTransform.value.copy(n.matrix))}(t,i):i.isShadowMaterial?(t.color.value.copy(i.color),t.opacity.value=i.opacity):i.isShaderMaterial&&(i.uniformsNeedUpdate=!1)}}}function ws(t){const e=void 0!==(t=t||{}).canvas?t.canvas:function(){const t=document.createElementNS("http://www.w3.org/1999/xhtml","canvas");return t.style.display="block",t}(),n=void 0!==t.context?t.context:null,i=void 0!==t.alpha&&t.alpha,r=void 0===t.depth||t.depth,s=void 0===t.stencil||t.stencil,a=void 0!==t.antialias&&t.antialias,o=void 0===t.premultipliedAlpha||t.premultipliedAlpha,l=void 0!==t.preserveDrawingBuffer&&t.preserveDrawingBuffer,c=void 0!==t.powerPreference?t.powerPreference:"default",h=void 0!==t.failIfMajorPerformanceCaveat&&t.failIfMajorPerformanceCaveat;let u=null,d=null;const p=[],m=[];this.domElement=e,this.debug={checkShaderErrors:!0},this.autoClear=!0,this.autoClearColor=!0,this.autoClearDepth=!0,this.autoClearStencil=!0,this.sortObjects=!0,this.clippingPlanes=[],this.localClippingEnabled=!1,this.gammaFactor=2,this.outputEncoding=X,this.physicallyCorrectLights=!1,this.toneMapping=0,this.toneMappingExposure=1;const f=this;let g=!1,v=0,y=0,_=null,w=-1,S=null;const T=new St,A=new St;let L=null,R=e.width,C=e.height,P=1,D=null,I=null;const N=new St(0,0,R,C),B=new St(0,0,R,C);let z=!1;const F=new ai;let O=!1,H=!1;const G=new se,U=new Lt,k={background:null,fog:null,environment:null,overrideMaterial:null,isScene:!0};function V(){return null===_?P:1}let W,j,q,Y,Z,J,Q,K,$,tt,et,nt,it,rt,st,at,ot,lt,ct,ht,ut,dt,pt=n;function ft(t,n){for(let i=0;i<t.length;i++){const r=t[i],s=e.getContext(r,n);if(null!==s)return s}return null}try{const t={alpha:i,depth:r,stencil:s,antialias:a,premultipliedAlpha:o,preserveDrawingBuffer:l,powerPreference:c,failIfMajorPerformanceCaveat:h};if(e.addEventListener("webglcontextlost",xt,!1),e.addEventListener("webglcontextrestored",_t,!1),null===pt){const e=["webgl2","webgl","experimental-webgl"];if(!0===f.isWebGL1Renderer&&e.shift(),pt=ft(e,t),null===pt)throw ft(e)?new Error("Error creating WebGL context with your selected attributes."):new Error("Error creating WebGL context.")}void 0===pt.getShaderPrecisionFormat&&(pt.getShaderPrecisionFormat=function(){return{rangeMin:1,rangeMax:1,precision:1}})}catch(t){throw console.error("THREE.WebGLRenderer: "+t.message),t}function gt(){W=new xi(pt),j=new gi(pt,W,t),W.init(j),ut=new ms(pt,W,j),q=new ds(pt,W,j),Y=new bi(pt),Z=new Kr,J=new ps(pt,W,q,Z,j,ut,Y),Q=new yi(f),K=new li(pt,j),dt=new mi(pt,W,K,j),$=new _i(pt,K,Y,dt),tt=new Ei(pt,$,K,Y),lt=new Ti(pt),st=new vi(Z),et=new Qr(f,Q,W,j,dt,st),nt=new _s(Z),it=new ns(Z),rt=new ls(W,j),ot=new pi(f,Q,q,tt,o),at=new us(f,tt,j),ct=new fi(pt,W,Y,j),ht=new wi(pt,W,Y,j),Y.programs=et.programs,f.capabilities=j,f.extensions=W,f.properties=Z,f.renderLists=it,f.shadowMap=at,f.state=q,f.info=Y}gt();const yt=new xs(f,pt);function xt(t){t.preventDefault(),console.log("THREE.WebGLRenderer: Context Lost."),g=!0}function _t(){console.log("THREE.WebGLRenderer: Context Restored."),g=!1;const t=Y.autoReset,e=at.enabled,n=at.autoUpdate,i=at.needsUpdate,r=at.type;gt(),Y.autoReset=t,at.enabled=e,at.autoUpdate=n,at.needsUpdate=i,at.type=r}function wt(t){const e=t.target;e.removeEventListener("dispose",wt),function(t){(function(t){const e=Z.get(t).programs;void 0!==e&&e.forEach((function(t){et.releaseProgram(t)}))})(t),Z.remove(t)}(e)}this.xr=yt,this.getContext=function(){return pt},this.getContextAttributes=function(){return pt.getContextAttributes()},this.forceContextLoss=function(){const t=W.get("WEBGL_lose_context");t&&t.loseContext()},this.forceContextRestore=function(){const t=W.get("WEBGL_lose_context");t&&t.restoreContext()},this.getPixelRatio=function(){return P},this.setPixelRatio=function(t){void 0!==t&&(P=t,this.setSize(R,C,!1))},this.getSize=function(t){return void 0===t&&(console.warn("WebGLRenderer: .getsize() now requires a Vector2 as an argument"),t=new vt),t.set(R,C)},this.setSize=function(t,n,i){yt.isPresenting?console.warn("THREE.WebGLRenderer: Can't change size while VR device is presenting."):(R=t,C=n,e.width=Math.floor(t*P),e.height=Math.floor(n*P),!1!==i&&(e.style.width=t+"px",e.style.height=n+"px"),this.setViewport(0,0,t,n))},this.getDrawingBufferSize=function(t){return void 0===t&&(console.warn("WebGLRenderer: .getdrawingBufferSize() now requires a Vector2 as an argument"),t=new vt),t.set(R*P,C*P).floor()},this.setDrawingBufferSize=function(t,n,i){R=t,C=n,P=i,e.width=Math.floor(t*i),e.height=Math.floor(n*i),this.setViewport(0,0,t,n)},this.getCurrentViewport=function(t){return void 0===t&&(console.warn("WebGLRenderer: .getCurrentViewport() now requires a Vector4 as an argument"),t=new St),t.copy(T)},this.getViewport=function(t){return t.copy(N)},this.setViewport=function(t,e,n,i){t.isVector4?N.set(t.x,t.y,t.z,t.w):N.set(t,e,n,i),q.viewport(T.copy(N).multiplyScalar(P).floor())},this.getScissor=function(t){return t.copy(B)},this.setScissor=function(t,e,n,i){t.isVector4?B.set(t.x,t.y,t.z,t.w):B.set(t,e,n,i),q.scissor(A.copy(B).multiplyScalar(P).floor())},this.getScissorTest=function(){return z},this.setScissorTest=function(t){q.setScissorTest(z=t)},this.setOpaqueSort=function(t){D=t},this.setTransparentSort=function(t){I=t},this.getClearColor=function(t){return void 0===t&&(console.warn("WebGLRenderer: .getClearColor() now requires a Color as an argument"),t=new tn),t.copy(ot.getClearColor())},this.setClearColor=function(){ot.setClearColor.apply(ot,arguments)},this.getClearAlpha=function(){return ot.getClearAlpha()},this.setClearAlpha=function(){ot.setClearAlpha.apply(ot,arguments)},this.clear=function(t,e,n){let i=0;(void 0===t||t)&&(i|=16384),(void 0===e||e)&&(i|=256),(void 0===n||n)&&(i|=1024),pt.clear(i)},this.clearColor=function(){this.clear(!0,!1,!1)},this.clearDepth=function(){this.clear(!1,!0,!1)},this.clearStencil=function(){this.clear(!1,!1,!0)},this.dispose=function(){e.removeEventListener("webglcontextlost",xt,!1),e.removeEventListener("webglcontextrestored",_t,!1),it.dispose(),rt.dispose(),Z.dispose(),Q.dispose(),tt.dispose(),dt.dispose(),yt.dispose(),yt.removeEventListener("sessionstart",Mt),yt.removeEventListener("sessionend",Tt),Et.stop()},this.renderBufferImmediate=function(t,e){dt.initAttributes();const n=Z.get(t);t.hasPositions&&!n.position&&(n.position=pt.createBuffer()),t.hasNormals&&!n.normal&&(n.normal=pt.createBuffer()),t.hasUvs&&!n.uv&&(n.uv=pt.createBuffer()),t.hasColors&&!n.color&&(n.color=pt.createBuffer());const i=e.getAttributes();t.hasPositions&&(pt.bindBuffer(34962,n.position),pt.bufferData(34962,t.positionArray,35048),dt.enableAttribute(i.position),pt.vertexAttribPointer(i.position,3,5126,!1,0,0)),t.hasNormals&&(pt.bindBuffer(34962,n.normal),pt.bufferData(34962,t.normalArray,35048),dt.enableAttribute(i.normal),pt.vertexAttribPointer(i.normal,3,5126,!1,0,0)),t.hasUvs&&(pt.bindBuffer(34962,n.uv),pt.bufferData(34962,t.uvArray,35048),dt.enableAttribute(i.uv),pt.vertexAttribPointer(i.uv,2,5126,!1,0,0)),t.hasColors&&(pt.bindBuffer(34962,n.color),pt.bufferData(34962,t.colorArray,35048),dt.enableAttribute(i.color),pt.vertexAttribPointer(i.color,3,5126,!1,0,0)),dt.disableUnusedAttributes(),pt.drawArrays(4,0,t.count),t.count=0},this.renderBufferDirect=function(t,e,n,i,r,s){null===e&&(e=k);const a=r.isMesh&&r.matrixWorld.determinant()<0,o=It(t,e,i,r);q.setMaterial(i,a);let l=n.index;const c=n.attributes.position;if(null===l){if(void 0===c||0===c.count)return}else if(0===l.count)return;let h,u=1;!0===i.wireframe&&(l=$.getWireframeAttribute(n),u=2),(i.morphTargets||i.morphNormals)&&lt.update(r,n,i,o),dt.setup(r,i,o,n,l);let d=ct;null!==l&&(h=K.get(l),d=ht,d.setIndex(h));const p=null!==l?l.count:c.count,m=n.drawRange.start*u,f=n.drawRange.count*u,g=null!==s?s.start*u:0,v=null!==s?s.count*u:1/0,y=Math.max(m,g),x=Math.min(p,m+f,g+v)-1,_=Math.max(0,x-y+1);if(0!==_){if(r.isMesh)!0===i.wireframe?(q.setLineWidth(i.wireframeLinewidth*V()),d.setMode(1)):d.setMode(4);else if(r.isLine){let t=i.linewidth;void 0===t&&(t=1),q.setLineWidth(t*V()),r.isLineSegments?d.setMode(1):r.isLineLoop?d.setMode(2):d.setMode(3)}else r.isPoints?d.setMode(0):r.isSprite&&d.setMode(4);if(r.isInstancedMesh)d.renderInstances(y,_,r.count);else if(n.isInstancedBufferGeometry){const t=Math.min(n.instanceCount,n._maxInstanceCount);d.renderInstances(y,_,t)}else d.render(y,_)}},this.compile=function(t,e){d=rt.get(t),d.init(),t.traverseVisible((function(t){t.isLight&&t.layers.test(e.layers)&&(d.pushLight(t),t.castShadow&&d.pushShadow(t))})),d.setupLights(),t.traverse((function(e){const n=e.material;if(n)if(Array.isArray(n))for(let i=0;i<n.length;i++){Pt(n[i],t,e)}else Pt(n,t,e)}))};let bt=null;function Mt(){Et.stop()}function Tt(){Et.start()}const Et=new oi;function At(t,e,n,i){if(!1===t.visible)return;if(t.layers.test(e.layers))if(t.isGroup)n=t.renderOrder;else if(t.isLOD)!0===t.autoUpdate&&t.update(e);else if(t.isLight)d.pushLight(t),t.castShadow&&d.pushShadow(t);else if(t.isSprite){if(!t.frustumCulled||F.intersectsSprite(t)){i&&U.setFromMatrixPosition(t.matrixWorld).applyMatrix4(G);const e=tt.update(t),r=t.material;r.visible&&u.push(t,e,r,n,U.z,null)}}else if(t.isImmediateRenderObject)i&&U.setFromMatrixPosition(t.matrixWorld).applyMatrix4(G),u.push(t,null,t.material,n,U.z,null);else if((t.isMesh||t.isLine||t.isPoints)&&(t.isSkinnedMesh&&t.skeleton.frame!==Y.render.frame&&(t.skeleton.update(),t.skeleton.frame=Y.render.frame),!t.frustumCulled||F.intersectsObject(t))){i&&U.setFromMatrixPosition(t.matrixWorld).applyMatrix4(G);const e=tt.update(t),r=t.material;if(Array.isArray(r)){const i=e.groups;for(let s=0,a=i.length;s<a;s++){const a=i[s],o=r[a.materialIndex];o&&o.visible&&u.push(t,e,o,n,U.z,a)}}else r.visible&&u.push(t,e,r,n,U.z,null)}const r=t.children;for(let t=0,s=r.length;t<s;t++)At(r[t],e,n,i)}function Rt(t,e,n){const i=!0===e.isScene?e.overrideMaterial:null;for(let r=0,s=t.length;r<s;r++){const s=t[r],a=s.object,o=s.geometry,l=null===i?s.material:i,c=s.group;if(n.isArrayCamera){const t=n.cameras;for(let n=0,i=t.length;n<i;n++){const i=t[n];a.layers.test(i.layers)&&(q.viewport(T.copy(i.viewport)),d.setupLightsView(i),Ct(a,e,i,o,l,c))}}else Ct(a,e,n,o,l,c)}}function Ct(t,e,n,i,r,s){if(t.onBeforeRender(f,e,n,i,r,s),t.modelViewMatrix.multiplyMatrices(n.matrixWorldInverse,t.matrixWorld),t.normalMatrix.getNormalMatrix(t.modelViewMatrix),t.isImmediateRenderObject){const i=It(n,e,r,t);q.setMaterial(r),dt.reset(),function(t,e){t.render((function(t){f.renderBufferImmediate(t,e)}))}(t,i)}else f.renderBufferDirect(n,e,i,r,t,s);t.onAfterRender(f,e,n,i,r,s)}function Pt(t,e,n){!0!==e.isScene&&(e=k);const i=Z.get(t),r=d.state.lights,s=d.state.shadowsArray,a=r.state.version,o=et.getParameters(t,r.state,s,e,n),l=et.getProgramCacheKey(o);let c=i.programs;i.environment=t.isMeshStandardMaterial?e.environment:null,i.fog=e.fog,i.envMap=Q.get(t.envMap||i.environment),void 0===c&&(t.addEventListener("dispose",wt),c=new Map,i.programs=c);let h=c.get(l);if(void 0!==h){if(i.currentProgram===h&&i.lightsStateVersion===a)return Dt(t,o),h}else o.uniforms=et.getUniforms(t),t.onBuild(o,f),t.onBeforeCompile(o,f),h=et.acquireProgram(o,l),c.set(l,h),i.uniforms=o.uniforms;const u=i.uniforms;(t.isShaderMaterial||t.isRawShaderMaterial)&&!0!==t.clipping||(u.clippingPlanes=st.uniform),Dt(t,o),i.needsLights=function(t){return t.isMeshLambertMaterial||t.isMeshToonMaterial||t.isMeshPhongMaterial||t.isMeshStandardMaterial||t.isShadowMaterial||t.isShaderMaterial&&!0===t.lights}(t),i.lightsStateVersion=a,i.needsLights&&(u.ambientLightColor.value=r.state.ambient,u.lightProbe.value=r.state.probe,u.directionalLights.value=r.state.directional,u.directionalLightShadows.value=r.state.directionalShadow,u.spotLights.value=r.state.spot,u.spotLightShadows.value=r.state.spotShadow,u.rectAreaLights.value=r.state.rectArea,u.ltc_1.value=r.state.rectAreaLTC1,u.ltc_2.value=r.state.rectAreaLTC2,u.pointLights.value=r.state.point,u.pointLightShadows.value=r.state.pointShadow,u.hemisphereLights.value=r.state.hemi,u.directionalShadowMap.value=r.state.directionalShadowMap,u.directionalShadowMatrix.value=r.state.directionalShadowMatrix,u.spotShadowMap.value=r.state.spotShadowMap,u.spotShadowMatrix.value=r.state.spotShadowMatrix,u.pointShadowMap.value=r.state.pointShadowMap,u.pointShadowMatrix.value=r.state.pointShadowMatrix);const p=h.getUniforms(),m=Cr.seqWithValue(p.seq,u);return i.currentProgram=h,i.uniformsList=m,h}function Dt(t,e){const n=Z.get(t);n.outputEncoding=e.outputEncoding,n.instancing=e.instancing,n.numClippingPlanes=e.numClippingPlanes,n.numIntersection=e.numClipIntersection,n.vertexAlphas=e.vertexAlphas}function It(t,e,n,i){!0!==e.isScene&&(e=k),J.resetTextureUnits();const r=e.fog,s=n.isMeshStandardMaterial?e.environment:null,a=null===_?f.outputEncoding:_.texture.encoding,o=Q.get(n.envMap||s),l=!0===n.vertexColors&&i.geometry&&i.geometry.attributes.color&&4===i.geometry.attributes.color.itemSize,c=Z.get(n),h=d.state.lights;if(!0===O&&(!0===H||t!==S)){const e=t===S&&n.id===w;st.setState(n,t,e)}let u=!1;n.version===c.__version?c.needsLights&&c.lightsStateVersion!==h.state.version||c.outputEncoding!==a||i.isInstancedMesh&&!1===c.instancing?u=!0:i.isInstancedMesh||!0!==c.instancing?c.envMap!==o||n.fog&&c.fog!==r?u=!0:void 0===c.numClippingPlanes||c.numClippingPlanes===st.numPlanes&&c.numIntersection===st.numIntersection?c.vertexAlphas!==l&&(u=!0):u=!0:u=!0:(u=!0,c.__version=n.version);let p=c.currentProgram;!0===u&&(p=Pt(n,e,i));let m=!1,g=!1,v=!1;const y=p.getUniforms(),x=c.uniforms;if(q.useProgram(p.program)&&(m=!0,g=!0,v=!0),n.id!==w&&(w=n.id,g=!0),m||S!==t){if(y.setValue(pt,"projectionMatrix",t.projectionMatrix),j.logarithmicDepthBuffer&&y.setValue(pt,"logDepthBufFC",2/(Math.log(t.far+1)/Math.LN2)),S!==t&&(S=t,g=!0,v=!0),n.isShaderMaterial||n.isMeshPhongMaterial||n.isMeshToonMaterial||n.isMeshStandardMaterial||n.envMap){const e=y.map.cameraPosition;void 0!==e&&e.setValue(pt,U.setFromMatrixPosition(t.matrixWorld))}(n.isMeshPhongMaterial||n.isMeshToonMaterial||n.isMeshLambertMaterial||n.isMeshBasicMaterial||n.isMeshStandardMaterial||n.isShaderMaterial)&&y.setValue(pt,"isOrthographic",!0===t.isOrthographicCamera),(n.isMeshPhongMaterial||n.isMeshToonMaterial||n.isMeshLambertMaterial||n.isMeshBasicMaterial||n.isMeshStandardMaterial||n.isShaderMaterial||n.isShadowMaterial||n.skinning)&&y.setValue(pt,"viewMatrix",t.matrixWorldInverse)}if(n.skinning){y.setOptional(pt,i,"bindMatrix"),y.setOptional(pt,i,"bindMatrixInverse");const t=i.skeleton;if(t){const e=t.bones;if(j.floatVertexTextures){if(null===t.boneTexture){let n=Math.sqrt(4*e.length);n=mt(n),n=Math.max(n,4);const i=new Float32Array(n*n*4);i.set(t.boneMatrices);const r=new ii(i,n,n,E,b);t.boneMatrices=i,t.boneTexture=r,t.boneTextureSize=n}y.setValue(pt,"boneTexture",t.boneTexture,J),y.setValue(pt,"boneTextureSize",t.boneTextureSize)}else y.setOptional(pt,t,"boneMatrices")}}var M,T;return(g||c.receiveShadow!==i.receiveShadow)&&(c.receiveShadow=i.receiveShadow,y.setValue(pt,"receiveShadow",i.receiveShadow)),g&&(y.setValue(pt,"toneMappingExposure",f.toneMappingExposure),c.needsLights&&(T=v,(M=x).ambientLightColor.needsUpdate=T,M.lightProbe.needsUpdate=T,M.directionalLights.needsUpdate=T,M.directionalLightShadows.needsUpdate=T,M.pointLights.needsUpdate=T,M.pointLightShadows.needsUpdate=T,M.spotLights.needsUpdate=T,M.spotLightShadows.needsUpdate=T,M.rectAreaLights.needsUpdate=T,M.hemisphereLights.needsUpdate=T),r&&n.fog&&nt.refreshFogUniforms(x,r),nt.refreshMaterialUniforms(x,n,P,C),Cr.upload(pt,c.uniformsList,x,J)),n.isShaderMaterial&&!0===n.uniformsNeedUpdate&&(Cr.upload(pt,c.uniformsList,x,J),n.uniformsNeedUpdate=!1),n.isSpriteMaterial&&y.setValue(pt,"center",i.center),y.setValue(pt,"modelViewMatrix",i.modelViewMatrix),y.setValue(pt,"normalMatrix",i.normalMatrix),y.setValue(pt,"modelMatrix",i.matrixWorld),p}Et.setAnimationLoop((function(t){bt&&bt(t)})),"undefined"!=typeof window&&Et.setContext(window),this.setAnimationLoop=function(t){bt=t,yt.setAnimationLoop(t),null===t?Et.stop():Et.start()},yt.addEventListener("sessionstart",Mt),yt.addEventListener("sessionend",Tt),this.render=function(t,e){let n,i;if(void 0!==arguments[2]&&(console.warn("THREE.WebGLRenderer.render(): the renderTarget argument has been removed. Use .setRenderTarget() instead."),n=arguments[2]),void 0!==arguments[3]&&(console.warn("THREE.WebGLRenderer.render(): the forceClear argument has been removed. Use .clear() instead."),i=arguments[3]),void 0!==e&&!0!==e.isCamera)return void console.error("THREE.WebGLRenderer.render: camera is not an instance of THREE.Camera.");if(!0===g)return;!0===t.autoUpdate&&t.updateMatrixWorld(),null===e.parent&&e.updateMatrixWorld(),!0===yt.enabled&&!0===yt.isPresenting&&(e=yt.getCamera(e)),!0===t.isScene&&t.onBeforeRender(f,t,e,n||_),d=rt.get(t,m.length),d.init(),m.push(d),G.multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse),F.setFromProjectionMatrix(G),H=this.localClippingEnabled,O=st.init(this.clippingPlanes,H,e),u=it.get(t,p.length),u.init(),p.push(u),At(t,e,0,f.sortObjects),u.finish(),!0===f.sortObjects&&u.sort(D,I),!0===O&&st.beginShadows();const r=d.state.shadowsArray;at.render(r,t,e),d.setupLights(),d.setupLightsView(e),!0===O&&st.endShadows(),!0===this.info.autoReset&&this.info.reset(),void 0!==n&&this.setRenderTarget(n),ot.render(u,t,e,i);const s=u.opaque,a=u.transparent;s.length>0&&Rt(s,t,e),a.length>0&&Rt(a,t,e),null!==_&&(J.updateRenderTargetMipmap(_),J.updateMultisampleRenderTarget(_)),!0===t.isScene&&t.onAfterRender(f,t,e),q.buffers.depth.setTest(!0),q.buffers.depth.setMask(!0),q.buffers.color.setMask(!0),q.setPolygonOffset(!1),dt.resetDefaultState(),w=-1,S=null,m.pop(),d=m.length>0?m[m.length-1]:null,p.pop(),u=p.length>0?p[p.length-1]:null},this.getActiveCubeFace=function(){return v},this.getActiveMipmapLevel=function(){return y},this.getRenderTarget=function(){return _},this.setRenderTarget=function(t,e=0,n=0){_=t,v=e,y=n,t&&void 0===Z.get(t).__webglFramebuffer&&J.setupRenderTarget(t);let i=null,r=!1,s=!1;if(t){const n=t.texture;(n.isDataTexture3D||n.isDataTexture2DArray)&&(s=!0);const a=Z.get(t).__webglFramebuffer;t.isWebGLCubeRenderTarget?(i=a[e],r=!0):i=t.isWebGLMultisampleRenderTarget?Z.get(t).__webglMultisampledFramebuffer:a,T.copy(t.viewport),A.copy(t.scissor),L=t.scissorTest}else T.copy(N).multiplyScalar(P).floor(),A.copy(B).multiplyScalar(P).floor(),L=z;if(q.bindFramebuffer(36160,i),q.viewport(T),q.scissor(A),q.setScissorTest(L),r){const i=Z.get(t.texture);pt.framebufferTexture2D(36160,36064,34069+e,i.__webglTexture,n)}else if(s){const i=Z.get(t.texture),r=e||0;pt.framebufferTextureLayer(36160,36064,i.__webglTexture,n||0,r)}},this.readRenderTargetPixels=function(t,e,n,i,r,s,a){if(!t||!t.isWebGLRenderTarget)return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not THREE.WebGLRenderTarget.");let o=Z.get(t).__webglFramebuffer;if(t.isWebGLCubeRenderTarget&&void 0!==a&&(o=o[a]),o){q.bindFramebuffer(36160,o);try{const a=t.texture,o=a.format,l=a.type;if(o!==E&&ut.convert(o)!==pt.getParameter(35739))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in RGBA or implementation defined format.");const c=l===M&&(W.has("EXT_color_buffer_half_float")||j.isWebGL2&&W.has("EXT_color_buffer_float"));if(!(l===x||ut.convert(l)===pt.getParameter(35738)||l===b&&(j.isWebGL2||W.has("OES_texture_float")||W.has("WEBGL_color_buffer_float"))||c))return void console.error("THREE.WebGLRenderer.readRenderTargetPixels: renderTarget is not in UnsignedByteType or implementation defined type.");36053===pt.checkFramebufferStatus(36160)?e>=0&&e<=t.width-i&&n>=0&&n<=t.height-r&&pt.readPixels(e,n,i,r,ut.convert(o),ut.convert(l),s):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.")}finally{const t=null!==_?Z.get(_).__webglFramebuffer:null;q.bindFramebuffer(36160,t)}}},this.copyFramebufferToTexture=function(t,e,n=0){const i=Math.pow(2,-n),r=Math.floor(e.image.width*i),s=Math.floor(e.image.height*i),a=ut.convert(e.format);J.setTexture2D(e,0),pt.copyTexImage2D(3553,n,a,t.x,t.y,r,s,0),q.unbindTexture()},this.copyTextureToTexture=function(t,e,n,i=0){const r=e.image.width,s=e.image.height,a=ut.convert(n.format),o=ut.convert(n.type);J.setTexture2D(n,0),pt.pixelStorei(37440,n.flipY),pt.pixelStorei(37441,n.premultiplyAlpha),pt.pixelStorei(3317,n.unpackAlignment),e.isDataTexture?pt.texSubImage2D(3553,i,t.x,t.y,r,s,a,o,e.image.data):e.isCompressedTexture?pt.compressedTexSubImage2D(3553,i,t.x,t.y,e.mipmaps[0].width,e.mipmaps[0].height,a,e.mipmaps[0].data):pt.texSubImage2D(3553,i,t.x,t.y,a,o,e.image),0===i&&n.generateMipmaps&&pt.generateMipmap(3553),q.unbindTexture()},this.copyTextureToTexture3D=function(t,e,n,i,r=0){if(f.isWebGL1Renderer)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.");const{width:s,height:a,data:o}=n.image,l=ut.convert(i.format),c=ut.convert(i.type);let h;if(i.isDataTexture3D)J.setTexture3D(i,0),h=32879;else{if(!i.isDataTexture2DArray)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.");J.setTexture2DArray(i,0),h=35866}pt.pixelStorei(37440,i.flipY),pt.pixelStorei(37441,i.premultiplyAlpha),pt.pixelStorei(3317,i.unpackAlignment);const u=pt.getParameter(3314),d=pt.getParameter(32878),p=pt.getParameter(3316),m=pt.getParameter(3315),g=pt.getParameter(32877);pt.pixelStorei(3314,s),pt.pixelStorei(32878,a),pt.pixelStorei(3316,t.min.x),pt.pixelStorei(3315,t.min.y),pt.pixelStorei(32877,t.min.z),pt.texSubImage3D(h,r,e.x,e.y,e.z,t.max.x-t.min.x+1,t.max.y-t.min.y+1,t.max.z-t.min.z+1,l,c,o),pt.pixelStorei(3314,u),pt.pixelStorei(32878,d),pt.pixelStorei(3316,p),pt.pixelStorei(3315,m),pt.pixelStorei(32877,g),0===r&&i.generateMipmaps&&pt.generateMipmap(h),q.unbindTexture()},this.initTexture=function(t){J.setTexture2D(t,0),q.unbindTexture()},this.resetState=function(){v=0,y=0,_=null,q.reset(),dt.reset()},"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}class bs extends ws{}bs.prototype.isWebGL1Renderer=!0;class Ms{constructor(t,e=25e-5){this.name="",this.color=new tn(t),this.density=e}clone(){return new Ms(this.color,this.density)}toJSON(){return{type:"FogExp2",color:this.color.getHex(),density:this.density}}}Ms.prototype.isFogExp2=!0;class Ss{constructor(t,e=1,n=1e3){this.name="",this.color=new tn(t),this.near=e,this.far=n}clone(){return new Ss(this.color,this.near,this.far)}toJSON(){return{type:"Fog",color:this.color.getHex(),near:this.near,far:this.far}}}Ss.prototype.isFog=!0;class Ts extends Ce{constructor(){super(),this.type="Scene",this.background=null,this.environment=null,this.fog=null,this.overrideMaterial=null,this.autoUpdate=!0,"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}copy(t,e){return super.copy(t,e),null!==t.background&&(this.background=t.background.clone()),null!==t.environment&&(this.environment=t.environment.clone()),null!==t.fog&&(this.fog=t.fog.clone()),null!==t.overrideMaterial&&(this.overrideMaterial=t.overrideMaterial.clone()),this.autoUpdate=t.autoUpdate,this.matrixAutoUpdate=t.matrixAutoUpdate,this}toJSON(t){const e=super.toJSON(t);return null!==this.background&&(e.object.background=this.background.toJSON(t)),null!==this.environment&&(e.object.environment=this.environment.toJSON(t)),null!==this.fog&&(e.object.fog=this.fog.toJSON()),e}}Ts.prototype.isScene=!0;class Es{constructor(t,e){this.array=t,this.stride=e,this.count=void 0!==t?t.length/e:0,this.usage=et,this.updateRange={offset:0,count:-1},this.version=0,this.uuid=ct(),this.onUploadCallback=function(){}}set needsUpdate(t){!0===t&&this.version++}setUsage(t){return this.usage=t,this}copy(t){return this.array=new t.array.constructor(t.array),this.count=t.count,this.stride=t.stride,this.usage=t.usage,this}copyAt(t,e,n){t*=this.stride,n*=e.stride;for(let i=0,r=this.stride;i<r;i++)this.array[t+i]=e.array[n+i];return this}set(t,e=0){return this.array.set(t,e),this}clone(t){void 0===t.arrayBuffers&&(t.arrayBuffers={}),void 0===this.array.buffer._uuid&&(this.array.buffer._uuid=ct()),void 0===t.arrayBuffers[this.array.buffer._uuid]&&(t.arrayBuffers[this.array.buffer._uuid]=this.array.slice(0).buffer);const e=new this.array.constructor(t.arrayBuffers[this.array.buffer._uuid]),n=new Es(e,this.stride);return n.setUsage(this.usage),n}onUpload(t){return this.onUploadCallback=t,this}toJSON(t){return void 0===t.arrayBuffers&&(t.arrayBuffers={}),void 0===this.array.buffer._uuid&&(this.array.buffer._uuid=ct()),void 0===t.arrayBuffers[this.array.buffer._uuid]&&(t.arrayBuffers[this.array.buffer._uuid]=Array.prototype.slice.call(new Uint32Array(this.array.buffer))),{uuid:this.uuid,buffer:this.array.buffer._uuid,type:this.array.constructor.name,stride:this.stride}}}Es.prototype.isInterleavedBuffer=!0;const As=new Lt;class Ls{constructor(t,e,n,i){this.name="",this.data=t,this.itemSize=e,this.offset=n,this.normalized=!0===i}get count(){return this.data.count}get array(){return this.data.array}set needsUpdate(t){this.data.needsUpdate=t}applyMatrix4(t){for(let e=0,n=this.data.count;e<n;e++)As.x=this.getX(e),As.y=this.getY(e),As.z=this.getZ(e),As.applyMatrix4(t),this.setXYZ(e,As.x,As.y,As.z);return this}applyNormalMatrix(t){for(let e=0,n=this.count;e<n;e++)As.x=this.getX(e),As.y=this.getY(e),As.z=this.getZ(e),As.applyNormalMatrix(t),this.setXYZ(e,As.x,As.y,As.z);return this}transformDirection(t){for(let e=0,n=this.count;e<n;e++)As.x=this.getX(e),As.y=this.getY(e),As.z=this.getZ(e),As.transformDirection(t),this.setXYZ(e,As.x,As.y,As.z);return this}setX(t,e){return this.data.array[t*this.data.stride+this.offset]=e,this}setY(t,e){return this.data.array[t*this.data.stride+this.offset+1]=e,this}setZ(t,e){return this.data.array[t*this.data.stride+this.offset+2]=e,this}setW(t,e){return this.data.array[t*this.data.stride+this.offset+3]=e,this}getX(t){return this.data.array[t*this.data.stride+this.offset]}getY(t){return this.data.array[t*this.data.stride+this.offset+1]}getZ(t){return this.data.array[t*this.data.stride+this.offset+2]}getW(t){return this.data.array[t*this.data.stride+this.offset+3]}setXY(t,e,n){return t=t*this.data.stride+this.offset,this.data.array[t+0]=e,this.data.array[t+1]=n,this}setXYZ(t,e,n,i){return t=t*this.data.stride+this.offset,this.data.array[t+0]=e,this.data.array[t+1]=n,this.data.array[t+2]=i,this}setXYZW(t,e,n,i,r){return t=t*this.data.stride+this.offset,this.data.array[t+0]=e,this.data.array[t+1]=n,this.data.array[t+2]=i,this.data.array[t+3]=r,this}clone(t){if(void 0===t){console.log("THREE.InterleavedBufferAttribute.clone(): Cloning an interlaved buffer attribute will deinterleave buffer data.");const t=[];for(let e=0;e<this.count;e++){const n=e*this.data.stride+this.offset;for(let e=0;e<this.itemSize;e++)t.push(this.data.array[n+e])}return new sn(new this.array.constructor(t),this.itemSize,this.normalized)}return void 0===t.interleavedBuffers&&(t.interleavedBuffers={}),void 0===t.interleavedBuffers[this.data.uuid]&&(t.interleavedBuffers[this.data.uuid]=this.data.clone(t)),new Ls(t.interleavedBuffers[this.data.uuid],this.itemSize,this.offset,this.normalized)}toJSON(t){if(void 0===t){console.log("THREE.InterleavedBufferAttribute.toJSON(): Serializing an interlaved buffer attribute will deinterleave buffer data.");const t=[];for(let e=0;e<this.count;e++){const n=e*this.data.stride+this.offset;for(let e=0;e<this.itemSize;e++)t.push(this.data.array[n+e])}return{itemSize:this.itemSize,type:this.array.constructor.name,array:t,normalized:this.normalized}}return void 0===t.interleavedBuffers&&(t.interleavedBuffers={}),void 0===t.interleavedBuffers[this.data.uuid]&&(t.interleavedBuffers[this.data.uuid]=this.data.toJSON(t)),{isInterleavedBufferAttribute:!0,itemSize:this.itemSize,data:this.data.uuid,offset:this.offset,normalized:this.normalized}}}Ls.prototype.isInterleavedBufferAttribute=!0;class Rs extends Xe{constructor(t){super(),this.type="SpriteMaterial",this.color=new tn(16777215),this.map=null,this.alphaMap=null,this.rotation=0,this.sizeAttenuation=!0,this.transparent=!0,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.alphaMap=t.alphaMap,this.rotation=t.rotation,this.sizeAttenuation=t.sizeAttenuation,this}}let Cs;Rs.prototype.isSpriteMaterial=!0;const Ps=new Lt,Ds=new Lt,Is=new Lt,Ns=new vt,Bs=new vt,zs=new se,Fs=new Lt,Os=new Lt,Hs=new Lt,Gs=new vt,Us=new vt,ks=new vt;class Vs extends Ce{constructor(t){if(super(),this.type="Sprite",void 0===Cs){Cs=new En;const t=new Float32Array([-.5,-.5,0,0,0,.5,-.5,0,1,0,.5,.5,0,1,1,-.5,.5,0,0,1]),e=new Es(t,5);Cs.setIndex([0,1,2,0,2,3]),Cs.setAttribute("position",new Ls(e,3,0,!1)),Cs.setAttribute("uv",new Ls(e,2,3,!1))}this.geometry=Cs,this.material=void 0!==t?t:new Rs,this.center=new vt(.5,.5)}raycast(t,e){null===t.camera&&console.error('THREE.Sprite: "Raycaster.camera" needs to be set in order to raycast against sprites.'),Ds.setFromMatrixScale(this.matrixWorld),zs.copy(t.camera.matrixWorld),this.modelViewMatrix.multiplyMatrices(t.camera.matrixWorldInverse,this.matrixWorld),Is.setFromMatrixPosition(this.modelViewMatrix),t.camera.isPerspectiveCamera&&!1===this.material.sizeAttenuation&&Ds.multiplyScalar(-Is.z);const n=this.material.rotation;let i,r;0!==n&&(r=Math.cos(n),i=Math.sin(n));const s=this.center;Ws(Fs.set(-.5,-.5,0),Is,s,Ds,i,r),Ws(Os.set(.5,-.5,0),Is,s,Ds,i,r),Ws(Hs.set(.5,.5,0),Is,s,Ds,i,r),Gs.set(0,0),Us.set(1,0),ks.set(1,1);let a=t.ray.intersectTriangle(Fs,Os,Hs,!1,Ps);if(null===a&&(Ws(Os.set(-.5,.5,0),Is,s,Ds,i,r),Us.set(0,1),a=t.ray.intersectTriangle(Fs,Hs,Os,!1,Ps),null===a))return;const o=t.ray.origin.distanceTo(Ps);o<t.near||o>t.far||e.push({distance:o,point:Ps.clone(),uv:je.getUV(Ps,Fs,Os,Hs,Gs,Us,ks,new vt),face:null,object:this})}copy(t){return super.copy(t),void 0!==t.center&&this.center.copy(t.center),this.material=t.material,this}}function Ws(t,e,n,i,r,s){Ns.subVectors(t,n).addScalar(.5).multiply(i),void 0!==r?(Bs.x=s*Ns.x-r*Ns.y,Bs.y=r*Ns.x+s*Ns.y):Bs.copy(Ns),t.copy(e),t.x+=Bs.x,t.y+=Bs.y,t.applyMatrix4(zs)}Vs.prototype.isSprite=!0;const js=new Lt,qs=new Lt;class Xs extends Ce{constructor(){super(),this._currentLevel=0,this.type="LOD",Object.defineProperties(this,{levels:{enumerable:!0,value:[]},isLOD:{value:!0}}),this.autoUpdate=!0}copy(t){super.copy(t,!1);const e=t.levels;for(let t=0,n=e.length;t<n;t++){const n=e[t];this.addLevel(n.object.clone(),n.distance)}return this.autoUpdate=t.autoUpdate,this}addLevel(t,e=0){e=Math.abs(e);const n=this.levels;let i;for(i=0;i<n.length&&!(e<n[i].distance);i++);return n.splice(i,0,{distance:e,object:t}),this.add(t),this}getCurrentLevel(){return this._currentLevel}getObjectForDistance(t){const e=this.levels;if(e.length>0){let n,i;for(n=1,i=e.length;n<i&&!(t<e[n].distance);n++);return e[n-1].object}return null}raycast(t,e){if(this.levels.length>0){js.setFromMatrixPosition(this.matrixWorld);const n=t.ray.origin.distanceTo(js);this.getObjectForDistance(n).raycast(t,e)}}update(t){const e=this.levels;if(e.length>1){js.setFromMatrixPosition(t.matrixWorld),qs.setFromMatrixPosition(this.matrixWorld);const n=js.distanceTo(qs)/t.zoom;let i,r;for(e[0].object.visible=!0,i=1,r=e.length;i<r&&n>=e[i].distance;i++)e[i-1].object.visible=!1,e[i].object.visible=!0;for(this._currentLevel=i-1;i<r;i++)e[i].object.visible=!1}}toJSON(t){const e=super.toJSON(t);!1===this.autoUpdate&&(e.object.autoUpdate=!1),e.object.levels=[];const n=this.levels;for(let t=0,i=n.length;t<i;t++){const i=n[t];e.object.levels.push({object:i.object.uuid,distance:i.distance})}return e}}const Ys=new Lt,Zs=new St,Js=new St,Qs=new Lt,Ks=new se;class $s extends Wn{constructor(t,e){super(t,e),this.type="SkinnedMesh",this.bindMode="attached",this.bindMatrix=new se,this.bindMatrixInverse=new se}copy(t){return super.copy(t),this.bindMode=t.bindMode,this.bindMatrix.copy(t.bindMatrix),this.bindMatrixInverse.copy(t.bindMatrixInverse),this.skeleton=t.skeleton,this}bind(t,e){this.skeleton=t,void 0===e&&(this.updateMatrixWorld(!0),this.skeleton.calculateInverses(),e=this.matrixWorld),this.bindMatrix.copy(e),this.bindMatrixInverse.copy(e).invert()}pose(){this.skeleton.pose()}normalizeSkinWeights(){const t=new St,e=this.geometry.attributes.skinWeight;for(let n=0,i=e.count;n<i;n++){t.x=e.getX(n),t.y=e.getY(n),t.z=e.getZ(n),t.w=e.getW(n);const i=1/t.manhattanLength();i!==1/0?t.multiplyScalar(i):t.set(1,0,0,0),e.setXYZW(n,t.x,t.y,t.z,t.w)}}updateMatrixWorld(t){super.updateMatrixWorld(t),"attached"===this.bindMode?this.bindMatrixInverse.copy(this.matrixWorld).invert():"detached"===this.bindMode?this.bindMatrixInverse.copy(this.bindMatrix).invert():console.warn("THREE.SkinnedMesh: Unrecognized bindMode: "+this.bindMode)}boneTransform(t,e){const n=this.skeleton,i=this.geometry;Zs.fromBufferAttribute(i.attributes.skinIndex,t),Js.fromBufferAttribute(i.attributes.skinWeight,t),Ys.fromBufferAttribute(i.attributes.position,t).applyMatrix4(this.bindMatrix),e.set(0,0,0);for(let t=0;t<4;t++){const i=Js.getComponent(t);if(0!==i){const r=Zs.getComponent(t);Ks.multiplyMatrices(n.bones[r].matrixWorld,n.boneInverses[r]),e.addScaledVector(Qs.copy(Ys).applyMatrix4(Ks),i)}}return e.applyMatrix4(this.bindMatrixInverse)}}$s.prototype.isSkinnedMesh=!0;class ta extends Ce{constructor(){super(),this.type="Bone"}}ta.prototype.isBone=!0;const ea=new se,na=new se;class ia{constructor(t=[],e=[]){this.uuid=ct(),this.bones=t.slice(0),this.boneInverses=e,this.boneMatrices=null,this.boneTexture=null,this.boneTextureSize=0,this.frame=-1,this.init()}init(){const t=this.bones,e=this.boneInverses;if(this.boneMatrices=new Float32Array(16*t.length),0===e.length)this.calculateInverses();else if(t.length!==e.length){console.warn("THREE.Skeleton: Number of inverse bone matrices does not match amount of bones."),this.boneInverses=[];for(let t=0,e=this.bones.length;t<e;t++)this.boneInverses.push(new se)}}calculateInverses(){this.boneInverses.length=0;for(let t=0,e=this.bones.length;t<e;t++){const e=new se;this.bones[t]&&e.copy(this.bones[t].matrixWorld).invert(),this.boneInverses.push(e)}}pose(){for(let t=0,e=this.bones.length;t<e;t++){const e=this.bones[t];e&&e.matrixWorld.copy(this.boneInverses[t]).invert()}for(let t=0,e=this.bones.length;t<e;t++){const e=this.bones[t];e&&(e.parent&&e.parent.isBone?(e.matrix.copy(e.parent.matrixWorld).invert(),e.matrix.multiply(e.matrixWorld)):e.matrix.copy(e.matrixWorld),e.matrix.decompose(e.position,e.quaternion,e.scale))}}update(){const t=this.bones,e=this.boneInverses,n=this.boneMatrices,i=this.boneTexture;for(let i=0,r=t.length;i<r;i++){const r=t[i]?t[i].matrixWorld:na;ea.multiplyMatrices(r,e[i]),ea.toArray(n,16*i)}null!==i&&(i.needsUpdate=!0)}clone(){return new ia(this.bones,this.boneInverses)}getBoneByName(t){for(let e=0,n=this.bones.length;e<n;e++){const n=this.bones[e];if(n.name===t)return n}}dispose(){null!==this.boneTexture&&(this.boneTexture.dispose(),this.boneTexture=null)}fromJSON(t,e){this.uuid=t.uuid;for(let n=0,i=t.bones.length;n<i;n++){const i=t.bones[n];let r=e[i];void 0===r&&(console.warn("THREE.Skeleton: No bone found with UUID:",i),r=new ta),this.bones.push(r),this.boneInverses.push((new se).fromArray(t.boneInverses[n]))}return this.init(),this}toJSON(){const t={metadata:{version:4.5,type:"Skeleton",generator:"Skeleton.toJSON"},bones:[],boneInverses:[]};t.uuid=this.uuid;const e=this.bones,n=this.boneInverses;for(let i=0,r=e.length;i<r;i++){const r=e[i];t.bones.push(r.uuid);const s=n[i];t.boneInverses.push(s.toArray())}return t}}const ra=new se,sa=new se,aa=[],oa=new Wn;class la extends Wn{constructor(t,e,n){super(t,e),this.instanceMatrix=new sn(new Float32Array(16*n),16),this.instanceColor=null,this.count=n,this.frustumCulled=!1}copy(t){return super.copy(t),this.instanceMatrix.copy(t.instanceMatrix),null!==t.instanceColor&&(this.instanceColor=t.instanceColor.clone()),this.count=t.count,this}getColorAt(t,e){e.fromArray(this.instanceColor.array,3*t)}getMatrixAt(t,e){e.fromArray(this.instanceMatrix.array,16*t)}raycast(t,e){const n=this.matrixWorld,i=this.count;if(oa.geometry=this.geometry,oa.material=this.material,void 0!==oa.material)for(let r=0;r<i;r++){this.getMatrixAt(r,ra),sa.multiplyMatrices(n,ra),oa.matrixWorld=sa,oa.raycast(t,aa);for(let t=0,n=aa.length;t<n;t++){const n=aa[t];n.instanceId=r,n.object=this,e.push(n)}aa.length=0}}setColorAt(t,e){null===this.instanceColor&&(this.instanceColor=new sn(new Float32Array(3*this.count),3)),e.toArray(this.instanceColor.array,3*t)}setMatrixAt(t,e){e.toArray(this.instanceMatrix.array,16*t)}updateMorphTargets(){}dispose(){this.dispatchEvent({type:"dispose"})}}la.prototype.isInstancedMesh=!0;class ca extends Xe{constructor(t){super(),this.type="LineBasicMaterial",this.color=new tn(16777215),this.linewidth=1,this.linecap="round",this.linejoin="round",this.morphTargets=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.linewidth=t.linewidth,this.linecap=t.linecap,this.linejoin=t.linejoin,this.morphTargets=t.morphTargets,this}}ca.prototype.isLineBasicMaterial=!0;const ha=new Lt,ua=new Lt,da=new se,pa=new re,ma=new Jt;class fa extends Ce{constructor(t=new En,e=new ca){super(),this.type="Line",this.geometry=t,this.material=e,this.updateMorphTargets()}copy(t){return super.copy(t),this.material=t.material,this.geometry=t.geometry,this}computeLineDistances(){const t=this.geometry;if(t.isBufferGeometry)if(null===t.index){const e=t.attributes.position,n=[0];for(let t=1,i=e.count;t<i;t++)ha.fromBufferAttribute(e,t-1),ua.fromBufferAttribute(e,t),n[t]=n[t-1],n[t]+=ha.distanceTo(ua);t.setAttribute("lineDistance",new mn(n,1))}else console.warn("THREE.Line.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");else t.isGeometry&&console.error("THREE.Line.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");return this}raycast(t,e){const n=this.geometry,i=this.matrixWorld,r=t.params.Line.threshold,s=n.drawRange;if(null===n.boundingSphere&&n.computeBoundingSphere(),ma.copy(n.boundingSphere),ma.applyMatrix4(i),ma.radius+=r,!1===t.ray.intersectsSphere(ma))return;da.copy(i).invert(),pa.copy(t.ray).applyMatrix4(da);const a=r/((this.scale.x+this.scale.y+this.scale.z)/3),o=a*a,l=new Lt,c=new Lt,h=new Lt,u=new Lt,d=this.isLineSegments?2:1;if(n.isBufferGeometry){const i=n.index,r=n.attributes.position;if(null!==i){for(let n=Math.max(0,s.start),a=Math.min(i.count,s.start+s.count)-1;n<a;n+=d){const s=i.getX(n),a=i.getX(n+1);l.fromBufferAttribute(r,s),c.fromBufferAttribute(r,a);if(pa.distanceSqToSegment(l,c,u,h)>o)continue;u.applyMatrix4(this.matrixWorld);const d=t.ray.origin.distanceTo(u);d<t.near||d>t.far||e.push({distance:d,point:h.clone().applyMatrix4(this.matrixWorld),index:n,face:null,faceIndex:null,object:this})}}else{for(let n=Math.max(0,s.start),i=Math.min(r.count,s.start+s.count)-1;n<i;n+=d){l.fromBufferAttribute(r,n),c.fromBufferAttribute(r,n+1);if(pa.distanceSqToSegment(l,c,u,h)>o)continue;u.applyMatrix4(this.matrixWorld);const i=t.ray.origin.distanceTo(u);i<t.near||i>t.far||e.push({distance:i,point:h.clone().applyMatrix4(this.matrixWorld),index:n,face:null,faceIndex:null,object:this})}}}else n.isGeometry&&console.error("THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}updateMorphTargets(){const t=this.geometry;if(t.isBufferGeometry){const e=t.morphAttributes,n=Object.keys(e);if(n.length>0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e<n;e++){const n=t[e].name||String(e);this.morphTargetInfluences.push(0),this.morphTargetDictionary[n]=e}}}}else{const e=t.morphTargets;void 0!==e&&e.length>0&&console.error("THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}fa.prototype.isLine=!0;const ga=new Lt,va=new Lt;class ya extends fa{constructor(t,e){super(t,e),this.type="LineSegments"}computeLineDistances(){const t=this.geometry;if(t.isBufferGeometry)if(null===t.index){const e=t.attributes.position,n=[];for(let t=0,i=e.count;t<i;t+=2)ga.fromBufferAttribute(e,t),va.fromBufferAttribute(e,t+1),n[t]=0===t?0:n[t-1],n[t+1]=n[t]+ga.distanceTo(va);t.setAttribute("lineDistance",new mn(n,1))}else console.warn("THREE.LineSegments.computeLineDistances(): Computation only possible with non-indexed BufferGeometry.");else t.isGeometry&&console.error("THREE.LineSegments.computeLineDistances() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");return this}}ya.prototype.isLineSegments=!0;class xa extends fa{constructor(t,e){super(t,e),this.type="LineLoop"}}xa.prototype.isLineLoop=!0;class _a extends Xe{constructor(t){super(),this.type="PointsMaterial",this.color=new tn(16777215),this.map=null,this.alphaMap=null,this.size=1,this.sizeAttenuation=!0,this.morphTargets=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.alphaMap=t.alphaMap,this.size=t.size,this.sizeAttenuation=t.sizeAttenuation,this.morphTargets=t.morphTargets,this}}_a.prototype.isPointsMaterial=!0;const wa=new se,ba=new re,Ma=new Jt,Sa=new Lt;class Ta extends Ce{constructor(t=new En,e=new _a){super(),this.type="Points",this.geometry=t,this.material=e,this.updateMorphTargets()}copy(t){return super.copy(t),this.material=t.material,this.geometry=t.geometry,this}raycast(t,e){const n=this.geometry,i=this.matrixWorld,r=t.params.Points.threshold,s=n.drawRange;if(null===n.boundingSphere&&n.computeBoundingSphere(),Ma.copy(n.boundingSphere),Ma.applyMatrix4(i),Ma.radius+=r,!1===t.ray.intersectsSphere(Ma))return;wa.copy(i).invert(),ba.copy(t.ray).applyMatrix4(wa);const a=r/((this.scale.x+this.scale.y+this.scale.z)/3),o=a*a;if(n.isBufferGeometry){const r=n.index,a=n.attributes.position;if(null!==r){for(let n=Math.max(0,s.start),l=Math.min(r.count,s.start+s.count);n<l;n++){const s=r.getX(n);Sa.fromBufferAttribute(a,s),Ea(Sa,s,o,i,t,e,this)}}else{for(let n=Math.max(0,s.start),r=Math.min(a.count,s.start+s.count);n<r;n++)Sa.fromBufferAttribute(a,n),Ea(Sa,n,o,i,t,e,this)}}else console.error("THREE.Points.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}updateMorphTargets(){const t=this.geometry;if(t.isBufferGeometry){const e=t.morphAttributes,n=Object.keys(e);if(n.length>0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e<n;e++){const n=t[e].name||String(e);this.morphTargetInfluences.push(0),this.morphTargetDictionary[n]=e}}}}else{const e=t.morphTargets;void 0!==e&&e.length>0&&console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}function Ea(t,e,n,i,r,s,a){const o=ba.distanceSqToPoint(t);if(o<n){const n=new Lt;ba.closestPointToPoint(t,n),n.applyMatrix4(i);const l=r.ray.origin.distanceTo(n);if(l<r.near||l>r.far)return;s.push({distance:l,distanceToRay:Math.sqrt(o),point:n,index:e,face:null,object:a})}}Ta.prototype.isPoints=!0;class Aa extends bt{constructor(t,e,n,i,r,s,a,o,l){super(t,e,n,i,r,s,a,o,l),this.format=void 0!==a?a:T,this.minFilter=void 0!==s?s:g,this.magFilter=void 0!==r?r:g,this.generateMipmaps=!1;const c=this;"requestVideoFrameCallback"in t&&t.requestVideoFrameCallback((function e(){c.needsUpdate=!0,t.requestVideoFrameCallback(e)}))}clone(){return new this.constructor(this.image).copy(this)}update(){const t=this.image;!1==="requestVideoFrameCallback"in t&&t.readyState>=t.HAVE_CURRENT_DATA&&(this.needsUpdate=!0)}}Aa.prototype.isVideoTexture=!0;class La extends bt{constructor(t,e,n,i,r,s,a,o,l,c,h,u){super(null,s,a,o,l,c,i,r,h,u),this.image={width:e,height:n},this.mipmaps=t,this.flipY=!1,this.generateMipmaps=!1}}La.prototype.isCompressedTexture=!0;class Ra extends bt{constructor(t,e,n,i,r,s,a,o,l){super(t,e,n,i,r,s,a,o,l),this.needsUpdate=!0}}Ra.prototype.isCanvasTexture=!0;class Ca extends bt{constructor(t,e,n,i,r,s,a,o,l,c){if((c=void 0!==c?c:A)!==A&&c!==L)throw new Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat");void 0===n&&c===A&&(n=_),void 0===n&&c===L&&(n=S),super(null,i,r,s,a,o,c,n,l),this.image={width:t,height:e},this.magFilter=void 0!==a?a:p,this.minFilter=void 0!==o?o:p,this.flipY=!1,this.generateMipmaps=!1}}Ca.prototype.isDepthTexture=!0;class Pa extends En{constructor(t=1,e=8,n=0,i=2*Math.PI){super(),this.type="CircleGeometry",this.parameters={radius:t,segments:e,thetaStart:n,thetaLength:i},e=Math.max(3,e);const r=[],s=[],a=[],o=[],l=new Lt,c=new vt;s.push(0,0,0),a.push(0,0,1),o.push(.5,.5);for(let r=0,h=3;r<=e;r++,h+=3){const u=n+r/e*i;l.x=t*Math.cos(u),l.y=t*Math.sin(u),s.push(l.x,l.y,l.z),a.push(0,0,1),c.x=(s[h]/t+1)/2,c.y=(s[h+1]/t+1)/2,o.push(c.x,c.y)}for(let t=1;t<=e;t++)r.push(t,t+1,0);this.setIndex(r),this.setAttribute("position",new mn(s,3)),this.setAttribute("normal",new mn(a,3)),this.setAttribute("uv",new mn(o,2))}}class Da extends En{constructor(t=1,e=1,n=1,i=8,r=1,s=!1,a=0,o=2*Math.PI){super(),this.type="CylinderGeometry",this.parameters={radiusTop:t,radiusBottom:e,height:n,radialSegments:i,heightSegments:r,openEnded:s,thetaStart:a,thetaLength:o};const l=this;i=Math.floor(i),r=Math.floor(r);const c=[],h=[],u=[],d=[];let p=0;const m=[],f=n/2;let g=0;function v(n){const r=p,s=new vt,m=new Lt;let v=0;const y=!0===n?t:e,x=!0===n?1:-1;for(let t=1;t<=i;t++)h.push(0,f*x,0),u.push(0,x,0),d.push(.5,.5),p++;const _=p;for(let t=0;t<=i;t++){const e=t/i*o+a,n=Math.cos(e),r=Math.sin(e);m.x=y*r,m.y=f*x,m.z=y*n,h.push(m.x,m.y,m.z),u.push(0,x,0),s.x=.5*n+.5,s.y=.5*r*x+.5,d.push(s.x,s.y),p++}for(let t=0;t<i;t++){const e=r+t,i=_+t;!0===n?c.push(i,i+1,e):c.push(i+1,i,e),v+=3}l.addGroup(g,v,!0===n?1:2),g+=v}!function(){const s=new Lt,v=new Lt;let y=0;const x=(e-t)/n;for(let l=0;l<=r;l++){const c=[],g=l/r,y=g*(e-t)+t;for(let t=0;t<=i;t++){const e=t/i,r=e*o+a,l=Math.sin(r),m=Math.cos(r);v.x=y*l,v.y=-g*n+f,v.z=y*m,h.push(v.x,v.y,v.z),s.set(l,x,m).normalize(),u.push(s.x,s.y,s.z),d.push(e,1-g),c.push(p++)}m.push(c)}for(let t=0;t<i;t++)for(let e=0;e<r;e++){const n=m[e][t],i=m[e+1][t],r=m[e+1][t+1],s=m[e][t+1];c.push(n,i,s),c.push(i,r,s),y+=6}l.addGroup(g,y,0),g+=y}(),!1===s&&(t>0&&v(!0),e>0&&v(!1)),this.setIndex(c),this.setAttribute("position",new mn(h,3)),this.setAttribute("normal",new mn(u,3)),this.setAttribute("uv",new mn(d,2))}}class Ia extends Da{constructor(t=1,e=1,n=8,i=1,r=!1,s=0,a=2*Math.PI){super(0,t,e,n,i,r,s,a),this.type="ConeGeometry",this.parameters={radius:t,height:e,radialSegments:n,heightSegments:i,openEnded:r,thetaStart:s,thetaLength:a}}}class Na extends En{constructor(t,e,n=1,i=0){super(),this.type="PolyhedronGeometry",this.parameters={vertices:t,indices:e,radius:n,detail:i};const r=[],s=[];function a(t,e,n,i){const r=i+1,s=[];for(let i=0;i<=r;i++){s[i]=[];const a=t.clone().lerp(n,i/r),o=e.clone().lerp(n,i/r),l=r-i;for(let t=0;t<=l;t++)s[i][t]=0===t&&i===r?a:a.clone().lerp(o,t/l)}for(let t=0;t<r;t++)for(let e=0;e<2*(r-t)-1;e++){const n=Math.floor(e/2);e%2==0?(o(s[t][n+1]),o(s[t+1][n]),o(s[t][n])):(o(s[t][n+1]),o(s[t+1][n+1]),o(s[t+1][n]))}}function o(t){r.push(t.x,t.y,t.z)}function l(e,n){const i=3*e;n.x=t[i+0],n.y=t[i+1],n.z=t[i+2]}function c(t,e,n,i){i<0&&1===t.x&&(s[e]=t.x-1),0===n.x&&0===n.z&&(s[e]=i/2/Math.PI+.5)}function h(t){return Math.atan2(t.z,-t.x)}!function(t){const n=new Lt,i=new Lt,r=new Lt;for(let s=0;s<e.length;s+=3)l(e[s+0],n),l(e[s+1],i),l(e[s+2],r),a(n,i,r,t)}(i),function(t){const e=new Lt;for(let n=0;n<r.length;n+=3)e.x=r[n+0],e.y=r[n+1],e.z=r[n+2],e.normalize().multiplyScalar(t),r[n+0]=e.x,r[n+1]=e.y,r[n+2]=e.z}(n),function(){const t=new Lt;for(let n=0;n<r.length;n+=3){t.x=r[n+0],t.y=r[n+1],t.z=r[n+2];const i=h(t)/2/Math.PI+.5,a=(e=t,Math.atan2(-e.y,Math.sqrt(e.x*e.x+e.z*e.z))/Math.PI+.5);s.push(i,1-a)}var e;(function(){const t=new Lt,e=new Lt,n=new Lt,i=new Lt,a=new vt,o=new vt,l=new vt;for(let u=0,d=0;u<r.length;u+=9,d+=6){t.set(r[u+0],r[u+1],r[u+2]),e.set(r[u+3],r[u+4],r[u+5]),n.set(r[u+6],r[u+7],r[u+8]),a.set(s[d+0],s[d+1]),o.set(s[d+2],s[d+3]),l.set(s[d+4],s[d+5]),i.copy(t).add(e).add(n).divideScalar(3);const p=h(i);c(a,d+0,t,p),c(o,d+2,e,p),c(l,d+4,n,p)}})(),function(){for(let t=0;t<s.length;t+=6){const e=s[t+0],n=s[t+2],i=s[t+4],r=Math.max(e,n,i),a=Math.min(e,n,i);r>.9&&a<.1&&(e<.2&&(s[t+0]+=1),n<.2&&(s[t+2]+=1),i<.2&&(s[t+4]+=1))}}()}(),this.setAttribute("position",new mn(r,3)),this.setAttribute("normal",new mn(r.slice(),3)),this.setAttribute("uv",new mn(s,2)),0===i?this.computeVertexNormals():this.normalizeNormals()}}class Ba extends Na{constructor(t=1,e=0){const n=(1+Math.sqrt(5))/2,i=1/n;super([-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,-i,-n,0,-i,n,0,i,-n,0,i,n,-i,-n,0,-i,n,0,i,-n,0,i,n,0,-n,0,-i,n,0,-i,-n,0,i,n,0,i],[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],t,e),this.type="DodecahedronGeometry",this.parameters={radius:t,detail:e}}}const za=new Lt,Fa=new Lt,Oa=new Lt,Ha=new je;class Ga extends En{constructor(t,e){if(super(),this.type="EdgesGeometry",this.parameters={thresholdAngle:e},e=void 0!==e?e:1,!0===t.isGeometry)return void console.error("THREE.EdgesGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");const n=Math.pow(10,4),i=Math.cos(ot*e),r=t.getIndex(),s=t.getAttribute("position"),a=r?r.count:s.count,o=[0,0,0],l=["a","b","c"],c=new Array(3),h={},u=[];for(let t=0;t<a;t+=3){r?(o[0]=r.getX(t),o[1]=r.getX(t+1),o[2]=r.getX(t+2)):(o[0]=t,o[1]=t+1,o[2]=t+2);const{a:e,b:a,c:d}=Ha;if(e.fromBufferAttribute(s,o[0]),a.fromBufferAttribute(s,o[1]),d.fromBufferAttribute(s,o[2]),Ha.getNormal(Oa),c[0]=`${Math.round(e.x*n)},${Math.round(e.y*n)},${Math.round(e.z*n)}`,c[1]=`${Math.round(a.x*n)},${Math.round(a.y*n)},${Math.round(a.z*n)}`,c[2]=`${Math.round(d.x*n)},${Math.round(d.y*n)},${Math.round(d.z*n)}`,c[0]!==c[1]&&c[1]!==c[2]&&c[2]!==c[0])for(let t=0;t<3;t++){const e=(t+1)%3,n=c[t],r=c[e],s=Ha[l[t]],a=Ha[l[e]],d=`${n}_${r}`,p=`${r}_${n}`;p in h&&h[p]?(Oa.dot(h[p].normal)<=i&&(u.push(s.x,s.y,s.z),u.push(a.x,a.y,a.z)),h[p]=null):d in h||(h[d]={index0:o[t],index1:o[e],normal:Oa.clone()})}}for(const t in h)if(h[t]){const{index0:e,index1:n}=h[t];za.fromBufferAttribute(s,e),Fa.fromBufferAttribute(s,n),u.push(za.x,za.y,za.z),u.push(Fa.x,Fa.y,Fa.z)}this.setAttribute("position",new mn(u,3))}}const Ua=function(t,e,n){n=n||2;const i=e&&e.length,r=i?e[0]*n:t.length;let s=ka(t,0,r,n,!0);const a=[];if(!s||s.next===s.prev)return a;let o,l,c,h,u,d,p;if(i&&(s=function(t,e,n,i){const r=[];let s,a,o,l,c;for(s=0,a=e.length;s<a;s++)o=e[s]*i,l=s<a-1?e[s+1]*i:t.length,c=ka(t,o,l,i,!1),c===c.next&&(c.steiner=!0),r.push($a(c));for(r.sort(Za),s=0;s<r.length;s++)Ja(r[s],n),n=Va(n,n.next);return n}(t,e,s,n)),t.length>80*n){o=c=t[0],l=h=t[1];for(let e=n;e<r;e+=n)u=t[e],d=t[e+1],u<o&&(o=u),d<l&&(l=d),u>c&&(c=u),d>h&&(h=d);p=Math.max(c-o,h-l),p=0!==p?1/p:0}return Wa(s,a,n,o,l,p),a};function ka(t,e,n,i,r){let s,a;if(r===function(t,e,n,i){let r=0;for(let s=e,a=n-i;s<n;s+=i)r+=(t[a]-t[s])*(t[s+1]+t[a+1]),a=s;return r}(t,e,n,i)>0)for(s=e;s<n;s+=i)a=co(s,t[s],t[s+1],a);else for(s=n-i;s>=e;s-=i)a=co(s,t[s],t[s+1],a);return a&&io(a,a.next)&&(ho(a),a=a.next),a}function Va(t,e){if(!t)return t;e||(e=t);let n,i=t;do{if(n=!1,i.steiner||!io(i,i.next)&&0!==no(i.prev,i,i.next))i=i.next;else{if(ho(i),i=e=i.prev,i===i.next)break;n=!0}}while(n||i!==e);return e}function Wa(t,e,n,i,r,s,a){if(!t)return;!a&&s&&function(t,e,n,i){let r=t;do{null===r.z&&(r.z=Ka(r.x,r.y,e,n,i)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next}while(r!==t);r.prevZ.nextZ=null,r.prevZ=null,function(t){let e,n,i,r,s,a,o,l,c=1;do{for(n=t,t=null,s=null,a=0;n;){for(a++,i=n,o=0,e=0;e<c&&(o++,i=i.nextZ,i);e++);for(l=c;o>0||l>0&&i;)0!==o&&(0===l||!i||n.z<=i.z)?(r=n,n=n.nextZ,o--):(r=i,i=i.nextZ,l--),s?s.nextZ=r:t=r,r.prevZ=s,s=r;n=i}s.nextZ=null,c*=2}while(a>1)}(r)}(t,i,r,s);let o,l,c=t;for(;t.prev!==t.next;)if(o=t.prev,l=t.next,s?qa(t,i,r,s):ja(t))e.push(o.i/n),e.push(t.i/n),e.push(l.i/n),ho(t),t=l.next,c=l.next;else if((t=l)===c){a?1===a?Wa(t=Xa(Va(t),e,n),e,n,i,r,s,2):2===a&&Ya(t,e,n,i,r,s):Wa(Va(t),e,n,i,r,s,1);break}}function ja(t){const e=t.prev,n=t,i=t.next;if(no(e,n,i)>=0)return!1;let r=t.next.next;for(;r!==t.prev;){if(to(e.x,e.y,n.x,n.y,i.x,i.y,r.x,r.y)&&no(r.prev,r,r.next)>=0)return!1;r=r.next}return!0}function qa(t,e,n,i){const r=t.prev,s=t,a=t.next;if(no(r,s,a)>=0)return!1;const o=r.x<s.x?r.x<a.x?r.x:a.x:s.x<a.x?s.x:a.x,l=r.y<s.y?r.y<a.y?r.y:a.y:s.y<a.y?s.y:a.y,c=r.x>s.x?r.x>a.x?r.x:a.x:s.x>a.x?s.x:a.x,h=r.y>s.y?r.y>a.y?r.y:a.y:s.y>a.y?s.y:a.y,u=Ka(o,l,e,n,i),d=Ka(c,h,e,n,i);let p=t.prevZ,m=t.nextZ;for(;p&&p.z>=u&&m&&m.z<=d;){if(p!==t.prev&&p!==t.next&&to(r.x,r.y,s.x,s.y,a.x,a.y,p.x,p.y)&&no(p.prev,p,p.next)>=0)return!1;if(p=p.prevZ,m!==t.prev&&m!==t.next&&to(r.x,r.y,s.x,s.y,a.x,a.y,m.x,m.y)&&no(m.prev,m,m.next)>=0)return!1;m=m.nextZ}for(;p&&p.z>=u;){if(p!==t.prev&&p!==t.next&&to(r.x,r.y,s.x,s.y,a.x,a.y,p.x,p.y)&&no(p.prev,p,p.next)>=0)return!1;p=p.prevZ}for(;m&&m.z<=d;){if(m!==t.prev&&m!==t.next&&to(r.x,r.y,s.x,s.y,a.x,a.y,m.x,m.y)&&no(m.prev,m,m.next)>=0)return!1;m=m.nextZ}return!0}function Xa(t,e,n){let i=t;do{const r=i.prev,s=i.next.next;!io(r,s)&&ro(r,i,i.next,s)&&oo(r,s)&&oo(s,r)&&(e.push(r.i/n),e.push(i.i/n),e.push(s.i/n),ho(i),ho(i.next),i=t=s),i=i.next}while(i!==t);return Va(i)}function Ya(t,e,n,i,r,s){let a=t;do{let t=a.next.next;for(;t!==a.prev;){if(a.i!==t.i&&eo(a,t)){let o=lo(a,t);return a=Va(a,a.next),o=Va(o,o.next),Wa(a,e,n,i,r,s),void Wa(o,e,n,i,r,s)}t=t.next}a=a.next}while(a!==t)}function Za(t,e){return t.x-e.x}function Ja(t,e){if(e=function(t,e){let n=e;const i=t.x,r=t.y;let s,a=-1/0;do{if(r<=n.y&&r>=n.next.y&&n.next.y!==n.y){const t=n.x+(r-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(t<=i&&t>a){if(a=t,t===i){if(r===n.y)return n;if(r===n.next.y)return n.next}s=n.x<n.next.x?n:n.next}}n=n.next}while(n!==e);if(!s)return null;if(i===a)return s;const o=s,l=s.x,c=s.y;let h,u=1/0;n=s;do{i>=n.x&&n.x>=l&&i!==n.x&&to(r<c?i:a,r,l,c,r<c?a:i,r,n.x,n.y)&&(h=Math.abs(r-n.y)/(i-n.x),oo(n,t)&&(h<u||h===u&&(n.x>s.x||n.x===s.x&&Qa(s,n)))&&(s=n,u=h)),n=n.next}while(n!==o);return s}(t,e)){const n=lo(e,t);Va(e,e.next),Va(n,n.next)}}function Qa(t,e){return no(t.prev,t,e.prev)<0&&no(e.next,t,t.next)<0}function Ka(t,e,n,i,r){return(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=32767*(t-n)*r)|t<<8))|t<<4))|t<<2))|t<<1))|(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=32767*(e-i)*r)|e<<8))|e<<4))|e<<2))|e<<1))<<1}function $a(t){let e=t,n=t;do{(e.x<n.x||e.x===n.x&&e.y<n.y)&&(n=e),e=e.next}while(e!==t);return n}function to(t,e,n,i,r,s,a,o){return(r-a)*(e-o)-(t-a)*(s-o)>=0&&(t-a)*(i-o)-(n-a)*(e-o)>=0&&(n-a)*(s-o)-(r-a)*(i-o)>=0}function eo(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!function(t,e){let n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&ro(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}(t,e)&&(oo(t,e)&&oo(e,t)&&function(t,e){let n=t,i=!1;const r=(t.x+e.x)/2,s=(t.y+e.y)/2;do{n.y>s!=n.next.y>s&&n.next.y!==n.y&&r<(n.next.x-n.x)*(s-n.y)/(n.next.y-n.y)+n.x&&(i=!i),n=n.next}while(n!==t);return i}(t,e)&&(no(t.prev,t,e.prev)||no(t,e.prev,e))||io(t,e)&&no(t.prev,t,t.next)>0&&no(e.prev,e,e.next)>0)}function no(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function io(t,e){return t.x===e.x&&t.y===e.y}function ro(t,e,n,i){const r=ao(no(t,e,n)),s=ao(no(t,e,i)),a=ao(no(n,i,t)),o=ao(no(n,i,e));return r!==s&&a!==o||(!(0!==r||!so(t,n,e))||(!(0!==s||!so(t,i,e))||(!(0!==a||!so(n,t,i))||!(0!==o||!so(n,e,i)))))}function so(t,e,n){return e.x<=Math.max(t.x,n.x)&&e.x>=Math.min(t.x,n.x)&&e.y<=Math.max(t.y,n.y)&&e.y>=Math.min(t.y,n.y)}function ao(t){return t>0?1:t<0?-1:0}function oo(t,e){return no(t.prev,t,t.next)<0?no(t,e,t.next)>=0&&no(t,t.prev,e)>=0:no(t,e,t.prev)<0||no(t,t.next,e)<0}function lo(t,e){const n=new uo(t.i,t.x,t.y),i=new uo(e.i,e.x,e.y),r=t.next,s=e.prev;return t.next=e,e.prev=t,n.next=r,r.prev=n,i.next=n,n.prev=i,s.next=i,i.prev=s,i}function co(t,e,n,i){const r=new uo(t,e,n);return i?(r.next=i.next,r.prev=i,i.next.prev=r,i.next=r):(r.prev=r,r.next=r),r}function ho(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function uo(t,e,n){this.i=t,this.x=e,this.y=n,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}class po{static area(t){const e=t.length;let n=0;for(let i=e-1,r=0;r<e;i=r++)n+=t[i].x*t[r].y-t[r].x*t[i].y;return.5*n}static isClockWise(t){return po.area(t)<0}static triangulateShape(t,e){const n=[],i=[],r=[];mo(t),fo(n,t);let s=t.length;e.forEach(mo);for(let t=0;t<e.length;t++)i.push(s),s+=e[t].length,fo(n,e[t]);const a=Ua(n,i);for(let t=0;t<a.length;t+=3)r.push(a.slice(t,t+3));return r}}function mo(t){const e=t.length;e>2&&t[e-1].equals(t[0])&&t.pop()}function fo(t,e){for(let n=0;n<e.length;n++)t.push(e[n].x),t.push(e[n].y)}class go extends En{constructor(t,e){super(),this.type="ExtrudeGeometry",this.parameters={shapes:t,options:e},t=Array.isArray(t)?t:[t];const n=this,i=[],r=[];for(let e=0,n=t.length;e<n;e++){s(t[e])}function s(t){const s=[],a=void 0!==e.curveSegments?e.curveSegments:12,o=void 0!==e.steps?e.steps:1;let l=void 0!==e.depth?e.depth:100,c=void 0===e.bevelEnabled||e.bevelEnabled,h=void 0!==e.bevelThickness?e.bevelThickness:6,u=void 0!==e.bevelSize?e.bevelSize:h-2,d=void 0!==e.bevelOffset?e.bevelOffset:0,p=void 0!==e.bevelSegments?e.bevelSegments:3;const m=e.extrudePath,f=void 0!==e.UVGenerator?e.UVGenerator:vo;void 0!==e.amount&&(console.warn("THREE.ExtrudeBufferGeometry: amount has been renamed to depth."),l=e.amount);let g,v,y,x,_,w=!1;m&&(g=m.getSpacedPoints(o),w=!0,c=!1,v=m.computeFrenetFrames(o,!1),y=new Lt,x=new Lt,_=new Lt),c||(p=0,h=0,u=0,d=0);const b=t.extractPoints(a);let M=b.shape;const S=b.holes;if(!po.isClockWise(M)){M=M.reverse();for(let t=0,e=S.length;t<e;t++){const e=S[t];po.isClockWise(e)&&(S[t]=e.reverse())}}const T=po.triangulateShape(M,S),E=M;for(let t=0,e=S.length;t<e;t++){const e=S[t];M=M.concat(e)}function A(t,e,n){return e||console.error("THREE.ExtrudeGeometry: vec does not exist"),e.clone().multiplyScalar(n).add(t)}const L=M.length,R=T.length;function C(t,e,n){let i,r,s;const a=t.x-e.x,o=t.y-e.y,l=n.x-t.x,c=n.y-t.y,h=a*a+o*o,u=a*c-o*l;if(Math.abs(u)>Number.EPSILON){const u=Math.sqrt(h),d=Math.sqrt(l*l+c*c),p=e.x-o/u,m=e.y+a/u,f=((n.x-c/d-p)*c-(n.y+l/d-m)*l)/(a*c-o*l);i=p+a*f-t.x,r=m+o*f-t.y;const g=i*i+r*r;if(g<=2)return new vt(i,r);s=Math.sqrt(g/2)}else{let t=!1;a>Number.EPSILON?l>Number.EPSILON&&(t=!0):a<-Number.EPSILON?l<-Number.EPSILON&&(t=!0):Math.sign(o)===Math.sign(c)&&(t=!0),t?(i=-o,r=a,s=Math.sqrt(h)):(i=a,r=o,s=Math.sqrt(h/2))}return new vt(i/s,r/s)}const P=[];for(let t=0,e=E.length,n=e-1,i=t+1;t<e;t++,n++,i++)n===e&&(n=0),i===e&&(i=0),P[t]=C(E[t],E[n],E[i]);const D=[];let I,N=P.concat();for(let t=0,e=S.length;t<e;t++){const e=S[t];I=[];for(let t=0,n=e.length,i=n-1,r=t+1;t<n;t++,i++,r++)i===n&&(i=0),r===n&&(r=0),I[t]=C(e[t],e[i],e[r]);D.push(I),N=N.concat(I)}for(let t=0;t<p;t++){const e=t/p,n=h*Math.cos(e*Math.PI/2),i=u*Math.sin(e*Math.PI/2)+d;for(let t=0,e=E.length;t<e;t++){const e=A(E[t],P[t],i);F(e.x,e.y,-n)}for(let t=0,e=S.length;t<e;t++){const e=S[t];I=D[t];for(let t=0,r=e.length;t<r;t++){const r=A(e[t],I[t],i);F(r.x,r.y,-n)}}}const B=u+d;for(let t=0;t<L;t++){const e=c?A(M[t],N[t],B):M[t];w?(x.copy(v.normals[0]).multiplyScalar(e.x),y.copy(v.binormals[0]).multiplyScalar(e.y),_.copy(g[0]).add(x).add(y),F(_.x,_.y,_.z)):F(e.x,e.y,0)}for(let t=1;t<=o;t++)for(let e=0;e<L;e++){const n=c?A(M[e],N[e],B):M[e];w?(x.copy(v.normals[t]).multiplyScalar(n.x),y.copy(v.binormals[t]).multiplyScalar(n.y),_.copy(g[t]).add(x).add(y),F(_.x,_.y,_.z)):F(n.x,n.y,l/o*t)}for(let t=p-1;t>=0;t--){const e=t/p,n=h*Math.cos(e*Math.PI/2),i=u*Math.sin(e*Math.PI/2)+d;for(let t=0,e=E.length;t<e;t++){const e=A(E[t],P[t],i);F(e.x,e.y,l+n)}for(let t=0,e=S.length;t<e;t++){const e=S[t];I=D[t];for(let t=0,r=e.length;t<r;t++){const r=A(e[t],I[t],i);w?F(r.x,r.y+g[o-1].y,g[o-1].x+n):F(r.x,r.y,l+n)}}}function z(t,e){let n=t.length;for(;--n>=0;){const i=n;let r=n-1;r<0&&(r=t.length-1);for(let t=0,n=o+2*p;t<n;t++){const n=L*t,s=L*(t+1);H(e+i+n,e+r+n,e+r+s,e+i+s)}}}function F(t,e,n){s.push(t),s.push(e),s.push(n)}function O(t,e,r){G(t),G(e),G(r);const s=i.length/3,a=f.generateTopUV(n,i,s-3,s-2,s-1);U(a[0]),U(a[1]),U(a[2])}function H(t,e,r,s){G(t),G(e),G(s),G(e),G(r),G(s);const a=i.length/3,o=f.generateSideWallUV(n,i,a-6,a-3,a-2,a-1);U(o[0]),U(o[1]),U(o[3]),U(o[1]),U(o[2]),U(o[3])}function G(t){i.push(s[3*t+0]),i.push(s[3*t+1]),i.push(s[3*t+2])}function U(t){r.push(t.x),r.push(t.y)}!function(){const t=i.length/3;if(c){let t=0,e=L*t;for(let t=0;t<R;t++){const n=T[t];O(n[2]+e,n[1]+e,n[0]+e)}t=o+2*p,e=L*t;for(let t=0;t<R;t++){const n=T[t];O(n[0]+e,n[1]+e,n[2]+e)}}else{for(let t=0;t<R;t++){const e=T[t];O(e[2],e[1],e[0])}for(let t=0;t<R;t++){const e=T[t];O(e[0]+L*o,e[1]+L*o,e[2]+L*o)}}n.addGroup(t,i.length/3-t,0)}(),function(){const t=i.length/3;let e=0;z(E,e),e+=E.length;for(let t=0,n=S.length;t<n;t++){const n=S[t];z(n,e),e+=n.length}n.addGroup(t,i.length/3-t,1)}()}this.setAttribute("position",new mn(i,3)),this.setAttribute("uv",new mn(r,2)),this.computeVertexNormals()}toJSON(){const t=En.prototype.toJSON.call(this);return function(t,e,n){if(n.shapes=[],Array.isArray(t))for(let e=0,i=t.length;e<i;e++){const i=t[e];n.shapes.push(i.uuid)}else n.shapes.push(t.uuid);void 0!==e.extrudePath&&(n.options.extrudePath=e.extrudePath.toJSON());return n}(this.parameters.shapes,this.parameters.options,t)}}const vo={generateTopUV:function(t,e,n,i,r){const s=e[3*n],a=e[3*n+1],o=e[3*i],l=e[3*i+1],c=e[3*r],h=e[3*r+1];return[new vt(s,a),new vt(o,l),new vt(c,h)]},generateSideWallUV:function(t,e,n,i,r,s){const a=e[3*n],o=e[3*n+1],l=e[3*n+2],c=e[3*i],h=e[3*i+1],u=e[3*i+2],d=e[3*r],p=e[3*r+1],m=e[3*r+2],f=e[3*s],g=e[3*s+1],v=e[3*s+2];return Math.abs(o-h)<.01?[new vt(a,1-l),new vt(c,1-u),new vt(d,1-m),new vt(f,1-v)]:[new vt(o,1-l),new vt(h,1-u),new vt(p,1-m),new vt(g,1-v)]}};class yo extends Na{constructor(t=1,e=0){const n=(1+Math.sqrt(5))/2;super([-1,n,0,1,n,0,-1,-n,0,1,-n,0,0,-1,n,0,1,n,0,-1,-n,0,1,-n,n,0,-1,n,0,1,-n,0,-1,-n,0,1],[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],t,e),this.type="IcosahedronGeometry",this.parameters={radius:t,detail:e}}}class xo extends En{constructor(t,e=12,n=0,i=2*Math.PI){super(),this.type="LatheGeometry",this.parameters={points:t,segments:e,phiStart:n,phiLength:i},e=Math.floor(e),i=ht(i,0,2*Math.PI);const r=[],s=[],a=[],o=1/e,l=new Lt,c=new vt;for(let r=0;r<=e;r++){const h=n+r*o*i,u=Math.sin(h),d=Math.cos(h);for(let n=0;n<=t.length-1;n++)l.x=t[n].x*u,l.y=t[n].y,l.z=t[n].x*d,s.push(l.x,l.y,l.z),c.x=r/e,c.y=n/(t.length-1),a.push(c.x,c.y)}for(let n=0;n<e;n++)for(let e=0;e<t.length-1;e++){const i=e+n*t.length,s=i,a=i+t.length,o=i+t.length+1,l=i+1;r.push(s,a,l),r.push(a,o,l)}if(this.setIndex(r),this.setAttribute("position",new mn(s,3)),this.setAttribute("uv",new mn(a,2)),this.computeVertexNormals(),i===2*Math.PI){const n=this.attributes.normal.array,i=new Lt,r=new Lt,s=new Lt,a=e*t.length*3;for(let e=0,o=0;e<t.length;e++,o+=3)i.x=n[o+0],i.y=n[o+1],i.z=n[o+2],r.x=n[a+o+0],r.y=n[a+o+1],r.z=n[a+o+2],s.addVectors(i,r).normalize(),n[o+0]=n[a+o+0]=s.x,n[o+1]=n[a+o+1]=s.y,n[o+2]=n[a+o+2]=s.z}}}class _o extends Na{constructor(t=1,e=0){super([1,0,0,-1,0,0,0,1,0,0,-1,0,0,0,1,0,0,-1],[0,2,4,0,4,3,0,3,5,0,5,2,1,2,5,1,5,3,1,3,4,1,4,2],t,e),this.type="OctahedronGeometry",this.parameters={radius:t,detail:e}}}class wo extends En{constructor(t,e,n){super(),this.type="ParametricGeometry",this.parameters={func:t,slices:e,stacks:n};const i=[],r=[],s=[],a=[],o=1e-5,l=new Lt,c=new Lt,h=new Lt,u=new Lt,d=new Lt;t.length<3&&console.error("THREE.ParametricGeometry: Function must now modify a Vector3 as third parameter.");const p=e+1;for(let i=0;i<=n;i++){const p=i/n;for(let n=0;n<=e;n++){const i=n/e;t(i,p,c),r.push(c.x,c.y,c.z),i-o>=0?(t(i-o,p,h),u.subVectors(c,h)):(t(i+o,p,h),u.subVectors(h,c)),p-o>=0?(t(i,p-o,h),d.subVectors(c,h)):(t(i,p+o,h),d.subVectors(h,c)),l.crossVectors(u,d).normalize(),s.push(l.x,l.y,l.z),a.push(i,p)}}for(let t=0;t<n;t++)for(let n=0;n<e;n++){const e=t*p+n,r=t*p+n+1,s=(t+1)*p+n+1,a=(t+1)*p+n;i.push(e,r,a),i.push(r,s,a)}this.setIndex(i),this.setAttribute("position",new mn(r,3)),this.setAttribute("normal",new mn(s,3)),this.setAttribute("uv",new mn(a,2))}}class bo extends En{constructor(t=.5,e=1,n=8,i=1,r=0,s=2*Math.PI){super(),this.type="RingGeometry",this.parameters={innerRadius:t,outerRadius:e,thetaSegments:n,phiSegments:i,thetaStart:r,thetaLength:s},n=Math.max(3,n);const a=[],o=[],l=[],c=[];let h=t;const u=(e-t)/(i=Math.max(1,i)),d=new Lt,p=new vt;for(let t=0;t<=i;t++){for(let t=0;t<=n;t++){const i=r+t/n*s;d.x=h*Math.cos(i),d.y=h*Math.sin(i),o.push(d.x,d.y,d.z),l.push(0,0,1),p.x=(d.x/e+1)/2,p.y=(d.y/e+1)/2,c.push(p.x,p.y)}h+=u}for(let t=0;t<i;t++){const e=t*(n+1);for(let t=0;t<n;t++){const i=t+e,r=i,s=i+n+1,o=i+n+2,l=i+1;a.push(r,s,l),a.push(s,o,l)}}this.setIndex(a),this.setAttribute("position",new mn(o,3)),this.setAttribute("normal",new mn(l,3)),this.setAttribute("uv",new mn(c,2))}}class Mo extends En{constructor(t,e=12){super(),this.type="ShapeGeometry",this.parameters={shapes:t,curveSegments:e};const n=[],i=[],r=[],s=[];let a=0,o=0;if(!1===Array.isArray(t))l(t);else for(let e=0;e<t.length;e++)l(t[e]),this.addGroup(a,o,e),a+=o,o=0;function l(t){const a=i.length/3,l=t.extractPoints(e);let c=l.shape;const h=l.holes;!1===po.isClockWise(c)&&(c=c.reverse());for(let t=0,e=h.length;t<e;t++){const e=h[t];!0===po.isClockWise(e)&&(h[t]=e.reverse())}const u=po.triangulateShape(c,h);for(let t=0,e=h.length;t<e;t++){const e=h[t];c=c.concat(e)}for(let t=0,e=c.length;t<e;t++){const e=c[t];i.push(e.x,e.y,0),r.push(0,0,1),s.push(e.x,e.y)}for(let t=0,e=u.length;t<e;t++){const e=u[t],i=e[0]+a,r=e[1]+a,s=e[2]+a;n.push(i,r,s),o+=3}}this.setIndex(n),this.setAttribute("position",new mn(i,3)),this.setAttribute("normal",new mn(r,3)),this.setAttribute("uv",new mn(s,2))}toJSON(){const t=En.prototype.toJSON.call(this);return function(t,e){if(e.shapes=[],Array.isArray(t))for(let n=0,i=t.length;n<i;n++){const i=t[n];e.shapes.push(i.uuid)}else e.shapes.push(t.uuid);return e}(this.parameters.shapes,t)}}class So extends En{constructor(t=1,e=8,n=6,i=0,r=2*Math.PI,s=0,a=Math.PI){super(),this.type="SphereGeometry",this.parameters={radius:t,widthSegments:e,heightSegments:n,phiStart:i,phiLength:r,thetaStart:s,thetaLength:a},e=Math.max(3,Math.floor(e)),n=Math.max(2,Math.floor(n));const o=Math.min(s+a,Math.PI);let l=0;const c=[],h=new Lt,u=new Lt,d=[],p=[],m=[],f=[];for(let d=0;d<=n;d++){const g=[],v=d/n;let y=0;0==d&&0==s?y=.5/e:d==n&&o==Math.PI&&(y=-.5/e);for(let n=0;n<=e;n++){const o=n/e;h.x=-t*Math.cos(i+o*r)*Math.sin(s+v*a),h.y=t*Math.cos(s+v*a),h.z=t*Math.sin(i+o*r)*Math.sin(s+v*a),p.push(h.x,h.y,h.z),u.copy(h).normalize(),m.push(u.x,u.y,u.z),f.push(o+y,1-v),g.push(l++)}c.push(g)}for(let t=0;t<n;t++)for(let i=0;i<e;i++){const e=c[t][i+1],r=c[t][i],a=c[t+1][i],l=c[t+1][i+1];(0!==t||s>0)&&d.push(e,r,l),(t!==n-1||o<Math.PI)&&d.push(r,a,l)}this.setIndex(d),this.setAttribute("position",new mn(p,3)),this.setAttribute("normal",new mn(m,3)),this.setAttribute("uv",new mn(f,2))}}class To extends Na{constructor(t=1,e=0){super([1,1,1,-1,-1,1,-1,1,-1,1,-1,-1],[2,1,0,0,3,2,1,3,0,2,3,1],t,e),this.type="TetrahedronGeometry",this.parameters={radius:t,detail:e}}}class Eo extends go{constructor(t,e={}){const n=e.font;if(!n||!n.isFont)return console.error("THREE.TextGeometry: font parameter is not an instance of THREE.Font."),new En;const i=n.generateShapes(t,e.size);e.depth=void 0!==e.height?e.height:50,void 0===e.bevelThickness&&(e.bevelThickness=10),void 0===e.bevelSize&&(e.bevelSize=8),void 0===e.bevelEnabled&&(e.bevelEnabled=!1),super(i,e),this.type="TextGeometry"}}class Ao extends En{constructor(t=1,e=.4,n=8,i=6,r=2*Math.PI){super(),this.type="TorusGeometry",this.parameters={radius:t,tube:e,radialSegments:n,tubularSegments:i,arc:r},n=Math.floor(n),i=Math.floor(i);const s=[],a=[],o=[],l=[],c=new Lt,h=new Lt,u=new Lt;for(let s=0;s<=n;s++)for(let d=0;d<=i;d++){const p=d/i*r,m=s/n*Math.PI*2;h.x=(t+e*Math.cos(m))*Math.cos(p),h.y=(t+e*Math.cos(m))*Math.sin(p),h.z=e*Math.sin(m),a.push(h.x,h.y,h.z),c.x=t*Math.cos(p),c.y=t*Math.sin(p),u.subVectors(h,c).normalize(),o.push(u.x,u.y,u.z),l.push(d/i),l.push(s/n)}for(let t=1;t<=n;t++)for(let e=1;e<=i;e++){const n=(i+1)*t+e-1,r=(i+1)*(t-1)+e-1,a=(i+1)*(t-1)+e,o=(i+1)*t+e;s.push(n,r,o),s.push(r,a,o)}this.setIndex(s),this.setAttribute("position",new mn(a,3)),this.setAttribute("normal",new mn(o,3)),this.setAttribute("uv",new mn(l,2))}}class Lo extends En{constructor(t=1,e=.4,n=64,i=8,r=2,s=3){super(),this.type="TorusKnotGeometry",this.parameters={radius:t,tube:e,tubularSegments:n,radialSegments:i,p:r,q:s},n=Math.floor(n),i=Math.floor(i);const a=[],o=[],l=[],c=[],h=new Lt,u=new Lt,d=new Lt,p=new Lt,m=new Lt,f=new Lt,g=new Lt;for(let a=0;a<=n;++a){const y=a/n*r*Math.PI*2;v(y,r,s,t,d),v(y+.01,r,s,t,p),f.subVectors(p,d),g.addVectors(p,d),m.crossVectors(f,g),g.crossVectors(m,f),m.normalize(),g.normalize();for(let t=0;t<=i;++t){const r=t/i*Math.PI*2,s=-e*Math.cos(r),p=e*Math.sin(r);h.x=d.x+(s*g.x+p*m.x),h.y=d.y+(s*g.y+p*m.y),h.z=d.z+(s*g.z+p*m.z),o.push(h.x,h.y,h.z),u.subVectors(h,d).normalize(),l.push(u.x,u.y,u.z),c.push(a/n),c.push(t/i)}}for(let t=1;t<=n;t++)for(let e=1;e<=i;e++){const n=(i+1)*(t-1)+(e-1),r=(i+1)*t+(e-1),s=(i+1)*t+e,o=(i+1)*(t-1)+e;a.push(n,r,o),a.push(r,s,o)}function v(t,e,n,i,r){const s=Math.cos(t),a=Math.sin(t),o=n/e*t,l=Math.cos(o);r.x=i*(2+l)*.5*s,r.y=i*(2+l)*a*.5,r.z=i*Math.sin(o)*.5}this.setIndex(a),this.setAttribute("position",new mn(o,3)),this.setAttribute("normal",new mn(l,3)),this.setAttribute("uv",new mn(c,2))}}class Ro extends En{constructor(t,e=64,n=1,i=8,r=!1){super(),this.type="TubeGeometry",this.parameters={path:t,tubularSegments:e,radius:n,radialSegments:i,closed:r};const s=t.computeFrenetFrames(e,r);this.tangents=s.tangents,this.normals=s.normals,this.binormals=s.binormals;const a=new Lt,o=new Lt,l=new vt;let c=new Lt;const h=[],u=[],d=[],p=[];function m(r){c=t.getPointAt(r/e,c);const l=s.normals[r],d=s.binormals[r];for(let t=0;t<=i;t++){const e=t/i*Math.PI*2,r=Math.sin(e),s=-Math.cos(e);o.x=s*l.x+r*d.x,o.y=s*l.y+r*d.y,o.z=s*l.z+r*d.z,o.normalize(),u.push(o.x,o.y,o.z),a.x=c.x+n*o.x,a.y=c.y+n*o.y,a.z=c.z+n*o.z,h.push(a.x,a.y,a.z)}}!function(){for(let t=0;t<e;t++)m(t);m(!1===r?e:0),function(){for(let t=0;t<=e;t++)for(let n=0;n<=i;n++)l.x=t/e,l.y=n/i,d.push(l.x,l.y)}(),function(){for(let t=1;t<=e;t++)for(let e=1;e<=i;e++){const n=(i+1)*(t-1)+(e-1),r=(i+1)*t+(e-1),s=(i+1)*t+e,a=(i+1)*(t-1)+e;p.push(n,r,a),p.push(r,s,a)}}()}(),this.setIndex(p),this.setAttribute("position",new mn(h,3)),this.setAttribute("normal",new mn(u,3)),this.setAttribute("uv",new mn(d,2))}toJSON(){const t=En.prototype.toJSON.call(this);return t.path=this.parameters.path.toJSON(),t}}class Co extends En{constructor(t){if(super(),this.type="WireframeGeometry",!0===t.isGeometry)return void console.error("THREE.WireframeGeometry no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.");const e=[],n=[0,0],i={},r=new Lt;if(null!==t.index){const s=t.attributes.position,a=t.index;let o=t.groups;0===o.length&&(o=[{start:0,count:a.count,materialIndex:0}]);for(let t=0,e=o.length;t<e;++t){const e=o[t],r=e.start;for(let t=r,s=r+e.count;t<s;t+=3)for(let e=0;e<3;e++){const r=a.getX(t+e),s=a.getX(t+(e+1)%3);n[0]=Math.min(r,s),n[1]=Math.max(r,s);const o=n[0]+","+n[1];void 0===i[o]&&(i[o]={index1:n[0],index2:n[1]})}}for(const t in i){const n=i[t];r.fromBufferAttribute(s,n.index1),e.push(r.x,r.y,r.z),r.fromBufferAttribute(s,n.index2),e.push(r.x,r.y,r.z)}}else{const n=t.attributes.position;for(let t=0,i=n.count/3;t<i;t++)for(let i=0;i<3;i++){const s=3*t+i;r.fromBufferAttribute(n,s),e.push(r.x,r.y,r.z);const a=3*t+(i+1)%3;r.fromBufferAttribute(n,a),e.push(r.x,r.y,r.z)}}this.setAttribute("position",new mn(e,3))}}var Po=Object.freeze({__proto__:null,BoxGeometry:qn,BoxBufferGeometry:qn,CircleGeometry:Pa,CircleBufferGeometry:Pa,ConeGeometry:Ia,ConeBufferGeometry:Ia,CylinderGeometry:Da,CylinderBufferGeometry:Da,DodecahedronGeometry:Ba,DodecahedronBufferGeometry:Ba,EdgesGeometry:Ga,ExtrudeGeometry:go,ExtrudeBufferGeometry:go,IcosahedronGeometry:yo,IcosahedronBufferGeometry:yo,LatheGeometry:xo,LatheBufferGeometry:xo,OctahedronGeometry:_o,OctahedronBufferGeometry:_o,ParametricGeometry:wo,ParametricBufferGeometry:wo,PlaneGeometry:ci,PlaneBufferGeometry:ci,PolyhedronGeometry:Na,PolyhedronBufferGeometry:Na,RingGeometry:bo,RingBufferGeometry:bo,ShapeGeometry:Mo,ShapeBufferGeometry:Mo,SphereGeometry:So,SphereBufferGeometry:So,TetrahedronGeometry:To,TetrahedronBufferGeometry:To,TextGeometry:Eo,TextBufferGeometry:Eo,TorusGeometry:Ao,TorusBufferGeometry:Ao,TorusKnotGeometry:Lo,TorusKnotBufferGeometry:Lo,TubeGeometry:Ro,TubeBufferGeometry:Ro,WireframeGeometry:Co});class Do extends Xe{constructor(t){super(),this.type="ShadowMaterial",this.color=new tn(0),this.transparent=!0,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this}}Do.prototype.isShadowMaterial=!0;class Io extends Jn{constructor(t){super(t),this.type="RawShaderMaterial"}}Io.prototype.isRawShaderMaterial=!0;class No extends Xe{constructor(t){super(),this.defines={STANDARD:""},this.type="MeshStandardMaterial",this.color=new tn(16777215),this.roughness=1,this.metalness=0,this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new tn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new vt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.roughnessMap=null,this.metalnessMap=null,this.alphaMap=null,this.envMap=null,this.envMapIntensity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.vertexTangents=!1,this.setValues(t)}copy(t){return super.copy(t),this.defines={STANDARD:""},this.color.copy(t.color),this.roughness=t.roughness,this.metalness=t.metalness,this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.roughnessMap=t.roughnessMap,this.metalnessMap=t.metalnessMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.envMapIntensity=t.envMapIntensity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this.flatShading=t.flatShading,this.vertexTangents=t.vertexTangents,this}}No.prototype.isMeshStandardMaterial=!0;class Bo extends No{constructor(t){super(),this.defines={STANDARD:"",PHYSICAL:""},this.type="MeshPhysicalMaterial",this.clearcoat=0,this.clearcoatMap=null,this.clearcoatRoughness=0,this.clearcoatRoughnessMap=null,this.clearcoatNormalScale=new vt(1,1),this.clearcoatNormalMap=null,this.reflectivity=.5,Object.defineProperty(this,"ior",{get:function(){return(1+.4*this.reflectivity)/(1-.4*this.reflectivity)},set:function(t){this.reflectivity=ht(2.5*(t-1)/(t+1),0,1)}}),this.sheen=null,this.transmission=0,this.transmissionMap=null,this.setValues(t)}copy(t){return super.copy(t),this.defines={STANDARD:"",PHYSICAL:""},this.clearcoat=t.clearcoat,this.clearcoatMap=t.clearcoatMap,this.clearcoatRoughness=t.clearcoatRoughness,this.clearcoatRoughnessMap=t.clearcoatRoughnessMap,this.clearcoatNormalMap=t.clearcoatNormalMap,this.clearcoatNormalScale.copy(t.clearcoatNormalScale),this.reflectivity=t.reflectivity,t.sheen?this.sheen=(this.sheen||new tn).copy(t.sheen):this.sheen=null,this.transmission=t.transmission,this.transmissionMap=t.transmissionMap,this}}Bo.prototype.isMeshPhysicalMaterial=!0;class zo extends Xe{constructor(t){super(),this.type="MeshPhongMaterial",this.color=new tn(16777215),this.specular=new tn(1118481),this.shininess=30,this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new tn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new vt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.specular.copy(t.specular),this.shininess=t.shininess,this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.specularMap=t.specularMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.combine=t.combine,this.reflectivity=t.reflectivity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this.flatShading=t.flatShading,this}}zo.prototype.isMeshPhongMaterial=!0;class Fo extends Xe{constructor(t){super(),this.defines={TOON:""},this.type="MeshToonMaterial",this.color=new tn(16777215),this.map=null,this.gradientMap=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new tn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new vt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.alphaMap=null,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.gradientMap=t.gradientMap,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.alphaMap=t.alphaMap,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this}}Fo.prototype.isMeshToonMaterial=!0;class Oo extends Xe{constructor(t){super(),this.type="MeshNormalMaterial",this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new vt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this.flatShading=t.flatShading,this}}Oo.prototype.isMeshNormalMaterial=!0;class Ho extends Xe{constructor(t){super(),this.type="MeshLambertMaterial",this.color=new tn(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new tn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.specularMap=t.specularMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.combine=t.combine,this.reflectivity=t.reflectivity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this}}Ho.prototype.isMeshLambertMaterial=!0;class Go extends Xe{constructor(t){super(),this.defines={MATCAP:""},this.type="MeshMatcapMaterial",this.color=new tn(16777215),this.matcap=null,this.map=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new vt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.alphaMap=null,this.skinning=!1,this.morphTargets=!1,this.morphNormals=!1,this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.defines={MATCAP:""},this.color.copy(t.color),this.matcap=t.matcap,this.map=t.map,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.alphaMap=t.alphaMap,this.skinning=t.skinning,this.morphTargets=t.morphTargets,this.morphNormals=t.morphNormals,this.flatShading=t.flatShading,this}}Go.prototype.isMeshMatcapMaterial=!0;class Uo extends ca{constructor(t){super(),this.type="LineDashedMaterial",this.scale=1,this.dashSize=3,this.gapSize=1,this.setValues(t)}copy(t){return super.copy(t),this.scale=t.scale,this.dashSize=t.dashSize,this.gapSize=t.gapSize,this}}Uo.prototype.isLineDashedMaterial=!0;var ko=Object.freeze({__proto__:null,ShadowMaterial:Do,SpriteMaterial:Rs,RawShaderMaterial:Io,ShaderMaterial:Jn,PointsMaterial:_a,MeshPhysicalMaterial:Bo,MeshStandardMaterial:No,MeshPhongMaterial:zo,MeshToonMaterial:Fo,MeshNormalMaterial:Oo,MeshLambertMaterial:Ho,MeshDepthMaterial:cs,MeshDistanceMaterial:hs,MeshBasicMaterial:en,MeshMatcapMaterial:Go,LineDashedMaterial:Uo,LineBasicMaterial:ca,Material:Xe});const Vo={arraySlice:function(t,e,n){return Vo.isTypedArray(t)?new t.constructor(t.subarray(e,void 0!==n?n:t.length)):t.slice(e,n)},convertArray:function(t,e,n){return!t||!n&&t.constructor===e?t:"number"==typeof e.BYTES_PER_ELEMENT?new e(t):Array.prototype.slice.call(t)},isTypedArray:function(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)},getKeyframeOrder:function(t){const e=t.length,n=new Array(e);for(let t=0;t!==e;++t)n[t]=t;return n.sort((function(e,n){return t[e]-t[n]})),n},sortedArray:function(t,e,n){const i=t.length,r=new t.constructor(i);for(let s=0,a=0;a!==i;++s){const i=n[s]*e;for(let n=0;n!==e;++n)r[a++]=t[i+n]}return r},flattenJSON:function(t,e,n,i){let r=1,s=t[0];for(;void 0!==s&&void 0===s[i];)s=t[r++];if(void 0===s)return;let a=s[i];if(void 0!==a)if(Array.isArray(a))do{a=s[i],void 0!==a&&(e.push(s.time),n.push.apply(n,a)),s=t[r++]}while(void 0!==s);else if(void 0!==a.toArray)do{a=s[i],void 0!==a&&(e.push(s.time),a.toArray(n,n.length)),s=t[r++]}while(void 0!==s);else do{a=s[i],void 0!==a&&(e.push(s.time),n.push(a)),s=t[r++]}while(void 0!==s)},subclip:function(t,e,n,i,r=30){const s=t.clone();s.name=e;const a=[];for(let t=0;t<s.tracks.length;++t){const e=s.tracks[t],o=e.getValueSize(),l=[],c=[];for(let t=0;t<e.times.length;++t){const s=e.times[t]*r;if(!(s<n||s>=i)){l.push(e.times[t]);for(let n=0;n<o;++n)c.push(e.values[t*o+n])}}0!==l.length&&(e.times=Vo.convertArray(l,e.times.constructor),e.values=Vo.convertArray(c,e.values.constructor),a.push(e))}s.tracks=a;let o=1/0;for(let t=0;t<s.tracks.length;++t)o>s.tracks[t].times[0]&&(o=s.tracks[t].times[0]);for(let t=0;t<s.tracks.length;++t)s.tracks[t].shift(-1*o);return s.resetDuration(),s},makeClipAdditive:function(t,e=0,n=t,i=30){i<=0&&(i=30);const r=n.tracks.length,s=e/i;for(let e=0;e<r;++e){const i=n.tracks[e],r=i.ValueTypeName;if("bool"===r||"string"===r)continue;const a=t.tracks.find((function(t){return t.name===i.name&&t.ValueTypeName===r}));if(void 0===a)continue;let o=0;const l=i.getValueSize();i.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline&&(o=l/3);let c=0;const h=a.getValueSize();a.createInterpolant.isInterpolantFactoryMethodGLTFCubicSpline&&(c=h/3);const u=i.times.length-1;let d;if(s<=i.times[0]){const t=o,e=l-o;d=Vo.arraySlice(i.values,t,e)}else if(s>=i.times[u]){const t=u*l+o,e=t+l-o;d=Vo.arraySlice(i.values,t,e)}else{const t=i.createInterpolant(),e=o,n=l-o;t.evaluate(s),d=Vo.arraySlice(t.resultBuffer,e,n)}if("quaternion"===r){(new At).fromArray(d).normalize().conjugate().toArray(d)}const p=a.times.length;for(let t=0;t<p;++t){const e=t*h+c;if("quaternion"===r)At.multiplyQuaternionsFlat(a.values,e,d,0,a.values,e);else{const t=h-2*c;for(let n=0;n<t;++n)a.values[e+n]-=d[n]}}}return t.blendMode=q,t}};class Wo{constructor(t,e,n,i){this.parameterPositions=t,this._cachedIndex=0,this.resultBuffer=void 0!==i?i:new e.constructor(n),this.sampleValues=e,this.valueSize=n,this.settings=null,this.DefaultSettings_={}}evaluate(t){const e=this.parameterPositions;let n=this._cachedIndex,i=e[n],r=e[n-1];t:{e:{let s;n:{i:if(!(t<i)){for(let s=n+2;;){if(void 0===i){if(t<r)break i;return n=e.length,this._cachedIndex=n,this.afterEnd_(n-1,t,r)}if(n===s)break;if(r=i,i=e[++n],t<i)break e}s=e.length;break n}if(t>=r)break t;{const a=e[1];t<a&&(n=2,r=a);for(let s=n-2;;){if(void 0===r)return this._cachedIndex=0,this.beforeStart_(0,t,i);if(n===s)break;if(i=r,r=e[--n-1],t>=r)break e}s=n,n=0}}for(;n<s;){const i=n+s>>>1;t<e[i]?s=i:n=i+1}if(i=e[n],r=e[n-1],void 0===r)return this._cachedIndex=0,this.beforeStart_(0,t,i);if(void 0===i)return n=e.length,this._cachedIndex=n,this.afterEnd_(n-1,r,t)}this._cachedIndex=n,this.intervalChanged_(n,r,i)}return this.interpolate_(n,r,t,i)}getSettings_(){return this.settings||this.DefaultSettings_}copySampleValue_(t){const e=this.resultBuffer,n=this.sampleValues,i=this.valueSize,r=t*i;for(let t=0;t!==i;++t)e[t]=n[r+t];return e}interpolate_(){throw new Error("call to abstract method")}intervalChanged_(){}}Wo.prototype.beforeStart_=Wo.prototype.copySampleValue_,Wo.prototype.afterEnd_=Wo.prototype.copySampleValue_;class jo extends Wo{constructor(t,e,n,i){super(t,e,n,i),this._weightPrev=-0,this._offsetPrev=-0,this._weightNext=-0,this._offsetNext=-0,this.DefaultSettings_={endingStart:k,endingEnd:k}}intervalChanged_(t,e,n){const i=this.parameterPositions;let r=t-2,s=t+1,a=i[r],o=i[s];if(void 0===a)switch(this.getSettings_().endingStart){case V:r=t,a=2*e-n;break;case W:r=i.length-2,a=e+i[r]-i[r+1];break;default:r=t,a=n}if(void 0===o)switch(this.getSettings_().endingEnd){case V:s=t,o=2*n-e;break;case W:s=1,o=n+i[1]-i[0];break;default:s=t-1,o=e}const l=.5*(n-e),c=this.valueSize;this._weightPrev=l/(e-a),this._weightNext=l/(o-n),this._offsetPrev=r*c,this._offsetNext=s*c}interpolate_(t,e,n,i){const r=this.resultBuffer,s=this.sampleValues,a=this.valueSize,o=t*a,l=o-a,c=this._offsetPrev,h=this._offsetNext,u=this._weightPrev,d=this._weightNext,p=(n-e)/(i-e),m=p*p,f=m*p,g=-u*f+2*u*m-u*p,v=(1+u)*f+(-1.5-2*u)*m+(-.5+u)*p+1,y=(-1-d)*f+(1.5+d)*m+.5*p,x=d*f-d*m;for(let t=0;t!==a;++t)r[t]=g*s[c+t]+v*s[l+t]+y*s[o+t]+x*s[h+t];return r}}class qo extends Wo{constructor(t,e,n,i){super(t,e,n,i)}interpolate_(t,e,n,i){const r=this.resultBuffer,s=this.sampleValues,a=this.valueSize,o=t*a,l=o-a,c=(n-e)/(i-e),h=1-c;for(let t=0;t!==a;++t)r[t]=s[l+t]*h+s[o+t]*c;return r}}class Xo extends Wo{constructor(t,e,n,i){super(t,e,n,i)}interpolate_(t){return this.copySampleValue_(t-1)}}class Yo{constructor(t,e,n,i){if(void 0===t)throw new Error("THREE.KeyframeTrack: track name is undefined");if(void 0===e||0===e.length)throw new Error("THREE.KeyframeTrack: no keyframes in track named "+t);this.name=t,this.times=Vo.convertArray(e,this.TimeBufferType),this.values=Vo.convertArray(n,this.ValueBufferType),this.setInterpolation(i||this.DefaultInterpolation)}static toJSON(t){const e=t.constructor;let n;if(e.toJSON!==this.toJSON)n=e.toJSON(t);else{n={name:t.name,times:Vo.convertArray(t.times,Array),values:Vo.convertArray(t.values,Array)};const e=t.getInterpolation();e!==t.DefaultInterpolation&&(n.interpolation=e)}return n.type=t.ValueTypeName,n}InterpolantFactoryMethodDiscrete(t){return new Xo(this.times,this.values,this.getValueSize(),t)}InterpolantFactoryMethodLinear(t){return new qo(this.times,this.values,this.getValueSize(),t)}InterpolantFactoryMethodSmooth(t){return new jo(this.times,this.values,this.getValueSize(),t)}setInterpolation(t){let e;switch(t){case H:e=this.InterpolantFactoryMethodDiscrete;break;case G:e=this.InterpolantFactoryMethodLinear;break;case U:e=this.InterpolantFactoryMethodSmooth}if(void 0===e){const e="unsupported interpolation for "+this.ValueTypeName+" keyframe track named "+this.name;if(void 0===this.createInterpolant){if(t===this.DefaultInterpolation)throw new Error(e);this.setInterpolation(this.DefaultInterpolation)}return console.warn("THREE.KeyframeTrack:",e),this}return this.createInterpolant=e,this}getInterpolation(){switch(this.createInterpolant){case this.InterpolantFactoryMethodDiscrete:return H;case this.InterpolantFactoryMethodLinear:return G;case this.InterpolantFactoryMethodSmooth:return U}}getValueSize(){return this.values.length/this.times.length}shift(t){if(0!==t){const e=this.times;for(let n=0,i=e.length;n!==i;++n)e[n]+=t}return this}scale(t){if(1!==t){const e=this.times;for(let n=0,i=e.length;n!==i;++n)e[n]*=t}return this}trim(t,e){const n=this.times,i=n.length;let r=0,s=i-1;for(;r!==i&&n[r]<t;)++r;for(;-1!==s&&n[s]>e;)--s;if(++s,0!==r||s!==i){r>=s&&(s=Math.max(s,1),r=s-1);const t=this.getValueSize();this.times=Vo.arraySlice(n,r,s),this.values=Vo.arraySlice(this.values,r*t,s*t)}return this}validate(){let t=!0;const e=this.getValueSize();e-Math.floor(e)!=0&&(console.error("THREE.KeyframeTrack: Invalid value size in track.",this),t=!1);const n=this.times,i=this.values,r=n.length;0===r&&(console.error("THREE.KeyframeTrack: Track is empty.",this),t=!1);let s=null;for(let e=0;e!==r;e++){const i=n[e];if("number"==typeof i&&isNaN(i)){console.error("THREE.KeyframeTrack: Time is not a valid number.",this,e,i),t=!1;break}if(null!==s&&s>i){console.error("THREE.KeyframeTrack: Out of order keys.",this,e,i,s),t=!1;break}s=i}if(void 0!==i&&Vo.isTypedArray(i))for(let e=0,n=i.length;e!==n;++e){const n=i[e];if(isNaN(n)){console.error("THREE.KeyframeTrack: Value is not a valid number.",this,e,n),t=!1;break}}return t}optimize(){const t=Vo.arraySlice(this.times),e=Vo.arraySlice(this.values),n=this.getValueSize(),i=this.getInterpolation()===U,r=t.length-1;let s=1;for(let a=1;a<r;++a){let r=!1;const o=t[a];if(o!==t[a+1]&&(1!==a||o!==t[0]))if(i)r=!0;else{const t=a*n,i=t-n,s=t+n;for(let a=0;a!==n;++a){const n=e[t+a];if(n!==e[i+a]||n!==e[s+a]){r=!0;break}}}if(r){if(a!==s){t[s]=t[a];const i=a*n,r=s*n;for(let t=0;t!==n;++t)e[r+t]=e[i+t]}++s}}if(r>0){t[s]=t[r];for(let t=r*n,i=s*n,a=0;a!==n;++a)e[i+a]=e[t+a];++s}return s!==t.length?(this.times=Vo.arraySlice(t,0,s),this.values=Vo.arraySlice(e,0,s*n)):(this.times=t,this.values=e),this}clone(){const t=Vo.arraySlice(this.times,0),e=Vo.arraySlice(this.values,0),n=new(0,this.constructor)(this.name,t,e);return n.createInterpolant=this.createInterpolant,n}}Yo.prototype.TimeBufferType=Float32Array,Yo.prototype.ValueBufferType=Float32Array,Yo.prototype.DefaultInterpolation=G;class Zo extends Yo{}Zo.prototype.ValueTypeName="bool",Zo.prototype.ValueBufferType=Array,Zo.prototype.DefaultInterpolation=H,Zo.prototype.InterpolantFactoryMethodLinear=void 0,Zo.prototype.InterpolantFactoryMethodSmooth=void 0;class Jo extends Yo{}Jo.prototype.ValueTypeName="color";class Qo extends Yo{}Qo.prototype.ValueTypeName="number";class Ko extends Wo{constructor(t,e,n,i){super(t,e,n,i)}interpolate_(t,e,n,i){const r=this.resultBuffer,s=this.sampleValues,a=this.valueSize,o=(n-e)/(i-e);let l=t*a;for(let t=l+a;l!==t;l+=4)At.slerpFlat(r,0,s,l-a,s,l,o);return r}}class $o extends Yo{InterpolantFactoryMethodLinear(t){return new Ko(this.times,this.values,this.getValueSize(),t)}}$o.prototype.ValueTypeName="quaternion",$o.prototype.DefaultInterpolation=G,$o.prototype.InterpolantFactoryMethodSmooth=void 0;class tl extends Yo{}tl.prototype.ValueTypeName="string",tl.prototype.ValueBufferType=Array,tl.prototype.DefaultInterpolation=H,tl.prototype.InterpolantFactoryMethodLinear=void 0,tl.prototype.InterpolantFactoryMethodSmooth=void 0;class el extends Yo{}el.prototype.ValueTypeName="vector";class nl{constructor(t,e=-1,n,i=2500){this.name=t,this.tracks=n,this.duration=e,this.blendMode=i,this.uuid=ct(),this.duration<0&&this.resetDuration()}static parse(t){const e=[],n=t.tracks,i=1/(t.fps||1);for(let t=0,r=n.length;t!==r;++t)e.push(il(n[t]).scale(i));const r=new this(t.name,t.duration,e,t.blendMode);return r.uuid=t.uuid,r}static toJSON(t){const e=[],n=t.tracks,i={name:t.name,duration:t.duration,tracks:e,uuid:t.uuid,blendMode:t.blendMode};for(let t=0,i=n.length;t!==i;++t)e.push(Yo.toJSON(n[t]));return i}static CreateFromMorphTargetSequence(t,e,n,i){const r=e.length,s=[];for(let t=0;t<r;t++){let a=[],o=[];a.push((t+r-1)%r,t,(t+1)%r),o.push(0,1,0);const l=Vo.getKeyframeOrder(a);a=Vo.sortedArray(a,1,l),o=Vo.sortedArray(o,1,l),i||0!==a[0]||(a.push(r),o.push(o[0])),s.push(new Qo(".morphTargetInfluences["+e[t].name+"]",a,o).scale(1/n))}return new this(t,-1,s)}static findByName(t,e){let n=t;if(!Array.isArray(t)){const e=t;n=e.geometry&&e.geometry.animations||e.animations}for(let t=0;t<n.length;t++)if(n[t].name===e)return n[t];return null}static CreateClipsFromMorphTargetSequences(t,e,n){const i={},r=/^([\w-]*?)([\d]+)$/;for(let e=0,n=t.length;e<n;e++){const n=t[e],s=n.name.match(r);if(s&&s.length>1){const t=s[1];let e=i[t];e||(i[t]=e=[]),e.push(n)}}const s=[];for(const t in i)s.push(this.CreateFromMorphTargetSequence(t,i[t],e,n));return s}static parseAnimation(t,e){if(!t)return console.error("THREE.AnimationClip: No animation in JSONLoader data."),null;const n=function(t,e,n,i,r){if(0!==n.length){const s=[],a=[];Vo.flattenJSON(n,s,a,i),0!==s.length&&r.push(new t(e,s,a))}},i=[],r=t.name||"default",s=t.fps||30,a=t.blendMode;let o=t.length||-1;const l=t.hierarchy||[];for(let t=0;t<l.length;t++){const r=l[t].keys;if(r&&0!==r.length)if(r[0].morphTargets){const t={};let e;for(e=0;e<r.length;e++)if(r[e].morphTargets)for(let n=0;n<r[e].morphTargets.length;n++)t[r[e].morphTargets[n]]=-1;for(const n in t){const t=[],s=[];for(let i=0;i!==r[e].morphTargets.length;++i){const i=r[e];t.push(i.time),s.push(i.morphTarget===n?1:0)}i.push(new Qo(".morphTargetInfluence["+n+"]",t,s))}o=t.length*(s||1)}else{const s=".bones["+e[t].name+"]";n(el,s+".position",r,"pos",i),n($o,s+".quaternion",r,"rot",i),n(el,s+".scale",r,"scl",i)}}if(0===i.length)return null;return new this(r,o,i,a)}resetDuration(){let t=0;for(let e=0,n=this.tracks.length;e!==n;++e){const n=this.tracks[e];t=Math.max(t,n.times[n.times.length-1])}return this.duration=t,this}trim(){for(let t=0;t<this.tracks.length;t++)this.tracks[t].trim(0,this.duration);return this}validate(){let t=!0;for(let e=0;e<this.tracks.length;e++)t=t&&this.tracks[e].validate();return t}optimize(){for(let t=0;t<this.tracks.length;t++)this.tracks[t].optimize();return this}clone(){const t=[];for(let e=0;e<this.tracks.length;e++)t.push(this.tracks[e].clone());return new this.constructor(this.name,this.duration,t,this.blendMode)}toJSON(){return this.constructor.toJSON(this)}}function il(t){if(void 0===t.type)throw new Error("THREE.KeyframeTrack: track type undefined, can not parse");const e=function(t){switch(t.toLowerCase()){case"scalar":case"double":case"float":case"number":case"integer":return Qo;case"vector":case"vector2":case"vector3":case"vector4":return el;case"color":return Jo;case"quaternion":return $o;case"bool":case"boolean":return Zo;case"string":return tl}throw new Error("THREE.KeyframeTrack: Unsupported typeName: "+t)}(t.type);if(void 0===t.times){const e=[],n=[];Vo.flattenJSON(t.keys,e,n,"value"),t.times=e,t.values=n}return void 0!==e.parse?e.parse(t):new e(t.name,t.times,t.values,t.interpolation)}const rl={enabled:!1,files:{},add:function(t,e){!1!==this.enabled&&(this.files[t]=e)},get:function(t){if(!1!==this.enabled)return this.files[t]},remove:function(t){delete this.files[t]},clear:function(){this.files={}}};class sl{constructor(t,e,n){const i=this;let r,s=!1,a=0,o=0;const l=[];this.onStart=void 0,this.onLoad=t,this.onProgress=e,this.onError=n,this.itemStart=function(t){o++,!1===s&&void 0!==i.onStart&&i.onStart(t,a,o),s=!0},this.itemEnd=function(t){a++,void 0!==i.onProgress&&i.onProgress(t,a,o),a===o&&(s=!1,void 0!==i.onLoad&&i.onLoad())},this.itemError=function(t){void 0!==i.onError&&i.onError(t)},this.resolveURL=function(t){return r?r(t):t},this.setURLModifier=function(t){return r=t,this},this.addHandler=function(t,e){return l.push(t,e),this},this.removeHandler=function(t){const e=l.indexOf(t);return-1!==e&&l.splice(e,2),this},this.getHandler=function(t){for(let e=0,n=l.length;e<n;e+=2){const n=l[e],i=l[e+1];if(n.global&&(n.lastIndex=0),n.test(t))return i}return null}}}const al=new sl;class ol{constructor(t){this.manager=void 0!==t?t:al,this.crossOrigin="anonymous",this.withCredentials=!1,this.path="",this.resourcePath="",this.requestHeader={}}load(){}loadAsync(t,e){const n=this;return new Promise((function(i,r){n.load(t,i,e,r)}))}parse(){}setCrossOrigin(t){return this.crossOrigin=t,this}setWithCredentials(t){return this.withCredentials=t,this}setPath(t){return this.path=t,this}setResourcePath(t){return this.resourcePath=t,this}setRequestHeader(t){return this.requestHeader=t,this}}const ll={};class cl extends ol{constructor(t){super(t)}load(t,e,n,i){void 0===t&&(t=""),void 0!==this.path&&(t=this.path+t),t=this.manager.resolveURL(t);const r=this,s=rl.get(t);if(void 0!==s)return r.manager.itemStart(t),setTimeout((function(){e&&e(s),r.manager.itemEnd(t)}),0),s;if(void 0!==ll[t])return void ll[t].push({onLoad:e,onProgress:n,onError:i});const a=t.match(/^data:(.*?)(;base64)?,(.*)$/);let o;if(a){const n=a[1],s=!!a[2];let o=a[3];o=decodeURIComponent(o),s&&(o=atob(o));try{let i;const s=(this.responseType||"").toLowerCase();switch(s){case"arraybuffer":case"blob":const t=new Uint8Array(o.length);for(let e=0;e<o.length;e++)t[e]=o.charCodeAt(e);i="blob"===s?new Blob([t.buffer],{type:n}):t.buffer;break;case"document":const e=new DOMParser;i=e.parseFromString(o,n);break;case"json":i=JSON.parse(o);break;default:i=o}setTimeout((function(){e&&e(i),r.manager.itemEnd(t)}),0)}catch(e){setTimeout((function(){i&&i(e),r.manager.itemError(t),r.manager.itemEnd(t)}),0)}}else{ll[t]=[],ll[t].push({onLoad:e,onProgress:n,onError:i}),o=new XMLHttpRequest,o.open("GET",t,!0),o.addEventListener("load",(function(e){const n=this.response,i=ll[t];if(delete ll[t],200===this.status||0===this.status){0===this.status&&console.warn("THREE.FileLoader: HTTP Status 0 received."),rl.add(t,n);for(let t=0,e=i.length;t<e;t++){const e=i[t];e.onLoad&&e.onLoad(n)}r.manager.itemEnd(t)}else{for(let t=0,n=i.length;t<n;t++){const n=i[t];n.onError&&n.onError(e)}r.manager.itemError(t),r.manager.itemEnd(t)}}),!1),o.addEventListener("progress",(function(e){const n=ll[t];for(let t=0,i=n.length;t<i;t++){const i=n[t];i.onProgress&&i.onProgress(e)}}),!1),o.addEventListener("error",(function(e){const n=ll[t];delete ll[t];for(let t=0,i=n.length;t<i;t++){const i=n[t];i.onError&&i.onError(e)}r.manager.itemError(t),r.manager.itemEnd(t)}),!1),o.addEventListener("abort",(function(e){const n=ll[t];delete ll[t];for(let t=0,i=n.length;t<i;t++){const i=n[t];i.onError&&i.onError(e)}r.manager.itemError(t),r.manager.itemEnd(t)}),!1),void 0!==this.responseType&&(o.responseType=this.responseType),void 0!==this.withCredentials&&(o.withCredentials=this.withCredentials),o.overrideMimeType&&o.overrideMimeType(void 0!==this.mimeType?this.mimeType:"text/plain");for(const t in this.requestHeader)o.setRequestHeader(t,this.requestHeader[t]);o.send(null)}return r.manager.itemStart(t),o}setResponseType(t){return this.responseType=t,this}setMimeType(t){return this.mimeType=t,this}}class hl extends ol{constructor(t){super(t)}load(t,e,n,i){void 0!==this.path&&(t=this.path+t),t=this.manager.resolveURL(t);const r=this,s=rl.get(t);if(void 0!==s)return r.manager.itemStart(t),setTimeout((function(){e&&e(s),r.manager.itemEnd(t)}),0),s;const a=document.createElementNS("http://www.w3.org/1999/xhtml","img");function o(){a.removeEventListener("load",o,!1),a.removeEventListener("error",l,!1),rl.add(t,this),e&&e(this),r.manager.itemEnd(t)}function l(e){a.removeEventListener("load",o,!1),a.removeEventListener("error",l,!1),i&&i(e),r.manager.itemError(t),r.manager.itemEnd(t)}return a.addEventListener("load",o,!1),a.addEventListener("error",l,!1),"data:"!==t.substr(0,5)&&void 0!==this.crossOrigin&&(a.crossOrigin=this.crossOrigin),r.manager.itemStart(t),a.src=t,a}}class ul extends ol{constructor(t){super(t)}load(t,e,n,i){const r=new ei,s=new hl(this.manager);s.setCrossOrigin(this.crossOrigin),s.setPath(this.path);let a=0;function o(n){s.load(t[n],(function(t){r.images[n]=t,a++,6===a&&(r.needsUpdate=!0,e&&e(r))}),void 0,i)}for(let e=0;e<t.length;++e)o(e);return r}}class dl extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=new ii,a=new cl(this.manager);return a.setResponseType("arraybuffer"),a.setRequestHeader(this.requestHeader),a.setPath(this.path),a.setWithCredentials(r.withCredentials),a.load(t,(function(t){const n=r.parse(t);n&&(void 0!==n.image?s.image=n.image:void 0!==n.data&&(s.image.width=n.width,s.image.height=n.height,s.image.data=n.data),s.wrapS=void 0!==n.wrapS?n.wrapS:u,s.wrapT=void 0!==n.wrapT?n.wrapT:u,s.magFilter=void 0!==n.magFilter?n.magFilter:g,s.minFilter=void 0!==n.minFilter?n.minFilter:g,s.anisotropy=void 0!==n.anisotropy?n.anisotropy:1,void 0!==n.encoding&&(s.encoding=n.encoding),void 0!==n.flipY&&(s.flipY=n.flipY),void 0!==n.format&&(s.format=n.format),void 0!==n.type&&(s.type=n.type),void 0!==n.mipmaps&&(s.mipmaps=n.mipmaps,s.minFilter=y),1===n.mipmapCount&&(s.minFilter=g),void 0!==n.generateMipmaps&&(s.generateMipmaps=n.generateMipmaps),s.needsUpdate=!0,e&&e(s,n))}),n,i),s}}class pl extends ol{constructor(t){super(t)}load(t,e,n,i){const r=new bt,s=new hl(this.manager);return s.setCrossOrigin(this.crossOrigin),s.setPath(this.path),s.load(t,(function(n){r.image=n;const i=t.search(/\.jpe?g($|\?)/i)>0||0===t.search(/^data\:image\/jpeg/);r.format=i?T:E,r.needsUpdate=!0,void 0!==e&&e(r)}),n,i),r}}class ml{constructor(){this.type="Curve",this.arcLengthDivisions=200}getPoint(){return console.warn("THREE.Curve: .getPoint() not implemented."),null}getPointAt(t,e){const n=this.getUtoTmapping(t);return this.getPoint(n,e)}getPoints(t=5){const e=[];for(let n=0;n<=t;n++)e.push(this.getPoint(n/t));return e}getSpacedPoints(t=5){const e=[];for(let n=0;n<=t;n++)e.push(this.getPointAt(n/t));return e}getLength(){const t=this.getLengths();return t[t.length-1]}getLengths(t=this.arcLengthDivisions){if(this.cacheArcLengths&&this.cacheArcLengths.length===t+1&&!this.needsUpdate)return this.cacheArcLengths;this.needsUpdate=!1;const e=[];let n,i=this.getPoint(0),r=0;e.push(0);for(let s=1;s<=t;s++)n=this.getPoint(s/t),r+=n.distanceTo(i),e.push(r),i=n;return this.cacheArcLengths=e,e}updateArcLengths(){this.needsUpdate=!0,this.getLengths()}getUtoTmapping(t,e){const n=this.getLengths();let i=0;const r=n.length;let s;s=e||t*n[r-1];let a,o=0,l=r-1;for(;o<=l;)if(i=Math.floor(o+(l-o)/2),a=n[i]-s,a<0)o=i+1;else{if(!(a>0)){l=i;break}l=i-1}if(i=l,n[i]===s)return i/(r-1);const c=n[i];return(i+(s-c)/(n[i+1]-c))/(r-1)}getTangent(t,e){const n=1e-4;let i=t-n,r=t+n;i<0&&(i=0),r>1&&(r=1);const s=this.getPoint(i),a=this.getPoint(r),o=e||(s.isVector2?new vt:new Lt);return o.copy(a).sub(s).normalize(),o}getTangentAt(t,e){const n=this.getUtoTmapping(t);return this.getTangent(n,e)}computeFrenetFrames(t,e){const n=new Lt,i=[],r=[],s=[],a=new Lt,o=new se;for(let e=0;e<=t;e++){const n=e/t;i[e]=this.getTangentAt(n,new Lt),i[e].normalize()}r[0]=new Lt,s[0]=new Lt;let l=Number.MAX_VALUE;const c=Math.abs(i[0].x),h=Math.abs(i[0].y),u=Math.abs(i[0].z);c<=l&&(l=c,n.set(1,0,0)),h<=l&&(l=h,n.set(0,1,0)),u<=l&&n.set(0,0,1),a.crossVectors(i[0],n).normalize(),r[0].crossVectors(i[0],a),s[0].crossVectors(i[0],r[0]);for(let e=1;e<=t;e++){if(r[e]=r[e-1].clone(),s[e]=s[e-1].clone(),a.crossVectors(i[e-1],i[e]),a.length()>Number.EPSILON){a.normalize();const t=Math.acos(ht(i[e-1].dot(i[e]),-1,1));r[e].applyMatrix4(o.makeRotationAxis(a,t))}s[e].crossVectors(i[e],r[e])}if(!0===e){let e=Math.acos(ht(r[0].dot(r[t]),-1,1));e/=t,i[0].dot(a.crossVectors(r[0],r[t]))>0&&(e=-e);for(let n=1;n<=t;n++)r[n].applyMatrix4(o.makeRotationAxis(i[n],e*n)),s[n].crossVectors(i[n],r[n])}return{tangents:i,normals:r,binormals:s}}clone(){return(new this.constructor).copy(this)}copy(t){return this.arcLengthDivisions=t.arcLengthDivisions,this}toJSON(){const t={metadata:{version:4.5,type:"Curve",generator:"Curve.toJSON"}};return t.arcLengthDivisions=this.arcLengthDivisions,t.type=this.type,t}fromJSON(t){return this.arcLengthDivisions=t.arcLengthDivisions,this}}class fl extends ml{constructor(t=0,e=0,n=1,i=1,r=0,s=2*Math.PI,a=!1,o=0){super(),this.type="EllipseCurve",this.aX=t,this.aY=e,this.xRadius=n,this.yRadius=i,this.aStartAngle=r,this.aEndAngle=s,this.aClockwise=a,this.aRotation=o}getPoint(t,e){const n=e||new vt,i=2*Math.PI;let r=this.aEndAngle-this.aStartAngle;const s=Math.abs(r)<Number.EPSILON;for(;r<0;)r+=i;for(;r>i;)r-=i;r<Number.EPSILON&&(r=s?0:i),!0!==this.aClockwise||s||(r===i?r=-i:r-=i);const a=this.aStartAngle+t*r;let o=this.aX+this.xRadius*Math.cos(a),l=this.aY+this.yRadius*Math.sin(a);if(0!==this.aRotation){const t=Math.cos(this.aRotation),e=Math.sin(this.aRotation),n=o-this.aX,i=l-this.aY;o=n*t-i*e+this.aX,l=n*e+i*t+this.aY}return n.set(o,l)}copy(t){return super.copy(t),this.aX=t.aX,this.aY=t.aY,this.xRadius=t.xRadius,this.yRadius=t.yRadius,this.aStartAngle=t.aStartAngle,this.aEndAngle=t.aEndAngle,this.aClockwise=t.aClockwise,this.aRotation=t.aRotation,this}toJSON(){const t=super.toJSON();return t.aX=this.aX,t.aY=this.aY,t.xRadius=this.xRadius,t.yRadius=this.yRadius,t.aStartAngle=this.aStartAngle,t.aEndAngle=this.aEndAngle,t.aClockwise=this.aClockwise,t.aRotation=this.aRotation,t}fromJSON(t){return super.fromJSON(t),this.aX=t.aX,this.aY=t.aY,this.xRadius=t.xRadius,this.yRadius=t.yRadius,this.aStartAngle=t.aStartAngle,this.aEndAngle=t.aEndAngle,this.aClockwise=t.aClockwise,this.aRotation=t.aRotation,this}}fl.prototype.isEllipseCurve=!0;class gl extends fl{constructor(t,e,n,i,r,s){super(t,e,n,n,i,r,s),this.type="ArcCurve"}}function vl(){let t=0,e=0,n=0,i=0;function r(r,s,a,o){t=r,e=a,n=-3*r+3*s-2*a-o,i=2*r-2*s+a+o}return{initCatmullRom:function(t,e,n,i,s){r(e,n,s*(n-t),s*(i-e))},initNonuniformCatmullRom:function(t,e,n,i,s,a,o){let l=(e-t)/s-(n-t)/(s+a)+(n-e)/a,c=(n-e)/a-(i-e)/(a+o)+(i-n)/o;l*=a,c*=a,r(e,n,l,c)},calc:function(r){const s=r*r;return t+e*r+n*s+i*(s*r)}}}gl.prototype.isArcCurve=!0;const yl=new Lt,xl=new vl,_l=new vl,wl=new vl;class bl extends ml{constructor(t=[],e=!1,n="centripetal",i=.5){super(),this.type="CatmullRomCurve3",this.points=t,this.closed=e,this.curveType=n,this.tension=i}getPoint(t,e=new Lt){const n=e,i=this.points,r=i.length,s=(r-(this.closed?0:1))*t;let a,o,l=Math.floor(s),c=s-l;this.closed?l+=l>0?0:(Math.floor(Math.abs(l)/r)+1)*r:0===c&&l===r-1&&(l=r-2,c=1),this.closed||l>0?a=i[(l-1)%r]:(yl.subVectors(i[0],i[1]).add(i[0]),a=yl);const h=i[l%r],u=i[(l+1)%r];if(this.closed||l+2<r?o=i[(l+2)%r]:(yl.subVectors(i[r-1],i[r-2]).add(i[r-1]),o=yl),"centripetal"===this.curveType||"chordal"===this.curveType){const t="chordal"===this.curveType?.5:.25;let e=Math.pow(a.distanceToSquared(h),t),n=Math.pow(h.distanceToSquared(u),t),i=Math.pow(u.distanceToSquared(o),t);n<1e-4&&(n=1),e<1e-4&&(e=n),i<1e-4&&(i=n),xl.initNonuniformCatmullRom(a.x,h.x,u.x,o.x,e,n,i),_l.initNonuniformCatmullRom(a.y,h.y,u.y,o.y,e,n,i),wl.initNonuniformCatmullRom(a.z,h.z,u.z,o.z,e,n,i)}else"catmullrom"===this.curveType&&(xl.initCatmullRom(a.x,h.x,u.x,o.x,this.tension),_l.initCatmullRom(a.y,h.y,u.y,o.y,this.tension),wl.initCatmullRom(a.z,h.z,u.z,o.z,this.tension));return n.set(xl.calc(c),_l.calc(c),wl.calc(c)),n}copy(t){super.copy(t),this.points=[];for(let e=0,n=t.points.length;e<n;e++){const n=t.points[e];this.points.push(n.clone())}return this.closed=t.closed,this.curveType=t.curveType,this.tension=t.tension,this}toJSON(){const t=super.toJSON();t.points=[];for(let e=0,n=this.points.length;e<n;e++){const n=this.points[e];t.points.push(n.toArray())}return t.closed=this.closed,t.curveType=this.curveType,t.tension=this.tension,t}fromJSON(t){super.fromJSON(t),this.points=[];for(let e=0,n=t.points.length;e<n;e++){const n=t.points[e];this.points.push((new Lt).fromArray(n))}return this.closed=t.closed,this.curveType=t.curveType,this.tension=t.tension,this}}function Ml(t,e,n,i,r){const s=.5*(i-e),a=.5*(r-n),o=t*t;return(2*n-2*i+s+a)*(t*o)+(-3*n+3*i-2*s-a)*o+s*t+n}function Sl(t,e,n,i){return function(t,e){const n=1-t;return n*n*e}(t,e)+function(t,e){return 2*(1-t)*t*e}(t,n)+function(t,e){return t*t*e}(t,i)}function Tl(t,e,n,i,r){return function(t,e){const n=1-t;return n*n*n*e}(t,e)+function(t,e){const n=1-t;return 3*n*n*t*e}(t,n)+function(t,e){return 3*(1-t)*t*t*e}(t,i)+function(t,e){return t*t*t*e}(t,r)}bl.prototype.isCatmullRomCurve3=!0;class El extends ml{constructor(t=new vt,e=new vt,n=new vt,i=new vt){super(),this.type="CubicBezierCurve",this.v0=t,this.v1=e,this.v2=n,this.v3=i}getPoint(t,e=new vt){const n=e,i=this.v0,r=this.v1,s=this.v2,a=this.v3;return n.set(Tl(t,i.x,r.x,s.x,a.x),Tl(t,i.y,r.y,s.y,a.y)),n}copy(t){return super.copy(t),this.v0.copy(t.v0),this.v1.copy(t.v1),this.v2.copy(t.v2),this.v3.copy(t.v3),this}toJSON(){const t=super.toJSON();return t.v0=this.v0.toArray(),t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t.v3=this.v3.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v0.fromArray(t.v0),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this.v3.fromArray(t.v3),this}}El.prototype.isCubicBezierCurve=!0;class Al extends ml{constructor(t=new Lt,e=new Lt,n=new Lt,i=new Lt){super(),this.type="CubicBezierCurve3",this.v0=t,this.v1=e,this.v2=n,this.v3=i}getPoint(t,e=new Lt){const n=e,i=this.v0,r=this.v1,s=this.v2,a=this.v3;return n.set(Tl(t,i.x,r.x,s.x,a.x),Tl(t,i.y,r.y,s.y,a.y),Tl(t,i.z,r.z,s.z,a.z)),n}copy(t){return super.copy(t),this.v0.copy(t.v0),this.v1.copy(t.v1),this.v2.copy(t.v2),this.v3.copy(t.v3),this}toJSON(){const t=super.toJSON();return t.v0=this.v0.toArray(),t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t.v3=this.v3.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v0.fromArray(t.v0),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this.v3.fromArray(t.v3),this}}Al.prototype.isCubicBezierCurve3=!0;class Ll extends ml{constructor(t=new vt,e=new vt){super(),this.type="LineCurve",this.v1=t,this.v2=e}getPoint(t,e=new vt){const n=e;return 1===t?n.copy(this.v2):(n.copy(this.v2).sub(this.v1),n.multiplyScalar(t).add(this.v1)),n}getPointAt(t,e){return this.getPoint(t,e)}getTangent(t,e){const n=e||new vt;return n.copy(this.v2).sub(this.v1).normalize(),n}copy(t){return super.copy(t),this.v1.copy(t.v1),this.v2.copy(t.v2),this}toJSON(){const t=super.toJSON();return t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this}}Ll.prototype.isLineCurve=!0;class Rl extends ml{constructor(t=new Lt,e=new Lt){super(),this.type="LineCurve3",this.isLineCurve3=!0,this.v1=t,this.v2=e}getPoint(t,e=new Lt){const n=e;return 1===t?n.copy(this.v2):(n.copy(this.v2).sub(this.v1),n.multiplyScalar(t).add(this.v1)),n}getPointAt(t,e){return this.getPoint(t,e)}copy(t){return super.copy(t),this.v1.copy(t.v1),this.v2.copy(t.v2),this}toJSON(){const t=super.toJSON();return t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this}}class Cl extends ml{constructor(t=new vt,e=new vt,n=new vt){super(),this.type="QuadraticBezierCurve",this.v0=t,this.v1=e,this.v2=n}getPoint(t,e=new vt){const n=e,i=this.v0,r=this.v1,s=this.v2;return n.set(Sl(t,i.x,r.x,s.x),Sl(t,i.y,r.y,s.y)),n}copy(t){return super.copy(t),this.v0.copy(t.v0),this.v1.copy(t.v1),this.v2.copy(t.v2),this}toJSON(){const t=super.toJSON();return t.v0=this.v0.toArray(),t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v0.fromArray(t.v0),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this}}Cl.prototype.isQuadraticBezierCurve=!0;class Pl extends ml{constructor(t=new Lt,e=new Lt,n=new Lt){super(),this.type="QuadraticBezierCurve3",this.v0=t,this.v1=e,this.v2=n}getPoint(t,e=new Lt){const n=e,i=this.v0,r=this.v1,s=this.v2;return n.set(Sl(t,i.x,r.x,s.x),Sl(t,i.y,r.y,s.y),Sl(t,i.z,r.z,s.z)),n}copy(t){return super.copy(t),this.v0.copy(t.v0),this.v1.copy(t.v1),this.v2.copy(t.v2),this}toJSON(){const t=super.toJSON();return t.v0=this.v0.toArray(),t.v1=this.v1.toArray(),t.v2=this.v2.toArray(),t}fromJSON(t){return super.fromJSON(t),this.v0.fromArray(t.v0),this.v1.fromArray(t.v1),this.v2.fromArray(t.v2),this}}Pl.prototype.isQuadraticBezierCurve3=!0;class Dl extends ml{constructor(t=[]){super(),this.type="SplineCurve",this.points=t}getPoint(t,e=new vt){const n=e,i=this.points,r=(i.length-1)*t,s=Math.floor(r),a=r-s,o=i[0===s?s:s-1],l=i[s],c=i[s>i.length-2?i.length-1:s+1],h=i[s>i.length-3?i.length-1:s+2];return n.set(Ml(a,o.x,l.x,c.x,h.x),Ml(a,o.y,l.y,c.y,h.y)),n}copy(t){super.copy(t),this.points=[];for(let e=0,n=t.points.length;e<n;e++){const n=t.points[e];this.points.push(n.clone())}return this}toJSON(){const t=super.toJSON();t.points=[];for(let e=0,n=this.points.length;e<n;e++){const n=this.points[e];t.points.push(n.toArray())}return t}fromJSON(t){super.fromJSON(t),this.points=[];for(let e=0,n=t.points.length;e<n;e++){const n=t.points[e];this.points.push((new vt).fromArray(n))}return this}}Dl.prototype.isSplineCurve=!0;var Il=Object.freeze({__proto__:null,ArcCurve:gl,CatmullRomCurve3:bl,CubicBezierCurve:El,CubicBezierCurve3:Al,EllipseCurve:fl,LineCurve:Ll,LineCurve3:Rl,QuadraticBezierCurve:Cl,QuadraticBezierCurve3:Pl,SplineCurve:Dl});class Nl extends ml{constructor(){super(),this.type="CurvePath",this.curves=[],this.autoClose=!1}add(t){this.curves.push(t)}closePath(){const t=this.curves[0].getPoint(0),e=this.curves[this.curves.length-1].getPoint(1);t.equals(e)||this.curves.push(new Ll(e,t))}getPoint(t){const e=t*this.getLength(),n=this.getCurveLengths();let i=0;for(;i<n.length;){if(n[i]>=e){const t=n[i]-e,r=this.curves[i],s=r.getLength(),a=0===s?0:1-t/s;return r.getPointAt(a)}i++}return null}getLength(){const t=this.getCurveLengths();return t[t.length-1]}updateArcLengths(){this.needsUpdate=!0,this.cacheLengths=null,this.getCurveLengths()}getCurveLengths(){if(this.cacheLengths&&this.cacheLengths.length===this.curves.length)return this.cacheLengths;const t=[];let e=0;for(let n=0,i=this.curves.length;n<i;n++)e+=this.curves[n].getLength(),t.push(e);return this.cacheLengths=t,t}getSpacedPoints(t=40){const e=[];for(let n=0;n<=t;n++)e.push(this.getPoint(n/t));return this.autoClose&&e.push(e[0]),e}getPoints(t=12){const e=[];let n;for(let i=0,r=this.curves;i<r.length;i++){const s=r[i],a=s&&s.isEllipseCurve?2*t:s&&(s.isLineCurve||s.isLineCurve3)?1:s&&s.isSplineCurve?t*s.points.length:t,o=s.getPoints(a);for(let t=0;t<o.length;t++){const i=o[t];n&&n.equals(i)||(e.push(i),n=i)}}return this.autoClose&&e.length>1&&!e[e.length-1].equals(e[0])&&e.push(e[0]),e}copy(t){super.copy(t),this.curves=[];for(let e=0,n=t.curves.length;e<n;e++){const n=t.curves[e];this.curves.push(n.clone())}return this.autoClose=t.autoClose,this}toJSON(){const t=super.toJSON();t.autoClose=this.autoClose,t.curves=[];for(let e=0,n=this.curves.length;e<n;e++){const n=this.curves[e];t.curves.push(n.toJSON())}return t}fromJSON(t){super.fromJSON(t),this.autoClose=t.autoClose,this.curves=[];for(let e=0,n=t.curves.length;e<n;e++){const n=t.curves[e];this.curves.push((new Il[n.type]).fromJSON(n))}return this}}class Bl extends Nl{constructor(t){super(),this.type="Path",this.currentPoint=new vt,t&&this.setFromPoints(t)}setFromPoints(t){this.moveTo(t[0].x,t[0].y);for(let e=1,n=t.length;e<n;e++)this.lineTo(t[e].x,t[e].y);return this}moveTo(t,e){return this.currentPoint.set(t,e),this}lineTo(t,e){const n=new Ll(this.currentPoint.clone(),new vt(t,e));return this.curves.push(n),this.currentPoint.set(t,e),this}quadraticCurveTo(t,e,n,i){const r=new Cl(this.currentPoint.clone(),new vt(t,e),new vt(n,i));return this.curves.push(r),this.currentPoint.set(n,i),this}bezierCurveTo(t,e,n,i,r,s){const a=new El(this.currentPoint.clone(),new vt(t,e),new vt(n,i),new vt(r,s));return this.curves.push(a),this.currentPoint.set(r,s),this}splineThru(t){const e=[this.currentPoint.clone()].concat(t),n=new Dl(e);return this.curves.push(n),this.currentPoint.copy(t[t.length-1]),this}arc(t,e,n,i,r,s){const a=this.currentPoint.x,o=this.currentPoint.y;return this.absarc(t+a,e+o,n,i,r,s),this}absarc(t,e,n,i,r,s){return this.absellipse(t,e,n,n,i,r,s),this}ellipse(t,e,n,i,r,s,a,o){const l=this.currentPoint.x,c=this.currentPoint.y;return this.absellipse(t+l,e+c,n,i,r,s,a,o),this}absellipse(t,e,n,i,r,s,a,o){const l=new fl(t,e,n,i,r,s,a,o);if(this.curves.length>0){const t=l.getPoint(0);t.equals(this.currentPoint)||this.lineTo(t.x,t.y)}this.curves.push(l);const c=l.getPoint(1);return this.currentPoint.copy(c),this}copy(t){return super.copy(t),this.currentPoint.copy(t.currentPoint),this}toJSON(){const t=super.toJSON();return t.currentPoint=this.currentPoint.toArray(),t}fromJSON(t){return super.fromJSON(t),this.currentPoint.fromArray(t.currentPoint),this}}class zl extends Bl{constructor(t){super(t),this.uuid=ct(),this.type="Shape",this.holes=[]}getPointsHoles(t){const e=[];for(let n=0,i=this.holes.length;n<i;n++)e[n]=this.holes[n].getPoints(t);return e}extractPoints(t){return{shape:this.getPoints(t),holes:this.getPointsHoles(t)}}copy(t){super.copy(t),this.holes=[];for(let e=0,n=t.holes.length;e<n;e++){const n=t.holes[e];this.holes.push(n.clone())}return this}toJSON(){const t=super.toJSON();t.uuid=this.uuid,t.holes=[];for(let e=0,n=this.holes.length;e<n;e++){const n=this.holes[e];t.holes.push(n.toJSON())}return t}fromJSON(t){super.fromJSON(t),this.uuid=t.uuid,this.holes=[];for(let e=0,n=t.holes.length;e<n;e++){const n=t.holes[e];this.holes.push((new Bl).fromJSON(n))}return this}}class Fl extends Ce{constructor(t,e=1){super(),this.type="Light",this.color=new tn(t),this.intensity=e}dispose(){}copy(t){return super.copy(t),this.color.copy(t.color),this.intensity=t.intensity,this}toJSON(t){const e=super.toJSON(t);return e.object.color=this.color.getHex(),e.object.intensity=this.intensity,void 0!==this.groundColor&&(e.object.groundColor=this.groundColor.getHex()),void 0!==this.distance&&(e.object.distance=this.distance),void 0!==this.angle&&(e.object.angle=this.angle),void 0!==this.decay&&(e.object.decay=this.decay),void 0!==this.penumbra&&(e.object.penumbra=this.penumbra),void 0!==this.shadow&&(e.object.shadow=this.shadow.toJSON()),e}}Fl.prototype.isLight=!0;class Ol extends Fl{constructor(t,e,n){super(t,n),this.type="HemisphereLight",this.position.copy(Ce.DefaultUp),this.updateMatrix(),this.groundColor=new tn(e)}copy(t){return Fl.prototype.copy.call(this,t),this.groundColor.copy(t.groundColor),this}}Ol.prototype.isHemisphereLight=!0;const Hl=new se,Gl=new Lt,Ul=new Lt;class kl{constructor(t){this.camera=t,this.bias=0,this.normalBias=0,this.radius=1,this.mapSize=new vt(512,512),this.map=null,this.mapPass=null,this.matrix=new se,this.autoUpdate=!0,this.needsUpdate=!1,this._frustum=new ai,this._frameExtents=new vt(1,1),this._viewportCount=1,this._viewports=[new St(0,0,1,1)]}getViewportCount(){return this._viewportCount}getFrustum(){return this._frustum}updateMatrices(t){const e=this.camera,n=this.matrix;Gl.setFromMatrixPosition(t.matrixWorld),e.position.copy(Gl),Ul.setFromMatrixPosition(t.target.matrixWorld),e.lookAt(Ul),e.updateMatrixWorld(),Hl.multiplyMatrices(e.projectionMatrix,e.matrixWorldInverse),this._frustum.setFromProjectionMatrix(Hl),n.set(.5,0,0,.5,0,.5,0,.5,0,0,.5,.5,0,0,0,1),n.multiply(e.projectionMatrix),n.multiply(e.matrixWorldInverse)}getViewport(t){return this._viewports[t]}getFrameExtents(){return this._frameExtents}dispose(){this.map&&this.map.dispose(),this.mapPass&&this.mapPass.dispose()}copy(t){return this.camera=t.camera.clone(),this.bias=t.bias,this.radius=t.radius,this.mapSize.copy(t.mapSize),this}clone(){return(new this.constructor).copy(this)}toJSON(){const t={};return 0!==this.bias&&(t.bias=this.bias),0!==this.normalBias&&(t.normalBias=this.normalBias),1!==this.radius&&(t.radius=this.radius),512===this.mapSize.x&&512===this.mapSize.y||(t.mapSize=this.mapSize.toArray()),t.camera=this.camera.toJSON(!1).object,delete t.camera.matrix,t}}class Vl extends kl{constructor(){super(new Kn(50,1,.5,500)),this.focus=1}updateMatrices(t){const e=this.camera,n=2*lt*t.angle*this.focus,i=this.mapSize.width/this.mapSize.height,r=t.distance||e.far;n===e.fov&&i===e.aspect&&r===e.far||(e.fov=n,e.aspect=i,e.far=r,e.updateProjectionMatrix()),super.updateMatrices(t)}copy(t){return super.copy(t),this.focus=t.focus,this}}Vl.prototype.isSpotLightShadow=!0;class Wl extends Fl{constructor(t,e,n=0,i=Math.PI/3,r=0,s=1){super(t,e),this.type="SpotLight",this.position.copy(Ce.DefaultUp),this.updateMatrix(),this.target=new Ce,this.distance=n,this.angle=i,this.penumbra=r,this.decay=s,this.shadow=new Vl}get power(){return this.intensity*Math.PI}set power(t){this.intensity=t/Math.PI}dispose(){this.shadow.dispose()}copy(t){return super.copy(t),this.distance=t.distance,this.angle=t.angle,this.penumbra=t.penumbra,this.decay=t.decay,this.target=t.target.clone(),this.shadow=t.shadow.clone(),this}}Wl.prototype.isSpotLight=!0;const jl=new se,ql=new Lt,Xl=new Lt;class Yl extends kl{constructor(){super(new Kn(90,1,.5,500)),this._frameExtents=new vt(4,2),this._viewportCount=6,this._viewports=[new St(2,1,1,1),new St(0,1,1,1),new St(3,1,1,1),new St(1,1,1,1),new St(3,0,1,1),new St(1,0,1,1)],this._cubeDirections=[new Lt(1,0,0),new Lt(-1,0,0),new Lt(0,0,1),new Lt(0,0,-1),new Lt(0,1,0),new Lt(0,-1,0)],this._cubeUps=[new Lt(0,1,0),new Lt(0,1,0),new Lt(0,1,0),new Lt(0,1,0),new Lt(0,0,1),new Lt(0,0,-1)]}updateMatrices(t,e=0){const n=this.camera,i=this.matrix,r=t.distance||n.far;r!==n.far&&(n.far=r,n.updateProjectionMatrix()),ql.setFromMatrixPosition(t.matrixWorld),n.position.copy(ql),Xl.copy(n.position),Xl.add(this._cubeDirections[e]),n.up.copy(this._cubeUps[e]),n.lookAt(Xl),n.updateMatrixWorld(),i.makeTranslation(-ql.x,-ql.y,-ql.z),jl.multiplyMatrices(n.projectionMatrix,n.matrixWorldInverse),this._frustum.setFromProjectionMatrix(jl)}}Yl.prototype.isPointLightShadow=!0;class Zl extends Fl{constructor(t,e,n=0,i=1){super(t,e),this.type="PointLight",this.distance=n,this.decay=i,this.shadow=new Yl}get power(){return 4*this.intensity*Math.PI}set power(t){this.intensity=t/(4*Math.PI)}dispose(){this.shadow.dispose()}copy(t){return super.copy(t),this.distance=t.distance,this.decay=t.decay,this.shadow=t.shadow.clone(),this}}Zl.prototype.isPointLight=!0;class Jl extends Qn{constructor(t=-1,e=1,n=1,i=-1,r=.1,s=2e3){super(),this.type="OrthographicCamera",this.zoom=1,this.view=null,this.left=t,this.right=e,this.top=n,this.bottom=i,this.near=r,this.far=s,this.updateProjectionMatrix()}copy(t,e){return super.copy(t,e),this.left=t.left,this.right=t.right,this.top=t.top,this.bottom=t.bottom,this.near=t.near,this.far=t.far,this.zoom=t.zoom,this.view=null===t.view?null:Object.assign({},t.view),this}setViewOffset(t,e,n,i,r,s){null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1}),this.view.enabled=!0,this.view.fullWidth=t,this.view.fullHeight=e,this.view.offsetX=n,this.view.offsetY=i,this.view.width=r,this.view.height=s,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const t=(this.right-this.left)/(2*this.zoom),e=(this.top-this.bottom)/(2*this.zoom),n=(this.right+this.left)/2,i=(this.top+this.bottom)/2;let r=n-t,s=n+t,a=i+e,o=i-e;if(null!==this.view&&this.view.enabled){const t=(this.right-this.left)/this.view.fullWidth/this.zoom,e=(this.top-this.bottom)/this.view.fullHeight/this.zoom;r+=t*this.view.offsetX,s=r+t*this.view.width,a-=e*this.view.offsetY,o=a-e*this.view.height}this.projectionMatrix.makeOrthographic(r,s,a,o,this.near,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(t){const e=super.toJSON(t);return e.object.zoom=this.zoom,e.object.left=this.left,e.object.right=this.right,e.object.top=this.top,e.object.bottom=this.bottom,e.object.near=this.near,e.object.far=this.far,null!==this.view&&(e.object.view=Object.assign({},this.view)),e}}Jl.prototype.isOrthographicCamera=!0;class Ql extends kl{constructor(){super(new Jl(-5,5,5,-5,.5,500))}}Ql.prototype.isDirectionalLightShadow=!0;class Kl extends Fl{constructor(t,e){super(t,e),this.type="DirectionalLight",this.position.copy(Ce.DefaultUp),this.updateMatrix(),this.target=new Ce,this.shadow=new Ql}dispose(){this.shadow.dispose()}copy(t){return super.copy(t),this.target=t.target.clone(),this.shadow=t.shadow.clone(),this}}Kl.prototype.isDirectionalLight=!0;class $l extends Fl{constructor(t,e){super(t,e),this.type="AmbientLight"}}$l.prototype.isAmbientLight=!0;class tc extends Fl{constructor(t,e,n=10,i=10){super(t,e),this.type="RectAreaLight",this.width=n,this.height=i}copy(t){return super.copy(t),this.width=t.width,this.height=t.height,this}toJSON(t){const e=super.toJSON(t);return e.object.width=this.width,e.object.height=this.height,e}}tc.prototype.isRectAreaLight=!0;class ec{constructor(){this.coefficients=[];for(let t=0;t<9;t++)this.coefficients.push(new Lt)}set(t){for(let e=0;e<9;e++)this.coefficients[e].copy(t[e]);return this}zero(){for(let t=0;t<9;t++)this.coefficients[t].set(0,0,0);return this}getAt(t,e){const n=t.x,i=t.y,r=t.z,s=this.coefficients;return e.copy(s[0]).multiplyScalar(.282095),e.addScaledVector(s[1],.488603*i),e.addScaledVector(s[2],.488603*r),e.addScaledVector(s[3],.488603*n),e.addScaledVector(s[4],n*i*1.092548),e.addScaledVector(s[5],i*r*1.092548),e.addScaledVector(s[6],.315392*(3*r*r-1)),e.addScaledVector(s[7],n*r*1.092548),e.addScaledVector(s[8],.546274*(n*n-i*i)),e}getIrradianceAt(t,e){const n=t.x,i=t.y,r=t.z,s=this.coefficients;return e.copy(s[0]).multiplyScalar(.886227),e.addScaledVector(s[1],1.023328*i),e.addScaledVector(s[2],1.023328*r),e.addScaledVector(s[3],1.023328*n),e.addScaledVector(s[4],.858086*n*i),e.addScaledVector(s[5],.858086*i*r),e.addScaledVector(s[6],.743125*r*r-.247708),e.addScaledVector(s[7],.858086*n*r),e.addScaledVector(s[8],.429043*(n*n-i*i)),e}add(t){for(let e=0;e<9;e++)this.coefficients[e].add(t.coefficients[e]);return this}addScaledSH(t,e){for(let n=0;n<9;n++)this.coefficients[n].addScaledVector(t.coefficients[n],e);return this}scale(t){for(let e=0;e<9;e++)this.coefficients[e].multiplyScalar(t);return this}lerp(t,e){for(let n=0;n<9;n++)this.coefficients[n].lerp(t.coefficients[n],e);return this}equals(t){for(let e=0;e<9;e++)if(!this.coefficients[e].equals(t.coefficients[e]))return!1;return!0}copy(t){return this.set(t.coefficients)}clone(){return(new this.constructor).copy(this)}fromArray(t,e=0){const n=this.coefficients;for(let i=0;i<9;i++)n[i].fromArray(t,e+3*i);return this}toArray(t=[],e=0){const n=this.coefficients;for(let i=0;i<9;i++)n[i].toArray(t,e+3*i);return t}static getBasisAt(t,e){const n=t.x,i=t.y,r=t.z;e[0]=.282095,e[1]=.488603*i,e[2]=.488603*r,e[3]=.488603*n,e[4]=1.092548*n*i,e[5]=1.092548*i*r,e[6]=.315392*(3*r*r-1),e[7]=1.092548*n*r,e[8]=.546274*(n*n-i*i)}}ec.prototype.isSphericalHarmonics3=!0;class nc extends Fl{constructor(t=new ec,e=1){super(void 0,e),this.sh=t}copy(t){return super.copy(t),this.sh.copy(t.sh),this}fromJSON(t){return this.intensity=t.intensity,this.sh.fromArray(t.sh),this}toJSON(t){const e=super.toJSON(t);return e.object.sh=this.sh.toArray(),e}}nc.prototype.isLightProbe=!0;class ic extends ol{constructor(t){super(t),this.textures={}}load(t,e,n,i){const r=this,s=new cl(r.manager);s.setPath(r.path),s.setRequestHeader(r.requestHeader),s.setWithCredentials(r.withCredentials),s.load(t,(function(n){try{e(r.parse(JSON.parse(n)))}catch(e){i?i(e):console.error(e),r.manager.itemError(t)}}),n,i)}parse(t){const e=this.textures;function n(t){return void 0===e[t]&&console.warn("THREE.MaterialLoader: Undefined texture",t),e[t]}const i=new ko[t.type];if(void 0!==t.uuid&&(i.uuid=t.uuid),void 0!==t.name&&(i.name=t.name),void 0!==t.color&&void 0!==i.color&&i.color.setHex(t.color),void 0!==t.roughness&&(i.roughness=t.roughness),void 0!==t.metalness&&(i.metalness=t.metalness),void 0!==t.sheen&&(i.sheen=(new tn).setHex(t.sheen)),void 0!==t.emissive&&void 0!==i.emissive&&i.emissive.setHex(t.emissive),void 0!==t.specular&&void 0!==i.specular&&i.specular.setHex(t.specular),void 0!==t.shininess&&(i.shininess=t.shininess),void 0!==t.clearcoat&&(i.clearcoat=t.clearcoat),void 0!==t.clearcoatRoughness&&(i.clearcoatRoughness=t.clearcoatRoughness),void 0!==t.fog&&(i.fog=t.fog),void 0!==t.flatShading&&(i.flatShading=t.flatShading),void 0!==t.blending&&(i.blending=t.blending),void 0!==t.combine&&(i.combine=t.combine),void 0!==t.side&&(i.side=t.side),void 0!==t.shadowSide&&(i.shadowSide=t.shadowSide),void 0!==t.opacity&&(i.opacity=t.opacity),void 0!==t.transparent&&(i.transparent=t.transparent),void 0!==t.alphaTest&&(i.alphaTest=t.alphaTest),void 0!==t.depthTest&&(i.depthTest=t.depthTest),void 0!==t.depthWrite&&(i.depthWrite=t.depthWrite),void 0!==t.colorWrite&&(i.colorWrite=t.colorWrite),void 0!==t.stencilWrite&&(i.stencilWrite=t.stencilWrite),void 0!==t.stencilWriteMask&&(i.stencilWriteMask=t.stencilWriteMask),void 0!==t.stencilFunc&&(i.stencilFunc=t.stencilFunc),void 0!==t.stencilRef&&(i.stencilRef=t.stencilRef),void 0!==t.stencilFuncMask&&(i.stencilFuncMask=t.stencilFuncMask),void 0!==t.stencilFail&&(i.stencilFail=t.stencilFail),void 0!==t.stencilZFail&&(i.stencilZFail=t.stencilZFail),void 0!==t.stencilZPass&&(i.stencilZPass=t.stencilZPass),void 0!==t.wireframe&&(i.wireframe=t.wireframe),void 0!==t.wireframeLinewidth&&(i.wireframeLinewidth=t.wireframeLinewidth),void 0!==t.wireframeLinecap&&(i.wireframeLinecap=t.wireframeLinecap),void 0!==t.wireframeLinejoin&&(i.wireframeLinejoin=t.wireframeLinejoin),void 0!==t.rotation&&(i.rotation=t.rotation),1!==t.linewidth&&(i.linewidth=t.linewidth),void 0!==t.dashSize&&(i.dashSize=t.dashSize),void 0!==t.gapSize&&(i.gapSize=t.gapSize),void 0!==t.scale&&(i.scale=t.scale),void 0!==t.polygonOffset&&(i.polygonOffset=t.polygonOffset),void 0!==t.polygonOffsetFactor&&(i.polygonOffsetFactor=t.polygonOffsetFactor),void 0!==t.polygonOffsetUnits&&(i.polygonOffsetUnits=t.polygonOffsetUnits),void 0!==t.skinning&&(i.skinning=t.skinning),void 0!==t.morphTargets&&(i.morphTargets=t.morphTargets),void 0!==t.morphNormals&&(i.morphNormals=t.morphNormals),void 0!==t.dithering&&(i.dithering=t.dithering),void 0!==t.alphaToCoverage&&(i.alphaToCoverage=t.alphaToCoverage),void 0!==t.premultipliedAlpha&&(i.premultipliedAlpha=t.premultipliedAlpha),void 0!==t.vertexTangents&&(i.vertexTangents=t.vertexTangents),void 0!==t.visible&&(i.visible=t.visible),void 0!==t.toneMapped&&(i.toneMapped=t.toneMapped),void 0!==t.userData&&(i.userData=t.userData),void 0!==t.vertexColors&&("number"==typeof t.vertexColors?i.vertexColors=t.vertexColors>0:i.vertexColors=t.vertexColors),void 0!==t.uniforms)for(const e in t.uniforms){const r=t.uniforms[e];switch(i.uniforms[e]={},r.type){case"t":i.uniforms[e].value=n(r.value);break;case"c":i.uniforms[e].value=(new tn).setHex(r.value);break;case"v2":i.uniforms[e].value=(new vt).fromArray(r.value);break;case"v3":i.uniforms[e].value=(new Lt).fromArray(r.value);break;case"v4":i.uniforms[e].value=(new St).fromArray(r.value);break;case"m3":i.uniforms[e].value=(new yt).fromArray(r.value);break;case"m4":i.uniforms[e].value=(new se).fromArray(r.value);break;default:i.uniforms[e].value=r.value}}if(void 0!==t.defines&&(i.defines=t.defines),void 0!==t.vertexShader&&(i.vertexShader=t.vertexShader),void 0!==t.fragmentShader&&(i.fragmentShader=t.fragmentShader),void 0!==t.extensions)for(const e in t.extensions)i.extensions[e]=t.extensions[e];if(void 0!==t.shading&&(i.flatShading=1===t.shading),void 0!==t.size&&(i.size=t.size),void 0!==t.sizeAttenuation&&(i.sizeAttenuation=t.sizeAttenuation),void 0!==t.map&&(i.map=n(t.map)),void 0!==t.matcap&&(i.matcap=n(t.matcap)),void 0!==t.alphaMap&&(i.alphaMap=n(t.alphaMap)),void 0!==t.bumpMap&&(i.bumpMap=n(t.bumpMap)),void 0!==t.bumpScale&&(i.bumpScale=t.bumpScale),void 0!==t.normalMap&&(i.normalMap=n(t.normalMap)),void 0!==t.normalMapType&&(i.normalMapType=t.normalMapType),void 0!==t.normalScale){let e=t.normalScale;!1===Array.isArray(e)&&(e=[e,e]),i.normalScale=(new vt).fromArray(e)}return void 0!==t.displacementMap&&(i.displacementMap=n(t.displacementMap)),void 0!==t.displacementScale&&(i.displacementScale=t.displacementScale),void 0!==t.displacementBias&&(i.displacementBias=t.displacementBias),void 0!==t.roughnessMap&&(i.roughnessMap=n(t.roughnessMap)),void 0!==t.metalnessMap&&(i.metalnessMap=n(t.metalnessMap)),void 0!==t.emissiveMap&&(i.emissiveMap=n(t.emissiveMap)),void 0!==t.emissiveIntensity&&(i.emissiveIntensity=t.emissiveIntensity),void 0!==t.specularMap&&(i.specularMap=n(t.specularMap)),void 0!==t.envMap&&(i.envMap=n(t.envMap)),void 0!==t.envMapIntensity&&(i.envMapIntensity=t.envMapIntensity),void 0!==t.reflectivity&&(i.reflectivity=t.reflectivity),void 0!==t.refractionRatio&&(i.refractionRatio=t.refractionRatio),void 0!==t.lightMap&&(i.lightMap=n(t.lightMap)),void 0!==t.lightMapIntensity&&(i.lightMapIntensity=t.lightMapIntensity),void 0!==t.aoMap&&(i.aoMap=n(t.aoMap)),void 0!==t.aoMapIntensity&&(i.aoMapIntensity=t.aoMapIntensity),void 0!==t.gradientMap&&(i.gradientMap=n(t.gradientMap)),void 0!==t.clearcoatMap&&(i.clearcoatMap=n(t.clearcoatMap)),void 0!==t.clearcoatRoughnessMap&&(i.clearcoatRoughnessMap=n(t.clearcoatRoughnessMap)),void 0!==t.clearcoatNormalMap&&(i.clearcoatNormalMap=n(t.clearcoatNormalMap)),void 0!==t.clearcoatNormalScale&&(i.clearcoatNormalScale=(new vt).fromArray(t.clearcoatNormalScale)),void 0!==t.transmission&&(i.transmission=t.transmission),void 0!==t.transmissionMap&&(i.transmissionMap=n(t.transmissionMap)),i}setTextures(t){return this.textures=t,this}}class rc{static decodeText(t){if("undefined"!=typeof TextDecoder)return(new TextDecoder).decode(t);let e="";for(let n=0,i=t.length;n<i;n++)e+=String.fromCharCode(t[n]);try{return decodeURIComponent(escape(e))}catch(t){return e}}static extractUrlBase(t){const e=t.lastIndexOf("/");return-1===e?"./":t.substr(0,e+1)}}class sc extends En{constructor(){super(),this.type="InstancedBufferGeometry",this.instanceCount=1/0}copy(t){return super.copy(t),this.instanceCount=t.instanceCount,this}clone(){return(new this.constructor).copy(this)}toJSON(){const t=super.toJSON(this);return t.instanceCount=this.instanceCount,t.isInstancedBufferGeometry=!0,t}}sc.prototype.isInstancedBufferGeometry=!0;class ac extends sn{constructor(t,e,n,i){"number"==typeof n&&(i=n,n=!1,console.error("THREE.InstancedBufferAttribute: The constructor now expects normalized as the third argument.")),super(t,e,n),this.meshPerAttribute=i||1}copy(t){return super.copy(t),this.meshPerAttribute=t.meshPerAttribute,this}toJSON(){const t=super.toJSON();return t.meshPerAttribute=this.meshPerAttribute,t.isInstancedBufferAttribute=!0,t}}ac.prototype.isInstancedBufferAttribute=!0;class oc extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=new cl(r.manager);s.setPath(r.path),s.setRequestHeader(r.requestHeader),s.setWithCredentials(r.withCredentials),s.load(t,(function(n){try{e(r.parse(JSON.parse(n)))}catch(e){i?i(e):console.error(e),r.manager.itemError(t)}}),n,i)}parse(t){const e={},n={};function i(t,i){if(void 0!==e[i])return e[i];const r=t.interleavedBuffers[i],s=function(t,e){if(void 0!==n[e])return n[e];const i=t.arrayBuffers[e],r=new Uint32Array(i).buffer;return n[e]=r,r}(t,r.buffer),a=yn(r.type,s),o=new Es(a,r.stride);return o.uuid=r.uuid,e[i]=o,o}const r=t.isInstancedBufferGeometry?new sc:new En,s=t.data.index;if(void 0!==s){const t=yn(s.type,s.array);r.setIndex(new sn(t,1))}const a=t.data.attributes;for(const e in a){const n=a[e];let s;if(n.isInterleavedBufferAttribute){const e=i(t.data,n.data);s=new Ls(e,n.itemSize,n.offset,n.normalized)}else{const t=yn(n.type,n.array);s=new(n.isInstancedBufferAttribute?ac:sn)(t,n.itemSize,n.normalized)}void 0!==n.name&&(s.name=n.name),void 0!==n.usage&&s.setUsage(n.usage),void 0!==n.updateRange&&(s.updateRange.offset=n.updateRange.offset,s.updateRange.count=n.updateRange.count),r.setAttribute(e,s)}const o=t.data.morphAttributes;if(o)for(const e in o){const n=o[e],s=[];for(let e=0,r=n.length;e<r;e++){const r=n[e];let a;if(r.isInterleavedBufferAttribute){const e=i(t.data,r.data);a=new Ls(e,r.itemSize,r.offset,r.normalized)}else{const t=yn(r.type,r.array);a=new sn(t,r.itemSize,r.normalized)}void 0!==r.name&&(a.name=r.name),s.push(a)}r.morphAttributes[e]=s}t.data.morphTargetsRelative&&(r.morphTargetsRelative=!0);const l=t.data.groups||t.data.drawcalls||t.data.offsets;if(void 0!==l)for(let t=0,e=l.length;t!==e;++t){const e=l[t];r.addGroup(e.start,e.count,e.materialIndex)}const c=t.data.boundingSphere;if(void 0!==c){const t=new Lt;void 0!==c.center&&t.fromArray(c.center),r.boundingSphere=new Jt(t,c.radius)}return t.name&&(r.name=t.name),t.userData&&(r.userData=t.userData),r}}const lc={UVMapping:i,CubeReflectionMapping:r,CubeRefractionMapping:s,EquirectangularReflectionMapping:a,EquirectangularRefractionMapping:o,CubeUVReflectionMapping:l,CubeUVRefractionMapping:c},cc={RepeatWrapping:h,ClampToEdgeWrapping:u,MirroredRepeatWrapping:d},hc={NearestFilter:p,NearestMipmapNearestFilter:m,NearestMipmapLinearFilter:f,LinearFilter:g,LinearMipmapNearestFilter:v,LinearMipmapLinearFilter:y};class uc extends ol{constructor(t){super(t),"undefined"==typeof createImageBitmap&&console.warn("THREE.ImageBitmapLoader: createImageBitmap() not supported."),"undefined"==typeof fetch&&console.warn("THREE.ImageBitmapLoader: fetch() not supported."),this.options={premultiplyAlpha:"none"}}setOptions(t){return this.options=t,this}load(t,e,n,i){void 0===t&&(t=""),void 0!==this.path&&(t=this.path+t),t=this.manager.resolveURL(t);const r=this,s=rl.get(t);if(void 0!==s)return r.manager.itemStart(t),setTimeout((function(){e&&e(s),r.manager.itemEnd(t)}),0),s;const a={};a.credentials="anonymous"===this.crossOrigin?"same-origin":"include",a.headers=this.requestHeader,fetch(t,a).then((function(t){return t.blob()})).then((function(t){return createImageBitmap(t,Object.assign(r.options,{colorSpaceConversion:"none"}))})).then((function(n){rl.add(t,n),e&&e(n),r.manager.itemEnd(t)})).catch((function(e){i&&i(e),r.manager.itemError(t),r.manager.itemEnd(t)})),r.manager.itemStart(t)}}uc.prototype.isImageBitmapLoader=!0;class dc{constructor(){this.type="ShapePath",this.color=new tn,this.subPaths=[],this.currentPath=null}moveTo(t,e){return this.currentPath=new Bl,this.subPaths.push(this.currentPath),this.currentPath.moveTo(t,e),this}lineTo(t,e){return this.currentPath.lineTo(t,e),this}quadraticCurveTo(t,e,n,i){return this.currentPath.quadraticCurveTo(t,e,n,i),this}bezierCurveTo(t,e,n,i,r,s){return this.currentPath.bezierCurveTo(t,e,n,i,r,s),this}splineThru(t){return this.currentPath.splineThru(t),this}toShapes(t,e){function n(t){const e=[];for(let n=0,i=t.length;n<i;n++){const i=t[n],r=new zl;r.curves=i.curves,e.push(r)}return e}function i(t,e){const n=e.length;let i=!1;for(let r=n-1,s=0;s<n;r=s++){let n=e[r],a=e[s],o=a.x-n.x,l=a.y-n.y;if(Math.abs(l)>Number.EPSILON){if(l<0&&(n=e[s],o=-o,a=e[r],l=-l),t.y<n.y||t.y>a.y)continue;if(t.y===n.y){if(t.x===n.x)return!0}else{const e=l*(t.x-n.x)-o*(t.y-n.y);if(0===e)return!0;if(e<0)continue;i=!i}}else{if(t.y!==n.y)continue;if(a.x<=t.x&&t.x<=n.x||n.x<=t.x&&t.x<=a.x)return!0}}return i}const r=po.isClockWise,s=this.subPaths;if(0===s.length)return[];if(!0===e)return n(s);let a,o,l;const c=[];if(1===s.length)return o=s[0],l=new zl,l.curves=o.curves,c.push(l),c;let h=!r(s[0].getPoints());h=t?!h:h;const u=[],d=[];let p,m,f=[],g=0;d[g]=void 0,f[g]=[];for(let e=0,n=s.length;e<n;e++)o=s[e],p=o.getPoints(),a=r(p),a=t?!a:a,a?(!h&&d[g]&&g++,d[g]={s:new zl,p:p},d[g].s.curves=o.curves,h&&g++,f[g]=[]):f[g].push({h:o,p:p[0]});if(!d[0])return n(s);if(d.length>1){let t=!1;const e=[];for(let t=0,e=d.length;t<e;t++)u[t]=[];for(let n=0,r=d.length;n<r;n++){const r=f[n];for(let s=0;s<r.length;s++){const a=r[s];let o=!0;for(let r=0;r<d.length;r++)i(a.p,d[r].p)&&(n!==r&&e.push({froms:n,tos:r,hole:s}),o?(o=!1,u[r].push(a)):t=!0);o&&u[n].push(a)}}e.length>0&&(t||(f=u))}for(let t=0,e=d.length;t<e;t++){l=d[t].s,c.push(l),m=f[t];for(let t=0,e=m.length;t<e;t++)l.holes.push(m[t].h)}return c}}class pc{constructor(t){this.type="Font",this.data=t}generateShapes(t,e=100){const n=[],i=function(t,e,n){const i=Array.from(t),r=e/n.resolution,s=(n.boundingBox.yMax-n.boundingBox.yMin+n.underlineThickness)*r,a=[];let o=0,l=0;for(let t=0;t<i.length;t++){const e=i[t];if("\n"===e)o=0,l-=s;else{const t=mc(e,r,o,l,n);o+=t.offsetX,a.push(t.path)}}return a}(t,e,this.data);for(let t=0,e=i.length;t<e;t++)Array.prototype.push.apply(n,i[t].toShapes());return n}}function mc(t,e,n,i,r){const s=r.glyphs[t]||r.glyphs["?"];if(!s)return void console.error('THREE.Font: character "'+t+'" does not exists in font family '+r.familyName+".");const a=new dc;let o,l,c,h,u,d,p,m;if(s.o){const t=s._cachedOutline||(s._cachedOutline=s.o.split(" "));for(let r=0,s=t.length;r<s;){switch(t[r++]){case"m":o=t[r++]*e+n,l=t[r++]*e+i,a.moveTo(o,l);break;case"l":o=t[r++]*e+n,l=t[r++]*e+i,a.lineTo(o,l);break;case"q":c=t[r++]*e+n,h=t[r++]*e+i,u=t[r++]*e+n,d=t[r++]*e+i,a.quadraticCurveTo(u,d,c,h);break;case"b":c=t[r++]*e+n,h=t[r++]*e+i,u=t[r++]*e+n,d=t[r++]*e+i,p=t[r++]*e+n,m=t[r++]*e+i,a.bezierCurveTo(u,d,p,m,c,h)}}}return{offsetX:s.ha*e,path:a}}pc.prototype.isFont=!0;let fc;const gc={getContext:function(){return void 0===fc&&(fc=new(window.AudioContext||window.webkitAudioContext)),fc},setContext:function(t){fc=t}};class vc extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=new cl(this.manager);s.setResponseType("arraybuffer"),s.setPath(this.path),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(t,(function(n){try{const t=n.slice(0);gc.getContext().decodeAudioData(t,(function(t){e(t)}))}catch(e){i?i(e):console.error(e),r.manager.itemError(t)}}),n,i)}}class yc extends nc{constructor(t,e,n=1){super(void 0,n);const i=(new tn).set(t),r=(new tn).set(e),s=new Lt(i.r,i.g,i.b),a=new Lt(r.r,r.g,r.b),o=Math.sqrt(Math.PI),l=o*Math.sqrt(.75);this.sh.coefficients[0].copy(s).add(a).multiplyScalar(o),this.sh.coefficients[1].copy(s).sub(a).multiplyScalar(l)}}yc.prototype.isHemisphereLightProbe=!0;class xc extends nc{constructor(t,e=1){super(void 0,e);const n=(new tn).set(t);this.sh.coefficients[0].set(n.r,n.g,n.b).multiplyScalar(2*Math.sqrt(Math.PI))}}xc.prototype.isAmbientLightProbe=!0;const _c=new se,wc=new se;class bc{constructor(t=!0){this.autoStart=t,this.startTime=0,this.oldTime=0,this.elapsedTime=0,this.running=!1}start(){this.startTime=Mc(),this.oldTime=this.startTime,this.elapsedTime=0,this.running=!0}stop(){this.getElapsedTime(),this.running=!1,this.autoStart=!1}getElapsedTime(){return this.getDelta(),this.elapsedTime}getDelta(){let t=0;if(this.autoStart&&!this.running)return this.start(),0;if(this.running){const e=Mc();t=(e-this.oldTime)/1e3,this.oldTime=e,this.elapsedTime+=t}return t}}function Mc(){return("undefined"==typeof performance?Date:performance).now()}const Sc=new Lt,Tc=new At,Ec=new Lt,Ac=new Lt;class Lc extends Ce{constructor(t){super(),this.type="Audio",this.listener=t,this.context=t.context,this.gain=this.context.createGain(),this.gain.connect(t.getInput()),this.autoplay=!1,this.buffer=null,this.detune=0,this.loop=!1,this.loopStart=0,this.loopEnd=0,this.offset=0,this.duration=void 0,this.playbackRate=1,this.isPlaying=!1,this.hasPlaybackControl=!0,this.source=null,this.sourceType="empty",this._startedAt=0,this._progress=0,this._connected=!1,this.filters=[]}getOutput(){return this.gain}setNodeSource(t){return this.hasPlaybackControl=!1,this.sourceType="audioNode",this.source=t,this.connect(),this}setMediaElementSource(t){return this.hasPlaybackControl=!1,this.sourceType="mediaNode",this.source=this.context.createMediaElementSource(t),this.connect(),this}setMediaStreamSource(t){return this.hasPlaybackControl=!1,this.sourceType="mediaStreamNode",this.source=this.context.createMediaStreamSource(t),this.connect(),this}setBuffer(t){return this.buffer=t,this.sourceType="buffer",this.autoplay&&this.play(),this}play(t=0){if(!0===this.isPlaying)return void console.warn("THREE.Audio: Audio is already playing.");if(!1===this.hasPlaybackControl)return void console.warn("THREE.Audio: this Audio has no playback control.");this._startedAt=this.context.currentTime+t;const e=this.context.createBufferSource();return e.buffer=this.buffer,e.loop=this.loop,e.loopStart=this.loopStart,e.loopEnd=this.loopEnd,e.onended=this.onEnded.bind(this),e.start(this._startedAt,this._progress+this.offset,this.duration),this.isPlaying=!0,this.source=e,this.setDetune(this.detune),this.setPlaybackRate(this.playbackRate),this.connect()}pause(){if(!1!==this.hasPlaybackControl)return!0===this.isPlaying&&(this._progress+=Math.max(this.context.currentTime-this._startedAt,0)*this.playbackRate,!0===this.loop&&(this._progress=this._progress%(this.duration||this.buffer.duration)),this.source.stop(),this.source.onended=null,this.isPlaying=!1),this;console.warn("THREE.Audio: this Audio has no playback control.")}stop(){if(!1!==this.hasPlaybackControl)return this._progress=0,this.source.stop(),this.source.onended=null,this.isPlaying=!1,this;console.warn("THREE.Audio: this Audio has no playback control.")}connect(){if(this.filters.length>0){this.source.connect(this.filters[0]);for(let t=1,e=this.filters.length;t<e;t++)this.filters[t-1].connect(this.filters[t]);this.filters[this.filters.length-1].connect(this.getOutput())}else this.source.connect(this.getOutput());return this._connected=!0,this}disconnect(){if(this.filters.length>0){this.source.disconnect(this.filters[0]);for(let t=1,e=this.filters.length;t<e;t++)this.filters[t-1].disconnect(this.filters[t]);this.filters[this.filters.length-1].disconnect(this.getOutput())}else this.source.disconnect(this.getOutput());return this._connected=!1,this}getFilters(){return this.filters}setFilters(t){return t||(t=[]),!0===this._connected?(this.disconnect(),this.filters=t.slice(),this.connect()):this.filters=t.slice(),this}setDetune(t){if(this.detune=t,void 0!==this.source.detune)return!0===this.isPlaying&&this.source.detune.setTargetAtTime(this.detune,this.context.currentTime,.01),this}getDetune(){return this.detune}getFilter(){return this.getFilters()[0]}setFilter(t){return this.setFilters(t?[t]:[])}setPlaybackRate(t){if(!1!==this.hasPlaybackControl)return this.playbackRate=t,!0===this.isPlaying&&this.source.playbackRate.setTargetAtTime(this.playbackRate,this.context.currentTime,.01),this;console.warn("THREE.Audio: this Audio has no playback control.")}getPlaybackRate(){return this.playbackRate}onEnded(){this.isPlaying=!1}getLoop(){return!1===this.hasPlaybackControl?(console.warn("THREE.Audio: this Audio has no playback control."),!1):this.loop}setLoop(t){if(!1!==this.hasPlaybackControl)return this.loop=t,!0===this.isPlaying&&(this.source.loop=this.loop),this;console.warn("THREE.Audio: this Audio has no playback control.")}setLoopStart(t){return this.loopStart=t,this}setLoopEnd(t){return this.loopEnd=t,this}getVolume(){return this.gain.gain.value}setVolume(t){return this.gain.gain.setTargetAtTime(t,this.context.currentTime,.01),this}}const Rc=new Lt,Cc=new At,Pc=new Lt,Dc=new Lt;class Ic{constructor(t,e=2048){this.analyser=t.context.createAnalyser(),this.analyser.fftSize=e,this.data=new Uint8Array(this.analyser.frequencyBinCount),t.getOutput().connect(this.analyser)}getFrequencyData(){return this.analyser.getByteFrequencyData(this.data),this.data}getAverageFrequency(){let t=0;const e=this.getFrequencyData();for(let n=0;n<e.length;n++)t+=e[n];return t/e.length}}class Nc{constructor(t,e,n){let i,r,s;switch(this.binding=t,this.valueSize=n,e){case"quaternion":i=this._slerp,r=this._slerpAdditive,s=this._setAdditiveIdentityQuaternion,this.buffer=new Float64Array(6*n),this._workIndex=5;break;case"string":case"bool":i=this._select,r=this._select,s=this._setAdditiveIdentityOther,this.buffer=new Array(5*n);break;default:i=this._lerp,r=this._lerpAdditive,s=this._setAdditiveIdentityNumeric,this.buffer=new Float64Array(5*n)}this._mixBufferRegion=i,this._mixBufferRegionAdditive=r,this._setIdentity=s,this._origIndex=3,this._addIndex=4,this.cumulativeWeight=0,this.cumulativeWeightAdditive=0,this.useCount=0,this.referenceCount=0}accumulate(t,e){const n=this.buffer,i=this.valueSize,r=t*i+i;let s=this.cumulativeWeight;if(0===s){for(let t=0;t!==i;++t)n[r+t]=n[t];s=e}else{s+=e;const t=e/s;this._mixBufferRegion(n,r,0,t,i)}this.cumulativeWeight=s}accumulateAdditive(t){const e=this.buffer,n=this.valueSize,i=n*this._addIndex;0===this.cumulativeWeightAdditive&&this._setIdentity(),this._mixBufferRegionAdditive(e,i,0,t,n),this.cumulativeWeightAdditive+=t}apply(t){const e=this.valueSize,n=this.buffer,i=t*e+e,r=this.cumulativeWeight,s=this.cumulativeWeightAdditive,a=this.binding;if(this.cumulativeWeight=0,this.cumulativeWeightAdditive=0,r<1){const t=e*this._origIndex;this._mixBufferRegion(n,i,t,1-r,e)}s>0&&this._mixBufferRegionAdditive(n,i,this._addIndex*e,1,e);for(let t=e,r=e+e;t!==r;++t)if(n[t]!==n[t+e]){a.setValue(n,i);break}}saveOriginalState(){const t=this.binding,e=this.buffer,n=this.valueSize,i=n*this._origIndex;t.getValue(e,i);for(let t=n,r=i;t!==r;++t)e[t]=e[i+t%n];this._setIdentity(),this.cumulativeWeight=0,this.cumulativeWeightAdditive=0}restoreOriginalState(){const t=3*this.valueSize;this.binding.setValue(this.buffer,t)}_setAdditiveIdentityNumeric(){const t=this._addIndex*this.valueSize,e=t+this.valueSize;for(let n=t;n<e;n++)this.buffer[n]=0}_setAdditiveIdentityQuaternion(){this._setAdditiveIdentityNumeric(),this.buffer[this._addIndex*this.valueSize+3]=1}_setAdditiveIdentityOther(){const t=this._origIndex*this.valueSize,e=this._addIndex*this.valueSize;for(let n=0;n<this.valueSize;n++)this.buffer[e+n]=this.buffer[t+n]}_select(t,e,n,i,r){if(i>=.5)for(let i=0;i!==r;++i)t[e+i]=t[n+i]}_slerp(t,e,n,i){At.slerpFlat(t,e,t,e,t,n,i)}_slerpAdditive(t,e,n,i,r){const s=this._workIndex*r;At.multiplyQuaternionsFlat(t,s,t,e,t,n),At.slerpFlat(t,e,t,e,t,s,i)}_lerp(t,e,n,i,r){const s=1-i;for(let a=0;a!==r;++a){const r=e+a;t[r]=t[r]*s+t[n+a]*i}}_lerpAdditive(t,e,n,i,r){for(let s=0;s!==r;++s){const r=e+s;t[r]=t[r]+t[n+s]*i}}}const Bc="\\[\\]\\.:\\/",zc=new RegExp("[\\[\\]\\.:\\/]","g"),Fc="[^\\[\\]\\.:\\/]",Oc="[^"+Bc.replace("\\.","")+"]",Hc=/((?:WC+[\/:])*)/.source.replace("WC",Fc),Gc=/(WCOD+)?/.source.replace("WCOD",Oc),Uc=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC",Fc),kc=/\.(WC+)(?:\[(.+)\])?/.source.replace("WC",Fc),Vc=new RegExp("^"+Hc+Gc+Uc+kc+"$"),Wc=["material","materials","bones"];class jc{constructor(t,e,n){this.path=e,this.parsedPath=n||jc.parseTrackName(e),this.node=jc.findNode(t,this.parsedPath.nodeName)||t,this.rootNode=t,this.getValue=this._getValue_unbound,this.setValue=this._setValue_unbound}static create(t,e,n){return t&&t.isAnimationObjectGroup?new jc.Composite(t,e,n):new jc(t,e,n)}static sanitizeNodeName(t){return t.replace(/\s/g,"_").replace(zc,"")}static parseTrackName(t){const e=Vc.exec(t);if(!e)throw new Error("PropertyBinding: Cannot parse trackName: "+t);const n={nodeName:e[2],objectName:e[3],objectIndex:e[4],propertyName:e[5],propertyIndex:e[6]},i=n.nodeName&&n.nodeName.lastIndexOf(".");if(void 0!==i&&-1!==i){const t=n.nodeName.substring(i+1);-1!==Wc.indexOf(t)&&(n.nodeName=n.nodeName.substring(0,i),n.objectName=t)}if(null===n.propertyName||0===n.propertyName.length)throw new Error("PropertyBinding: can not parse propertyName from trackName: "+t);return n}static findNode(t,e){if(!e||""===e||"."===e||-1===e||e===t.name||e===t.uuid)return t;if(t.skeleton){const n=t.skeleton.getBoneByName(e);if(void 0!==n)return n}if(t.children){const n=function(t){for(let i=0;i<t.length;i++){const r=t[i];if(r.name===e||r.uuid===e)return r;const s=n(r.children);if(s)return s}return null},i=n(t.children);if(i)return i}return null}_getValue_unavailable(){}_setValue_unavailable(){}_getValue_direct(t,e){t[e]=this.node[this.propertyName]}_getValue_array(t,e){const n=this.resolvedProperty;for(let i=0,r=n.length;i!==r;++i)t[e++]=n[i]}_getValue_arrayElement(t,e){t[e]=this.resolvedProperty[this.propertyIndex]}_getValue_toArray(t,e){this.resolvedProperty.toArray(t,e)}_setValue_direct(t,e){this.targetObject[this.propertyName]=t[e]}_setValue_direct_setNeedsUpdate(t,e){this.targetObject[this.propertyName]=t[e],this.targetObject.needsUpdate=!0}_setValue_direct_setMatrixWorldNeedsUpdate(t,e){this.targetObject[this.propertyName]=t[e],this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_array(t,e){const n=this.resolvedProperty;for(let i=0,r=n.length;i!==r;++i)n[i]=t[e++]}_setValue_array_setNeedsUpdate(t,e){const n=this.resolvedProperty;for(let i=0,r=n.length;i!==r;++i)n[i]=t[e++];this.targetObject.needsUpdate=!0}_setValue_array_setMatrixWorldNeedsUpdate(t,e){const n=this.resolvedProperty;for(let i=0,r=n.length;i!==r;++i)n[i]=t[e++];this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_arrayElement(t,e){this.resolvedProperty[this.propertyIndex]=t[e]}_setValue_arrayElement_setNeedsUpdate(t,e){this.resolvedProperty[this.propertyIndex]=t[e],this.targetObject.needsUpdate=!0}_setValue_arrayElement_setMatrixWorldNeedsUpdate(t,e){this.resolvedProperty[this.propertyIndex]=t[e],this.targetObject.matrixWorldNeedsUpdate=!0}_setValue_fromArray(t,e){this.resolvedProperty.fromArray(t,e)}_setValue_fromArray_setNeedsUpdate(t,e){this.resolvedProperty.fromArray(t,e),this.targetObject.needsUpdate=!0}_setValue_fromArray_setMatrixWorldNeedsUpdate(t,e){this.resolvedProperty.fromArray(t,e),this.targetObject.matrixWorldNeedsUpdate=!0}_getValue_unbound(t,e){this.bind(),this.getValue(t,e)}_setValue_unbound(t,e){this.bind(),this.setValue(t,e)}bind(){let t=this.node;const e=this.parsedPath,n=e.objectName,i=e.propertyName;let r=e.propertyIndex;if(t||(t=jc.findNode(this.rootNode,e.nodeName)||this.rootNode,this.node=t),this.getValue=this._getValue_unavailable,this.setValue=this._setValue_unavailable,!t)return void console.error("THREE.PropertyBinding: Trying to update node for track: "+this.path+" but it wasn't found.");if(n){let i=e.objectIndex;switch(n){case"materials":if(!t.material)return void console.error("THREE.PropertyBinding: Can not bind to material as node does not have a material.",this);if(!t.material.materials)return void console.error("THREE.PropertyBinding: Can not bind to material.materials as node.material does not have a materials array.",this);t=t.material.materials;break;case"bones":if(!t.skeleton)return void console.error("THREE.PropertyBinding: Can not bind to bones as node does not have a skeleton.",this);t=t.skeleton.bones;for(let e=0;e<t.length;e++)if(t[e].name===i){i=e;break}break;default:if(void 0===t[n])return void console.error("THREE.PropertyBinding: Can not bind to objectName of node undefined.",this);t=t[n]}if(void 0!==i){if(void 0===t[i])return void console.error("THREE.PropertyBinding: Trying to bind to objectIndex of objectName, but is undefined.",this,t);t=t[i]}}const s=t[i];if(void 0===s){const n=e.nodeName;return void console.error("THREE.PropertyBinding: Trying to update property for track: "+n+"."+i+" but it wasn't found.",t)}let a=this.Versioning.None;this.targetObject=t,void 0!==t.needsUpdate?a=this.Versioning.NeedsUpdate:void 0!==t.matrixWorldNeedsUpdate&&(a=this.Versioning.MatrixWorldNeedsUpdate);let o=this.BindingType.Direct;if(void 0!==r){if("morphTargetInfluences"===i){if(!t.geometry)return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.",this);if(!t.geometry.isBufferGeometry)return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences on THREE.Geometry. Use THREE.BufferGeometry instead.",this);if(!t.geometry.morphAttributes)return void console.error("THREE.PropertyBinding: Can not bind to morphTargetInfluences because node does not have a geometry.morphAttributes.",this);void 0!==t.morphTargetDictionary[r]&&(r=t.morphTargetDictionary[r])}o=this.BindingType.ArrayElement,this.resolvedProperty=s,this.propertyIndex=r}else void 0!==s.fromArray&&void 0!==s.toArray?(o=this.BindingType.HasFromToArray,this.resolvedProperty=s):Array.isArray(s)?(o=this.BindingType.EntireArray,this.resolvedProperty=s):this.propertyName=i;this.getValue=this.GetterByBindingType[o],this.setValue=this.SetterByBindingTypeAndVersioning[o][a]}unbind(){this.node=null,this.getValue=this._getValue_unbound,this.setValue=this._setValue_unbound}}jc.Composite=class{constructor(t,e,n){const i=n||jc.parseTrackName(e);this._targetGroup=t,this._bindings=t.subscribe_(e,i)}getValue(t,e){this.bind();const n=this._targetGroup.nCachedObjects_,i=this._bindings[n];void 0!==i&&i.getValue(t,e)}setValue(t,e){const n=this._bindings;for(let i=this._targetGroup.nCachedObjects_,r=n.length;i!==r;++i)n[i].setValue(t,e)}bind(){const t=this._bindings;for(let e=this._targetGroup.nCachedObjects_,n=t.length;e!==n;++e)t[e].bind()}unbind(){const t=this._bindings;for(let e=this._targetGroup.nCachedObjects_,n=t.length;e!==n;++e)t[e].unbind()}},jc.prototype.BindingType={Direct:0,EntireArray:1,ArrayElement:2,HasFromToArray:3},jc.prototype.Versioning={None:0,NeedsUpdate:1,MatrixWorldNeedsUpdate:2},jc.prototype.GetterByBindingType=[jc.prototype._getValue_direct,jc.prototype._getValue_array,jc.prototype._getValue_arrayElement,jc.prototype._getValue_toArray],jc.prototype.SetterByBindingTypeAndVersioning=[[jc.prototype._setValue_direct,jc.prototype._setValue_direct_setNeedsUpdate,jc.prototype._setValue_direct_setMatrixWorldNeedsUpdate],[jc.prototype._setValue_array,jc.prototype._setValue_array_setNeedsUpdate,jc.prototype._setValue_array_setMatrixWorldNeedsUpdate],[jc.prototype._setValue_arrayElement,jc.prototype._setValue_arrayElement_setNeedsUpdate,jc.prototype._setValue_arrayElement_setMatrixWorldNeedsUpdate],[jc.prototype._setValue_fromArray,jc.prototype._setValue_fromArray_setNeedsUpdate,jc.prototype._setValue_fromArray_setMatrixWorldNeedsUpdate]];class qc{constructor(){this.uuid=ct(),this._objects=Array.prototype.slice.call(arguments),this.nCachedObjects_=0;const t={};this._indicesByUUID=t;for(let e=0,n=arguments.length;e!==n;++e)t[arguments[e].uuid]=e;this._paths=[],this._parsedPaths=[],this._bindings=[],this._bindingsIndicesByPath={};const e=this;this.stats={objects:{get total(){return e._objects.length},get inUse(){return this.total-e.nCachedObjects_}},get bindingsPerObject(){return e._bindings.length}}}add(){const t=this._objects,e=this._indicesByUUID,n=this._paths,i=this._parsedPaths,r=this._bindings,s=r.length;let a,o=t.length,l=this.nCachedObjects_;for(let c=0,h=arguments.length;c!==h;++c){const h=arguments[c],u=h.uuid;let d=e[u];if(void 0===d){d=o++,e[u]=d,t.push(h);for(let t=0,e=s;t!==e;++t)r[t].push(new jc(h,n[t],i[t]))}else if(d<l){a=t[d];const o=--l,c=t[o];e[c.uuid]=d,t[d]=c,e[u]=o,t[o]=h;for(let t=0,e=s;t!==e;++t){const e=r[t],s=e[o];let a=e[d];e[d]=s,void 0===a&&(a=new jc(h,n[t],i[t])),e[o]=a}}else t[d]!==a&&console.error("THREE.AnimationObjectGroup: Different objects with the same UUID detected. Clean the caches or recreate your infrastructure when reloading scenes.")}this.nCachedObjects_=l}remove(){const t=this._objects,e=this._indicesByUUID,n=this._bindings,i=n.length;let r=this.nCachedObjects_;for(let s=0,a=arguments.length;s!==a;++s){const a=arguments[s],o=a.uuid,l=e[o];if(void 0!==l&&l>=r){const s=r++,c=t[s];e[c.uuid]=l,t[l]=c,e[o]=s,t[s]=a;for(let t=0,e=i;t!==e;++t){const e=n[t],i=e[s],r=e[l];e[l]=i,e[s]=r}}}this.nCachedObjects_=r}uncache(){const t=this._objects,e=this._indicesByUUID,n=this._bindings,i=n.length;let r=this.nCachedObjects_,s=t.length;for(let a=0,o=arguments.length;a!==o;++a){const o=arguments[a].uuid,l=e[o];if(void 0!==l)if(delete e[o],l<r){const a=--r,o=t[a],c=--s,h=t[c];e[o.uuid]=l,t[l]=o,e[h.uuid]=a,t[a]=h,t.pop();for(let t=0,e=i;t!==e;++t){const e=n[t],i=e[a],r=e[c];e[l]=i,e[a]=r,e.pop()}}else{const r=--s,a=t[r];r>0&&(e[a.uuid]=l),t[l]=a,t.pop();for(let t=0,e=i;t!==e;++t){const e=n[t];e[l]=e[r],e.pop()}}}this.nCachedObjects_=r}subscribe_(t,e){const n=this._bindingsIndicesByPath;let i=n[t];const r=this._bindings;if(void 0!==i)return r[i];const s=this._paths,a=this._parsedPaths,o=this._objects,l=o.length,c=this.nCachedObjects_,h=new Array(l);i=r.length,n[t]=i,s.push(t),a.push(e),r.push(h);for(let n=c,i=o.length;n!==i;++n){const i=o[n];h[n]=new jc(i,t,e)}return h}unsubscribe_(t){const e=this._bindingsIndicesByPath,n=e[t];if(void 0!==n){const i=this._paths,r=this._parsedPaths,s=this._bindings,a=s.length-1,o=s[a];e[t[a]]=n,s[n]=o,s.pop(),r[n]=r[a],r.pop(),i[n]=i[a],i.pop()}}}qc.prototype.isAnimationObjectGroup=!0;class Xc{constructor(t,e,n=null,i=e.blendMode){this._mixer=t,this._clip=e,this._localRoot=n,this.blendMode=i;const r=e.tracks,s=r.length,a=new Array(s),o={endingStart:k,endingEnd:k};for(let t=0;t!==s;++t){const e=r[t].createInterpolant(null);a[t]=e,e.settings=o}this._interpolantSettings=o,this._interpolants=a,this._propertyBindings=new Array(s),this._cacheIndex=null,this._byClipCacheIndex=null,this._timeScaleInterpolant=null,this._weightInterpolant=null,this.loop=2201,this._loopCount=-1,this._startTime=null,this.time=0,this.timeScale=1,this._effectiveTimeScale=1,this.weight=1,this._effectiveWeight=1,this.repetitions=1/0,this.paused=!1,this.enabled=!0,this.clampWhenFinished=!1,this.zeroSlopeAtStart=!0,this.zeroSlopeAtEnd=!0}play(){return this._mixer._activateAction(this),this}stop(){return this._mixer._deactivateAction(this),this.reset()}reset(){return this.paused=!1,this.enabled=!0,this.time=0,this._loopCount=-1,this._startTime=null,this.stopFading().stopWarping()}isRunning(){return this.enabled&&!this.paused&&0!==this.timeScale&&null===this._startTime&&this._mixer._isActiveAction(this)}isScheduled(){return this._mixer._isActiveAction(this)}startAt(t){return this._startTime=t,this}setLoop(t,e){return this.loop=t,this.repetitions=e,this}setEffectiveWeight(t){return this.weight=t,this._effectiveWeight=this.enabled?t:0,this.stopFading()}getEffectiveWeight(){return this._effectiveWeight}fadeIn(t){return this._scheduleFading(t,0,1)}fadeOut(t){return this._scheduleFading(t,1,0)}crossFadeFrom(t,e,n){if(t.fadeOut(e),this.fadeIn(e),n){const n=this._clip.duration,i=t._clip.duration,r=i/n,s=n/i;t.warp(1,r,e),this.warp(s,1,e)}return this}crossFadeTo(t,e,n){return t.crossFadeFrom(this,e,n)}stopFading(){const t=this._weightInterpolant;return null!==t&&(this._weightInterpolant=null,this._mixer._takeBackControlInterpolant(t)),this}setEffectiveTimeScale(t){return this.timeScale=t,this._effectiveTimeScale=this.paused?0:t,this.stopWarping()}getEffectiveTimeScale(){return this._effectiveTimeScale}setDuration(t){return this.timeScale=this._clip.duration/t,this.stopWarping()}syncWith(t){return this.time=t.time,this.timeScale=t.timeScale,this.stopWarping()}halt(t){return this.warp(this._effectiveTimeScale,0,t)}warp(t,e,n){const i=this._mixer,r=i.time,s=this.timeScale;let a=this._timeScaleInterpolant;null===a&&(a=i._lendControlInterpolant(),this._timeScaleInterpolant=a);const o=a.parameterPositions,l=a.sampleValues;return o[0]=r,o[1]=r+n,l[0]=t/s,l[1]=e/s,this}stopWarping(){const t=this._timeScaleInterpolant;return null!==t&&(this._timeScaleInterpolant=null,this._mixer._takeBackControlInterpolant(t)),this}getMixer(){return this._mixer}getClip(){return this._clip}getRoot(){return this._localRoot||this._mixer._root}_update(t,e,n,i){if(!this.enabled)return void this._updateWeight(t);const r=this._startTime;if(null!==r){const i=(t-r)*n;if(i<0||0===n)return;this._startTime=null,e=n*i}e*=this._updateTimeScale(t);const s=this._updateTime(e),a=this._updateWeight(t);if(a>0){const t=this._interpolants,e=this._propertyBindings;switch(this.blendMode){case q:for(let n=0,i=t.length;n!==i;++n)t[n].evaluate(s),e[n].accumulateAdditive(a);break;case j:default:for(let n=0,r=t.length;n!==r;++n)t[n].evaluate(s),e[n].accumulate(i,a)}}}_updateWeight(t){let e=0;if(this.enabled){e=this.weight;const n=this._weightInterpolant;if(null!==n){const i=n.evaluate(t)[0];e*=i,t>n.parameterPositions[1]&&(this.stopFading(),0===i&&(this.enabled=!1))}}return this._effectiveWeight=e,e}_updateTimeScale(t){let e=0;if(!this.paused){e=this.timeScale;const n=this._timeScaleInterpolant;if(null!==n){e*=n.evaluate(t)[0],t>n.parameterPositions[1]&&(this.stopWarping(),0===e?this.paused=!0:this.timeScale=e)}}return this._effectiveTimeScale=e,e}_updateTime(t){const e=this._clip.duration,n=this.loop;let i=this.time+t,r=this._loopCount;const s=2202===n;if(0===t)return-1===r?i:s&&1==(1&r)?e-i:i;if(2200===n){-1===r&&(this._loopCount=0,this._setEndings(!0,!0,!1));t:{if(i>=e)i=e;else{if(!(i<0)){this.time=i;break t}i=0}this.clampWhenFinished?this.paused=!0:this.enabled=!1,this.time=i,this._mixer.dispatchEvent({type:"finished",action:this,direction:t<0?-1:1})}}else{if(-1===r&&(t>=0?(r=0,this._setEndings(!0,0===this.repetitions,s)):this._setEndings(0===this.repetitions,!0,s)),i>=e||i<0){const n=Math.floor(i/e);i-=e*n,r+=Math.abs(n);const a=this.repetitions-r;if(a<=0)this.clampWhenFinished?this.paused=!0:this.enabled=!1,i=t>0?e:0,this.time=i,this._mixer.dispatchEvent({type:"finished",action:this,direction:t>0?1:-1});else{if(1===a){const e=t<0;this._setEndings(e,!e,s)}else this._setEndings(!1,!1,s);this._loopCount=r,this.time=i,this._mixer.dispatchEvent({type:"loop",action:this,loopDelta:n})}}else this.time=i;if(s&&1==(1&r))return e-i}return i}_setEndings(t,e,n){const i=this._interpolantSettings;n?(i.endingStart=V,i.endingEnd=V):(i.endingStart=t?this.zeroSlopeAtStart?V:k:W,i.endingEnd=e?this.zeroSlopeAtEnd?V:k:W)}_scheduleFading(t,e,n){const i=this._mixer,r=i.time;let s=this._weightInterpolant;null===s&&(s=i._lendControlInterpolant(),this._weightInterpolant=s);const a=s.parameterPositions,o=s.sampleValues;return a[0]=r,o[0]=e,a[1]=r+t,o[1]=n,this}}class Yc extends rt{constructor(t){super(),this._root=t,this._initMemoryManager(),this._accuIndex=0,this.time=0,this.timeScale=1}_bindAction(t,e){const n=t._localRoot||this._root,i=t._clip.tracks,r=i.length,s=t._propertyBindings,a=t._interpolants,o=n.uuid,l=this._bindingsByRootAndName;let c=l[o];void 0===c&&(c={},l[o]=c);for(let t=0;t!==r;++t){const r=i[t],l=r.name;let h=c[l];if(void 0!==h)s[t]=h;else{if(h=s[t],void 0!==h){null===h._cacheIndex&&(++h.referenceCount,this._addInactiveBinding(h,o,l));continue}const i=e&&e._propertyBindings[t].binding.parsedPath;h=new Nc(jc.create(n,l,i),r.ValueTypeName,r.getValueSize()),++h.referenceCount,this._addInactiveBinding(h,o,l),s[t]=h}a[t].resultBuffer=h.buffer}}_activateAction(t){if(!this._isActiveAction(t)){if(null===t._cacheIndex){const e=(t._localRoot||this._root).uuid,n=t._clip.uuid,i=this._actionsByClip[n];this._bindAction(t,i&&i.knownActions[0]),this._addInactiveAction(t,n,e)}const e=t._propertyBindings;for(let t=0,n=e.length;t!==n;++t){const n=e[t];0==n.useCount++&&(this._lendBinding(n),n.saveOriginalState())}this._lendAction(t)}}_deactivateAction(t){if(this._isActiveAction(t)){const e=t._propertyBindings;for(let t=0,n=e.length;t!==n;++t){const n=e[t];0==--n.useCount&&(n.restoreOriginalState(),this._takeBackBinding(n))}this._takeBackAction(t)}}_initMemoryManager(){this._actions=[],this._nActiveActions=0,this._actionsByClip={},this._bindings=[],this._nActiveBindings=0,this._bindingsByRootAndName={},this._controlInterpolants=[],this._nActiveControlInterpolants=0;const t=this;this.stats={actions:{get total(){return t._actions.length},get inUse(){return t._nActiveActions}},bindings:{get total(){return t._bindings.length},get inUse(){return t._nActiveBindings}},controlInterpolants:{get total(){return t._controlInterpolants.length},get inUse(){return t._nActiveControlInterpolants}}}}_isActiveAction(t){const e=t._cacheIndex;return null!==e&&e<this._nActiveActions}_addInactiveAction(t,e,n){const i=this._actions,r=this._actionsByClip;let s=r[e];if(void 0===s)s={knownActions:[t],actionByRoot:{}},t._byClipCacheIndex=0,r[e]=s;else{const e=s.knownActions;t._byClipCacheIndex=e.length,e.push(t)}t._cacheIndex=i.length,i.push(t),s.actionByRoot[n]=t}_removeInactiveAction(t){const e=this._actions,n=e[e.length-1],i=t._cacheIndex;n._cacheIndex=i,e[i]=n,e.pop(),t._cacheIndex=null;const r=t._clip.uuid,s=this._actionsByClip,a=s[r],o=a.knownActions,l=o[o.length-1],c=t._byClipCacheIndex;l._byClipCacheIndex=c,o[c]=l,o.pop(),t._byClipCacheIndex=null;delete a.actionByRoot[(t._localRoot||this._root).uuid],0===o.length&&delete s[r],this._removeInactiveBindingsForAction(t)}_removeInactiveBindingsForAction(t){const e=t._propertyBindings;for(let t=0,n=e.length;t!==n;++t){const n=e[t];0==--n.referenceCount&&this._removeInactiveBinding(n)}}_lendAction(t){const e=this._actions,n=t._cacheIndex,i=this._nActiveActions++,r=e[i];t._cacheIndex=i,e[i]=t,r._cacheIndex=n,e[n]=r}_takeBackAction(t){const e=this._actions,n=t._cacheIndex,i=--this._nActiveActions,r=e[i];t._cacheIndex=i,e[i]=t,r._cacheIndex=n,e[n]=r}_addInactiveBinding(t,e,n){const i=this._bindingsByRootAndName,r=this._bindings;let s=i[e];void 0===s&&(s={},i[e]=s),s[n]=t,t._cacheIndex=r.length,r.push(t)}_removeInactiveBinding(t){const e=this._bindings,n=t.binding,i=n.rootNode.uuid,r=n.path,s=this._bindingsByRootAndName,a=s[i],o=e[e.length-1],l=t._cacheIndex;o._cacheIndex=l,e[l]=o,e.pop(),delete a[r],0===Object.keys(a).length&&delete s[i]}_lendBinding(t){const e=this._bindings,n=t._cacheIndex,i=this._nActiveBindings++,r=e[i];t._cacheIndex=i,e[i]=t,r._cacheIndex=n,e[n]=r}_takeBackBinding(t){const e=this._bindings,n=t._cacheIndex,i=--this._nActiveBindings,r=e[i];t._cacheIndex=i,e[i]=t,r._cacheIndex=n,e[n]=r}_lendControlInterpolant(){const t=this._controlInterpolants,e=this._nActiveControlInterpolants++;let n=t[e];return void 0===n&&(n=new qo(new Float32Array(2),new Float32Array(2),1,this._controlInterpolantsResultBuffer),n.__cacheIndex=e,t[e]=n),n}_takeBackControlInterpolant(t){const e=this._controlInterpolants,n=t.__cacheIndex,i=--this._nActiveControlInterpolants,r=e[i];t.__cacheIndex=i,e[i]=t,r.__cacheIndex=n,e[n]=r}clipAction(t,e,n){const i=e||this._root,r=i.uuid;let s="string"==typeof t?nl.findByName(i,t):t;const a=null!==s?s.uuid:t,o=this._actionsByClip[a];let l=null;if(void 0===n&&(n=null!==s?s.blendMode:j),void 0!==o){const t=o.actionByRoot[r];if(void 0!==t&&t.blendMode===n)return t;l=o.knownActions[0],null===s&&(s=l._clip)}if(null===s)return null;const c=new Xc(this,s,e,n);return this._bindAction(c,l),this._addInactiveAction(c,a,r),c}existingAction(t,e){const n=e||this._root,i=n.uuid,r="string"==typeof t?nl.findByName(n,t):t,s=r?r.uuid:t,a=this._actionsByClip[s];return void 0!==a&&a.actionByRoot[i]||null}stopAllAction(){const t=this._actions;for(let e=this._nActiveActions-1;e>=0;--e)t[e].stop();return this}update(t){t*=this.timeScale;const e=this._actions,n=this._nActiveActions,i=this.time+=t,r=Math.sign(t),s=this._accuIndex^=1;for(let a=0;a!==n;++a){e[a]._update(i,t,r,s)}const a=this._bindings,o=this._nActiveBindings;for(let t=0;t!==o;++t)a[t].apply(s);return this}setTime(t){this.time=0;for(let t=0;t<this._actions.length;t++)this._actions[t].time=0;return this.update(t)}getRoot(){return this._root}uncacheClip(t){const e=this._actions,n=t.uuid,i=this._actionsByClip,r=i[n];if(void 0!==r){const t=r.knownActions;for(let n=0,i=t.length;n!==i;++n){const i=t[n];this._deactivateAction(i);const r=i._cacheIndex,s=e[e.length-1];i._cacheIndex=null,i._byClipCacheIndex=null,s._cacheIndex=r,e[r]=s,e.pop(),this._removeInactiveBindingsForAction(i)}delete i[n]}}uncacheRoot(t){const e=t.uuid,n=this._actionsByClip;for(const t in n){const i=n[t].actionByRoot[e];void 0!==i&&(this._deactivateAction(i),this._removeInactiveAction(i))}const i=this._bindingsByRootAndName[e];if(void 0!==i)for(const t in i){const e=i[t];e.restoreOriginalState(),this._removeInactiveBinding(e)}}uncacheAction(t,e){const n=this.existingAction(t,e);null!==n&&(this._deactivateAction(n),this._removeInactiveAction(n))}}Yc.prototype._controlInterpolantsResultBuffer=new Float32Array(1);class Zc{constructor(t){"string"==typeof t&&(console.warn("THREE.Uniform: Type parameter is no longer needed."),t=arguments[1]),this.value=t}clone(){return new Zc(void 0===this.value.clone?this.value:this.value.clone())}}class Jc extends Es{constructor(t,e,n=1){super(t,e),this.meshPerAttribute=n||1}copy(t){return super.copy(t),this.meshPerAttribute=t.meshPerAttribute,this}clone(t){const e=super.clone(t);return e.meshPerAttribute=this.meshPerAttribute,e}toJSON(t){const e=super.toJSON(t);return e.isInstancedInterleavedBuffer=!0,e.meshPerAttribute=this.meshPerAttribute,e}}Jc.prototype.isInstancedInterleavedBuffer=!0;class Qc{constructor(t,e,n,i,r){this.buffer=t,this.type=e,this.itemSize=n,this.elementSize=i,this.count=r,this.version=0}set needsUpdate(t){!0===t&&this.version++}setBuffer(t){return this.buffer=t,this}setType(t,e){return this.type=t,this.elementSize=e,this}setItemSize(t){return this.itemSize=t,this}setCount(t){return this.count=t,this}}Qc.prototype.isGLBufferAttribute=!0;function Kc(t,e){return t.distance-e.distance}function $c(t,e,n,i){if(t.layers.test(e.layers)&&t.raycast(e,n),!0===i){const i=t.children;for(let t=0,r=i.length;t<r;t++)$c(i[t],e,n,!0)}}const th=new vt;class eh{constructor(t=new vt(1/0,1/0),e=new vt(-1/0,-1/0)){this.min=t,this.max=e}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromPoints(t){this.makeEmpty();for(let e=0,n=t.length;e<n;e++)this.expandByPoint(t[e]);return this}setFromCenterAndSize(t,e){const n=th.copy(e).multiplyScalar(.5);return this.min.copy(t).sub(n),this.max.copy(t).add(n),this}clone(){return(new this.constructor).copy(this)}copy(t){return this.min.copy(t.min),this.max.copy(t.max),this}makeEmpty(){return this.min.x=this.min.y=1/0,this.max.x=this.max.y=-1/0,this}isEmpty(){return this.max.x<this.min.x||this.max.y<this.min.y}getCenter(t){return void 0===t&&(console.warn("THREE.Box2: .getCenter() target is now required"),t=new vt),this.isEmpty()?t.set(0,0):t.addVectors(this.min,this.max).multiplyScalar(.5)}getSize(t){return void 0===t&&(console.warn("THREE.Box2: .getSize() target is now required"),t=new vt),this.isEmpty()?t.set(0,0):t.subVectors(this.max,this.min)}expandByPoint(t){return this.min.min(t),this.max.max(t),this}expandByVector(t){return this.min.sub(t),this.max.add(t),this}expandByScalar(t){return this.min.addScalar(-t),this.max.addScalar(t),this}containsPoint(t){return!(t.x<this.min.x||t.x>this.max.x||t.y<this.min.y||t.y>this.max.y)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y}getParameter(t,e){return void 0===e&&(console.warn("THREE.Box2: .getParameter() target is now required"),e=new vt),e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y))}intersectsBox(t){return!(t.max.x<this.min.x||t.min.x>this.max.x||t.max.y<this.min.y||t.min.y>this.max.y)}clampPoint(t,e){return void 0===e&&(console.warn("THREE.Box2: .clampPoint() target is now required"),e=new vt),e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return th.copy(t).clamp(this.min,this.max).sub(t).length()}intersect(t){return this.min.max(t.min),this.max.min(t.max),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}}eh.prototype.isBox2=!0;const nh=new Lt,ih=new Lt;class rh{constructor(t=new Lt,e=new Lt){this.start=t,this.end=e}set(t,e){return this.start.copy(t),this.end.copy(e),this}copy(t){return this.start.copy(t.start),this.end.copy(t.end),this}getCenter(t){return void 0===t&&(console.warn("THREE.Line3: .getCenter() target is now required"),t=new Lt),t.addVectors(this.start,this.end).multiplyScalar(.5)}delta(t){return void 0===t&&(console.warn("THREE.Line3: .delta() target is now required"),t=new Lt),t.subVectors(this.end,this.start)}distanceSq(){return this.start.distanceToSquared(this.end)}distance(){return this.start.distanceTo(this.end)}at(t,e){return void 0===e&&(console.warn("THREE.Line3: .at() target is now required"),e=new Lt),this.delta(e).multiplyScalar(t).add(this.start)}closestPointToPointParameter(t,e){nh.subVectors(t,this.start),ih.subVectors(this.end,this.start);const n=ih.dot(ih);let i=ih.dot(nh)/n;return e&&(i=ht(i,0,1)),i}closestPointToPoint(t,e,n){const i=this.closestPointToPointParameter(t,e);return void 0===n&&(console.warn("THREE.Line3: .closestPointToPoint() target is now required"),n=new Lt),this.delta(n).multiplyScalar(i).add(this.start)}applyMatrix4(t){return this.start.applyMatrix4(t),this.end.applyMatrix4(t),this}equals(t){return t.start.equals(this.start)&&t.end.equals(this.end)}clone(){return(new this.constructor).copy(this)}}class sh extends Ce{constructor(t){super(),this.material=t,this.render=function(){},this.hasPositions=!1,this.hasNormals=!1,this.hasColors=!1,this.hasUvs=!1,this.positionArray=null,this.normalArray=null,this.colorArray=null,this.uvArray=null,this.count=0}}sh.prototype.isImmediateRenderObject=!0;const ah=new Lt;const oh=new Lt,lh=new se,ch=new se;class hh extends ya{constructor(t){const e=uh(t),n=new En,i=[],r=[],s=new tn(0,0,1),a=new tn(0,1,0);for(let t=0;t<e.length;t++){const n=e[t];n.parent&&n.parent.isBone&&(i.push(0,0,0),i.push(0,0,0),r.push(s.r,s.g,s.b),r.push(a.r,a.g,a.b))}n.setAttribute("position",new mn(i,3)),n.setAttribute("color",new mn(r,3));super(n,new ca({vertexColors:!0,depthTest:!1,depthWrite:!1,toneMapped:!1,transparent:!0})),this.type="SkeletonHelper",this.isSkeletonHelper=!0,this.root=t,this.bones=e,this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1}updateMatrixWorld(t){const e=this.bones,n=this.geometry,i=n.getAttribute("position");ch.copy(this.root.matrixWorld).invert();for(let t=0,n=0;t<e.length;t++){const r=e[t];r.parent&&r.parent.isBone&&(lh.multiplyMatrices(ch,r.matrixWorld),oh.setFromMatrixPosition(lh),i.setXYZ(n,oh.x,oh.y,oh.z),lh.multiplyMatrices(ch,r.parent.matrixWorld),oh.setFromMatrixPosition(lh),i.setXYZ(n+1,oh.x,oh.y,oh.z),n+=2)}n.getAttribute("position").needsUpdate=!0,super.updateMatrixWorld(t)}}function uh(t){const e=[];t&&t.isBone&&e.push(t);for(let n=0;n<t.children.length;n++)e.push.apply(e,uh(t.children[n]));return e}const dh=new Lt,ph=new tn,mh=new tn;class fh extends ya{constructor(t=10,e=10,n=4473924,i=8947848){n=new tn(n),i=new tn(i);const r=e/2,s=t/e,a=t/2,o=[],l=[];for(let t=0,c=0,h=-a;t<=e;t++,h+=s){o.push(-a,0,h,a,0,h),o.push(h,0,-a,h,0,a);const e=t===r?n:i;e.toArray(l,c),c+=3,e.toArray(l,c),c+=3,e.toArray(l,c),c+=3,e.toArray(l,c),c+=3}const c=new En;c.setAttribute("position",new mn(o,3)),c.setAttribute("color",new mn(l,3));super(c,new ca({vertexColors:!0,toneMapped:!1})),this.type="GridHelper"}}const gh=new Lt,vh=new Lt,yh=new Lt;const xh=new Lt,_h=new Qn;function wh(t,e,n,i,r,s,a){xh.set(r,s,a).unproject(i);const o=e[t];if(void 0!==o){const t=n.getAttribute("position");for(let e=0,n=o.length;e<n;e++)t.setXYZ(o[e],xh.x,xh.y,xh.z)}}const bh=new Pt;class Mh extends ya{constructor(t,e=16776960){const n=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]),i=new Float32Array(24),r=new En;r.setIndex(new sn(n,1)),r.setAttribute("position",new sn(i,3)),super(r,new ca({color:e,toneMapped:!1})),this.object=t,this.type="BoxHelper",this.matrixAutoUpdate=!1,this.update()}update(t){if(void 0!==t&&console.warn("THREE.BoxHelper: .update() has no longer arguments."),void 0!==this.object&&bh.setFromObject(this.object),bh.isEmpty())return;const e=bh.min,n=bh.max,i=this.geometry.attributes.position,r=i.array;r[0]=n.x,r[1]=n.y,r[2]=n.z,r[3]=e.x,r[4]=n.y,r[5]=n.z,r[6]=e.x,r[7]=e.y,r[8]=n.z,r[9]=n.x,r[10]=e.y,r[11]=n.z,r[12]=n.x,r[13]=n.y,r[14]=e.z,r[15]=e.x,r[16]=n.y,r[17]=e.z,r[18]=e.x,r[19]=e.y,r[20]=e.z,r[21]=n.x,r[22]=e.y,r[23]=e.z,i.needsUpdate=!0,this.geometry.computeBoundingSphere()}setFromObject(t){return this.object=t,this.update(),this}copy(t){return ya.prototype.copy.call(this,t),this.object=t.object,this}}const Sh=new Lt;let Th,Eh;class Ah extends ya{constructor(t=1){const e=[0,0,0,t,0,0,0,0,0,0,t,0,0,0,0,0,0,t],n=new En;n.setAttribute("position",new mn(e,3)),n.setAttribute("color",new mn([1,0,0,1,.6,0,0,1,0,.6,1,0,0,0,1,0,.6,1],3));super(n,new ca({vertexColors:!0,toneMapped:!1})),this.type="AxesHelper"}dispose(){this.geometry.dispose(),this.material.dispose()}}const Lh=new Float32Array(1),Rh=new Int32Array(Lh.buffer);const Ch=Math.pow(2,8),Ph=[.125,.215,.35,.446,.526,.582],Dh=5+Ph.length,Ih=20,Nh={[X]:0,[Y]:1,[J]:2,[Q]:3,[K]:4,[$]:5,[Z]:6},Bh=new en({side:1,depthWrite:!1,depthTest:!1}),zh=new Wn(new qn,Bh),Fh=new Jl,{_lodPlanes:Oh,_sizeLods:Hh,_sigmas:Gh}=Yh(),Uh=new tn;let kh=null;const Vh=(1+Math.sqrt(5))/2,Wh=1/Vh,jh=[new Lt(1,1,1),new Lt(-1,1,1),new Lt(1,1,-1),new Lt(-1,1,-1),new Lt(0,Vh,Wh),new Lt(0,Vh,-Wh),new Lt(Wh,0,Vh),new Lt(-Wh,0,Vh),new Lt(Vh,Wh,0),new Lt(-Vh,Wh,0)];function qh(t){const e=Math.max(t.r,t.g,t.b),n=Math.min(Math.max(Math.ceil(Math.log2(e)),-128),127);t.multiplyScalar(Math.pow(2,-n));return(n+128)/255}function Xh(t){return void 0!==t&&t.type===x&&(t.encoding===X||t.encoding===Y||t.encoding===Z)}function Yh(){const t=[],e=[],n=[];let i=8;for(let r=0;r<Dh;r++){const s=Math.pow(2,i);e.push(s);let a=1/s;r>4?a=Ph[r-8+4-1]:0==r&&(a=0),n.push(a);const o=1/(s-1),l=-o/2,c=1+o/2,h=[l,l,c,l,c,c,l,l,c,c,l,c],u=6,d=6,p=3,m=2,f=1,g=new Float32Array(p*d*u),v=new Float32Array(m*d*u),y=new Float32Array(f*d*u);for(let t=0;t<u;t++){const e=t%3*2/3-1,n=t>2?0:-1,i=[e,n,0,e+2/3,n,0,e+2/3,n+1,0,e,n,0,e+2/3,n+1,0,e,n+1,0];g.set(i,p*d*t),v.set(h,m*d*t);const r=[t,t,t,t,t,t];y.set(r,f*d*t)}const x=new En;x.setAttribute("position",new sn(g,p)),x.setAttribute("uv",new sn(v,m)),x.setAttribute("faceIndex",new sn(y,f)),t.push(x),i>4&&i--}return{_lodPlanes:t,_sizeLods:e,_sigmas:n}}function Zh(t){const e=new Tt(3*Ch,3*Ch,t);return e.texture.mapping=l,e.texture.name="PMREM.cubeUv",e.scissorTest=!0,e}function Jh(t,e,n,i,r){t.viewport.set(e,n,i,r),t.scissor.set(e,n,i,r)}function Qh(){const t=new vt(1,1);return new Io({name:"EquirectangularToCubeUV",uniforms:{envMap:{value:null},texelSize:{value:t},inputEncoding:{value:Nh[3e3]},outputEncoding:{value:Nh[3e3]}},vertexShader:$h(),fragmentShader:`\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 vec2 texelSize;\n\n\t\t\t${tu()}\n\n\t\t\t#include <common>\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\n\t\t\t\tvec3 outputDirection = normalize( vOutputDirection );\n\t\t\t\tvec2 uv = equirectUv( outputDirection );\n\n\t\t\t\tvec2 f = fract( uv / texelSize - 0.5 );\n\t\t\t\tuv -= f * texelSize;\n\t\t\t\tvec3 tl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x += texelSize.x;\n\t\t\t\tvec3 tr = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.y += texelSize.y;\n\t\t\t\tvec3 br = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x -= texelSize.x;\n\t\t\t\tvec3 bl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\n\t\t\t\tvec3 tm = mix( tl, tr, f.x );\n\t\t\t\tvec3 bm = mix( bl, br, f.x );\n\t\t\t\tgl_FragColor.rgb = mix( tm, bm, f.y );\n\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}function Kh(){return new Io({name:"CubemapToCubeUV",uniforms:{envMap:{value:null},inputEncoding:{value:Nh[3e3]},outputEncoding:{value:Nh[3e3]}},vertexShader:$h(),fragmentShader:`\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 samplerCube envMap;\n\n\t\t\t${tu()}\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb = envMapTexelToLinear( textureCube( envMap, vec3( - vOutputDirection.x, vOutputDirection.yz ) ) ).rgb;\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}function $h(){return"\n\n\t\tprecision mediump float;\n\t\tprecision mediump int;\n\n\t\tattribute vec3 position;\n\t\tattribute vec2 uv;\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"}function tu(){return"\n\n\t\tuniform int inputEncoding;\n\t\tuniform int outputEncoding;\n\n\t\t#include <encodings_pars_fragment>\n\n\t\tvec4 inputTexelToLinear( vec4 value ) {\n\n\t\t\tif ( inputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( inputEncoding == 1 ) {\n\n\t\t\t\treturn sRGBToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 2 ) {\n\n\t\t\t\treturn RGBEToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 3 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 7.0 );\n\n\t\t\t} else if ( inputEncoding == 4 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 16.0 );\n\n\t\t\t} else if ( inputEncoding == 5 ) {\n\n\t\t\t\treturn RGBDToLinear( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn GammaToLinear( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 linearToOutputTexel( vec4 value ) {\n\n\t\t\tif ( outputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( outputEncoding == 1 ) {\n\n\t\t\t\treturn LinearTosRGB( value );\n\n\t\t\t} else if ( outputEncoding == 2 ) {\n\n\t\t\t\treturn LinearToRGBE( value );\n\n\t\t\t} else if ( outputEncoding == 3 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 7.0 );\n\n\t\t\t} else if ( outputEncoding == 4 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 16.0 );\n\n\t\t\t} else if ( outputEncoding == 5 ) {\n\n\t\t\t\treturn LinearToRGBD( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn LinearToGamma( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 envMapTexelToLinear( vec4 color ) {\n\n\t\t\treturn inputTexelToLinear( color );\n\n\t\t}\n\t"}ml.create=function(t,e){return console.log("THREE.Curve.create() has been deprecated"),t.prototype=Object.create(ml.prototype),t.prototype.constructor=t,t.prototype.getPoint=e,t},Bl.prototype.fromPoints=function(t){return console.warn("THREE.Path: .fromPoints() has been renamed to .setFromPoints()."),this.setFromPoints(t)},fh.prototype.setColors=function(){console.error("THREE.GridHelper: setColors() has been deprecated, pass them in the constructor instead.")},hh.prototype.update=function(){console.error("THREE.SkeletonHelper: update() no longer needs to be called.")},ol.prototype.extractUrlBase=function(t){return console.warn("THREE.Loader: .extractUrlBase() has been deprecated. Use THREE.LoaderUtils.extractUrlBase() instead."),rc.extractUrlBase(t)},ol.Handlers={add:function(){console.error("THREE.Loader: Handlers.add() has been removed. Use LoadingManager.addHandler() instead.")},get:function(){console.error("THREE.Loader: Handlers.get() has been removed. Use LoadingManager.getHandler() instead.")}},eh.prototype.center=function(t){return console.warn("THREE.Box2: .center() has been renamed to .getCenter()."),this.getCenter(t)},eh.prototype.empty=function(){return console.warn("THREE.Box2: .empty() has been renamed to .isEmpty()."),this.isEmpty()},eh.prototype.isIntersectionBox=function(t){return console.warn("THREE.Box2: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(t)},eh.prototype.size=function(t){return console.warn("THREE.Box2: .size() has been renamed to .getSize()."),this.getSize(t)},Pt.prototype.center=function(t){return console.warn("THREE.Box3: .center() has been renamed to .getCenter()."),this.getCenter(t)},Pt.prototype.empty=function(){return console.warn("THREE.Box3: .empty() has been renamed to .isEmpty()."),this.isEmpty()},Pt.prototype.isIntersectionBox=function(t){return console.warn("THREE.Box3: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(t)},Pt.prototype.isIntersectionSphere=function(t){return console.warn("THREE.Box3: .isIntersectionSphere() has been renamed to .intersectsSphere()."),this.intersectsSphere(t)},Pt.prototype.size=function(t){return console.warn("THREE.Box3: .size() has been renamed to .getSize()."),this.getSize(t)},Jt.prototype.empty=function(){return console.warn("THREE.Sphere: .empty() has been renamed to .isEmpty()."),this.isEmpty()},ai.prototype.setFromMatrix=function(t){return console.warn("THREE.Frustum: .setFromMatrix() has been renamed to .setFromProjectionMatrix()."),this.setFromProjectionMatrix(t)},rh.prototype.center=function(t){return console.warn("THREE.Line3: .center() has been renamed to .getCenter()."),this.getCenter(t)},yt.prototype.flattenToArrayOffset=function(t,e){return console.warn("THREE.Matrix3: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."),this.toArray(t,e)},yt.prototype.multiplyVector3=function(t){return console.warn("THREE.Matrix3: .multiplyVector3() has been removed. Use vector.applyMatrix3( matrix ) instead."),t.applyMatrix3(this)},yt.prototype.multiplyVector3Array=function(){console.error("THREE.Matrix3: .multiplyVector3Array() has been removed.")},yt.prototype.applyToBufferAttribute=function(t){return console.warn("THREE.Matrix3: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix3( matrix ) instead."),t.applyMatrix3(this)},yt.prototype.applyToVector3Array=function(){console.error("THREE.Matrix3: .applyToVector3Array() has been removed.")},yt.prototype.getInverse=function(t){return console.warn("THREE.Matrix3: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."),this.copy(t).invert()},se.prototype.extractPosition=function(t){return console.warn("THREE.Matrix4: .extractPosition() has been renamed to .copyPosition()."),this.copyPosition(t)},se.prototype.flattenToArrayOffset=function(t,e){return console.warn("THREE.Matrix4: .flattenToArrayOffset() has been deprecated. Use .toArray() instead."),this.toArray(t,e)},se.prototype.getPosition=function(){return console.warn("THREE.Matrix4: .getPosition() has been removed. Use Vector3.setFromMatrixPosition( matrix ) instead."),(new Lt).setFromMatrixColumn(this,3)},se.prototype.setRotationFromQuaternion=function(t){return console.warn("THREE.Matrix4: .setRotationFromQuaternion() has been renamed to .makeRotationFromQuaternion()."),this.makeRotationFromQuaternion(t)},se.prototype.multiplyToArray=function(){console.warn("THREE.Matrix4: .multiplyToArray() has been removed.")},se.prototype.multiplyVector3=function(t){return console.warn("THREE.Matrix4: .multiplyVector3() has been removed. Use vector.applyMatrix4( matrix ) instead."),t.applyMatrix4(this)},se.prototype.multiplyVector4=function(t){return console.warn("THREE.Matrix4: .multiplyVector4() has been removed. Use vector.applyMatrix4( matrix ) instead."),t.applyMatrix4(this)},se.prototype.multiplyVector3Array=function(){console.error("THREE.Matrix4: .multiplyVector3Array() has been removed.")},se.prototype.rotateAxis=function(t){console.warn("THREE.Matrix4: .rotateAxis() has been removed. Use Vector3.transformDirection( matrix ) instead."),t.transformDirection(this)},se.prototype.crossVector=function(t){return console.warn("THREE.Matrix4: .crossVector() has been removed. Use vector.applyMatrix4( matrix ) instead."),t.applyMatrix4(this)},se.prototype.translate=function(){console.error("THREE.Matrix4: .translate() has been removed.")},se.prototype.rotateX=function(){console.error("THREE.Matrix4: .rotateX() has been removed.")},se.prototype.rotateY=function(){console.error("THREE.Matrix4: .rotateY() has been removed.")},se.prototype.rotateZ=function(){console.error("THREE.Matrix4: .rotateZ() has been removed.")},se.prototype.rotateByAxis=function(){console.error("THREE.Matrix4: .rotateByAxis() has been removed.")},se.prototype.applyToBufferAttribute=function(t){return console.warn("THREE.Matrix4: .applyToBufferAttribute() has been removed. Use attribute.applyMatrix4( matrix ) instead."),t.applyMatrix4(this)},se.prototype.applyToVector3Array=function(){console.error("THREE.Matrix4: .applyToVector3Array() has been removed.")},se.prototype.makeFrustum=function(t,e,n,i,r,s){return console.warn("THREE.Matrix4: .makeFrustum() has been removed. Use .makePerspective( left, right, top, bottom, near, far ) instead."),this.makePerspective(t,e,i,n,r,s)},se.prototype.getInverse=function(t){return console.warn("THREE.Matrix4: .getInverse() has been removed. Use matrixInv.copy( matrix ).invert(); instead."),this.copy(t).invert()},Ne.prototype.isIntersectionLine=function(t){return console.warn("THREE.Plane: .isIntersectionLine() has been renamed to .intersectsLine()."),this.intersectsLine(t)},At.prototype.multiplyVector3=function(t){return console.warn("THREE.Quaternion: .multiplyVector3() has been removed. Use is now vector.applyQuaternion( quaternion ) instead."),t.applyQuaternion(this)},At.prototype.inverse=function(){return console.warn("THREE.Quaternion: .inverse() has been renamed to invert()."),this.invert()},re.prototype.isIntersectionBox=function(t){return console.warn("THREE.Ray: .isIntersectionBox() has been renamed to .intersectsBox()."),this.intersectsBox(t)},re.prototype.isIntersectionPlane=function(t){return console.warn("THREE.Ray: .isIntersectionPlane() has been renamed to .intersectsPlane()."),this.intersectsPlane(t)},re.prototype.isIntersectionSphere=function(t){return console.warn("THREE.Ray: .isIntersectionSphere() has been renamed to .intersectsSphere()."),this.intersectsSphere(t)},je.prototype.area=function(){return console.warn("THREE.Triangle: .area() has been renamed to .getArea()."),this.getArea()},je.prototype.barycoordFromPoint=function(t,e){return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."),this.getBarycoord(t,e)},je.prototype.midpoint=function(t){return console.warn("THREE.Triangle: .midpoint() has been renamed to .getMidpoint()."),this.getMidpoint(t)},je.prototypenormal=function(t){return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."),this.getNormal(t)},je.prototype.plane=function(t){return console.warn("THREE.Triangle: .plane() has been renamed to .getPlane()."),this.getPlane(t)},je.barycoordFromPoint=function(t,e,n,i,r){return console.warn("THREE.Triangle: .barycoordFromPoint() has been renamed to .getBarycoord()."),je.getBarycoord(t,e,n,i,r)},je.normal=function(t,e,n,i){return console.warn("THREE.Triangle: .normal() has been renamed to .getNormal()."),je.getNormal(t,e,n,i)},zl.prototype.extractAllPoints=function(t){return console.warn("THREE.Shape: .extractAllPoints() has been removed. Use .extractPoints() instead."),this.extractPoints(t)},zl.prototype.extrude=function(t){return console.warn("THREE.Shape: .extrude() has been removed. Use ExtrudeGeometry() instead."),new go(this,t)},zl.prototype.makeGeometry=function(t){return console.warn("THREE.Shape: .makeGeometry() has been removed. Use ShapeGeometry() instead."),new Mo(this,t)},vt.prototype.fromAttribute=function(t,e,n){return console.warn("THREE.Vector2: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(t,e,n)},vt.prototype.distanceToManhattan=function(t){return console.warn("THREE.Vector2: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."),this.manhattanDistanceTo(t)},vt.prototype.lengthManhattan=function(){return console.warn("THREE.Vector2: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},Lt.prototype.setEulerFromRotationMatrix=function(){console.error("THREE.Vector3: .setEulerFromRotationMatrix() has been removed. Use Euler.setFromRotationMatrix() instead.")},Lt.prototype.setEulerFromQuaternion=function(){console.error("THREE.Vector3: .setEulerFromQuaternion() has been removed. Use Euler.setFromQuaternion() instead.")},Lt.prototype.getPositionFromMatrix=function(t){return console.warn("THREE.Vector3: .getPositionFromMatrix() has been renamed to .setFromMatrixPosition()."),this.setFromMatrixPosition(t)},Lt.prototype.getScaleFromMatrix=function(t){return console.warn("THREE.Vector3: .getScaleFromMatrix() has been renamed to .setFromMatrixScale()."),this.setFromMatrixScale(t)},Lt.prototype.getColumnFromMatrix=function(t,e){return console.warn("THREE.Vector3: .getColumnFromMatrix() has been renamed to .setFromMatrixColumn()."),this.setFromMatrixColumn(e,t)},Lt.prototype.applyProjection=function(t){return console.warn("THREE.Vector3: .applyProjection() has been removed. Use .applyMatrix4( m ) instead."),this.applyMatrix4(t)},Lt.prototype.fromAttribute=function(t,e,n){return console.warn("THREE.Vector3: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(t,e,n)},Lt.prototype.distanceToManhattan=function(t){return console.warn("THREE.Vector3: .distanceToManhattan() has been renamed to .manhattanDistanceTo()."),this.manhattanDistanceTo(t)},Lt.prototype.lengthManhattan=function(){return console.warn("THREE.Vector3: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},St.prototype.fromAttribute=function(t,e,n){return console.warn("THREE.Vector4: .fromAttribute() has been renamed to .fromBufferAttribute()."),this.fromBufferAttribute(t,e,n)},St.prototype.lengthManhattan=function(){return console.warn("THREE.Vector4: .lengthManhattan() has been renamed to .manhattanLength()."),this.manhattanLength()},Ce.prototype.getChildByName=function(t){return console.warn("THREE.Object3D: .getChildByName() has been renamed to .getObjectByName()."),this.getObjectByName(t)},Ce.prototype.renderDepth=function(){console.warn("THREE.Object3D: .renderDepth has been removed. Use .renderOrder, instead.")},Ce.prototype.translate=function(t,e){return console.warn("THREE.Object3D: .translate() has been removed. Use .translateOnAxis( axis, distance ) instead."),this.translateOnAxis(e,t)},Ce.prototype.getWorldRotation=function(){console.error("THREE.Object3D: .getWorldRotation() has been removed. Use THREE.Object3D.getWorldQuaternion( target ) instead.")},Ce.prototype.applyMatrix=function(t){return console.warn("THREE.Object3D: .applyMatrix() has been renamed to .applyMatrix4()."),this.applyMatrix4(t)},Object.defineProperties(Ce.prototype,{eulerOrder:{get:function(){return console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."),this.rotation.order},set:function(t){console.warn("THREE.Object3D: .eulerOrder is now .rotation.order."),this.rotation.order=t}},useQuaternion:{get:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")},set:function(){console.warn("THREE.Object3D: .useQuaternion has been removed. The library now uses quaternions by default.")}}}),Wn.prototype.setDrawMode=function(){console.error("THREE.Mesh: .setDrawMode() has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary.")},Object.defineProperties(Wn.prototype,{drawMode:{get:function(){return console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode."),0},set:function(){console.error("THREE.Mesh: .drawMode has been removed. The renderer now always assumes THREE.TrianglesDrawMode. Transform your geometry via BufferGeometryUtils.toTrianglesDrawMode() if necessary.")}}}),$s.prototype.initBones=function(){console.error("THREE.SkinnedMesh: initBones() has been removed.")},Kn.prototype.setLens=function(t,e){console.warn("THREE.PerspectiveCamera.setLens is deprecated. Use .setFocalLength and .filmGauge for a photographic setup."),void 0!==e&&(this.filmGauge=e),this.setFocalLength(t)},Object.defineProperties(Fl.prototype,{onlyShadow:{set:function(){console.warn("THREE.Light: .onlyShadow has been removed.")}},shadowCameraFov:{set:function(t){console.warn("THREE.Light: .shadowCameraFov is now .shadow.camera.fov."),this.shadow.camera.fov=t}},shadowCameraLeft:{set:function(t){console.warn("THREE.Light: .shadowCameraLeft is now .shadow.camera.left."),this.shadow.camera.left=t}},shadowCameraRight:{set:function(t){console.warn("THREE.Light: .shadowCameraRight is now .shadow.camera.right."),this.shadow.camera.right=t}},shadowCameraTop:{set:function(t){console.warn("THREE.Light: .shadowCameraTop is now .shadow.camera.top."),this.shadow.camera.top=t}},shadowCameraBottom:{set:function(t){console.warn("THREE.Light: .shadowCameraBottom is now .shadow.camera.bottom."),this.shadow.camera.bottom=t}},shadowCameraNear:{set:function(t){console.warn("THREE.Light: .shadowCameraNear is now .shadow.camera.near."),this.shadow.camera.near=t}},shadowCameraFar:{set:function(t){console.warn("THREE.Light: .shadowCameraFar is now .shadow.camera.far."),this.shadow.camera.far=t}},shadowCameraVisible:{set:function(){console.warn("THREE.Light: .shadowCameraVisible has been removed. Use new THREE.CameraHelper( light.shadow.camera ) instead.")}},shadowBias:{set:function(t){console.warn("THREE.Light: .shadowBias is now .shadow.bias."),this.shadow.bias=t}},shadowDarkness:{set:function(){console.warn("THREE.Light: .shadowDarkness has been removed.")}},shadowMapWidth:{set:function(t){console.warn("THREE.Light: .shadowMapWidth is now .shadow.mapSize.width."),this.shadow.mapSize.width=t}},shadowMapHeight:{set:function(t){console.warn("THREE.Light: .shadowMapHeight is now .shadow.mapSize.height."),this.shadow.mapSize.height=t}}}),Object.defineProperties(sn.prototype,{length:{get:function(){return console.warn("THREE.BufferAttribute: .length has been deprecated. Use .count instead."),this.array.length}},dynamic:{get:function(){return console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."),this.usage===nt},set:function(){console.warn("THREE.BufferAttribute: .dynamic has been deprecated. Use .usage instead."),this.setUsage(nt)}}}),sn.prototype.setDynamic=function(t){return console.warn("THREE.BufferAttribute: .setDynamic() has been deprecated. Use .setUsage() instead."),this.setUsage(!0===t?nt:et),this},sn.prototype.copyIndicesArray=function(){console.error("THREE.BufferAttribute: .copyIndicesArray() has been removed.")},sn.prototype.setArray=function(){console.error("THREE.BufferAttribute: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers")},En.prototype.addIndex=function(t){console.warn("THREE.BufferGeometry: .addIndex() has been renamed to .setIndex()."),this.setIndex(t)},En.prototype.addAttribute=function(t,e){return console.warn("THREE.BufferGeometry: .addAttribute() has been renamed to .setAttribute()."),e&&e.isBufferAttribute||e&&e.isInterleavedBufferAttribute?"index"===t?(console.warn("THREE.BufferGeometry.addAttribute: Use .setIndex() for index attribute."),this.setIndex(e),this):this.setAttribute(t,e):(console.warn("THREE.BufferGeometry: .addAttribute() now expects ( name, attribute )."),this.setAttribute(t,new sn(arguments[1],arguments[2])))},En.prototype.addDrawCall=function(t,e,n){void 0!==n&&console.warn("THREE.BufferGeometry: .addDrawCall() no longer supports indexOffset."),console.warn("THREE.BufferGeometry: .addDrawCall() is now .addGroup()."),this.addGroup(t,e)},En.prototype.clearDrawCalls=function(){console.warn("THREE.BufferGeometry: .clearDrawCalls() is now .clearGroups()."),this.clearGroups()},En.prototype.computeOffsets=function(){console.warn("THREE.BufferGeometry: .computeOffsets() has been removed.")},En.prototype.removeAttribute=function(t){return console.warn("THREE.BufferGeometry: .removeAttribute() has been renamed to .deleteAttribute()."),this.deleteAttribute(t)},En.prototype.applyMatrix=function(t){return console.warn("THREE.BufferGeometry: .applyMatrix() has been renamed to .applyMatrix4()."),this.applyMatrix4(t)},Object.defineProperties(En.prototype,{drawcalls:{get:function(){return console.error("THREE.BufferGeometry: .drawcalls has been renamed to .groups."),this.groups}},offsets:{get:function(){return console.warn("THREE.BufferGeometry: .offsets has been renamed to .groups."),this.groups}}}),Es.prototype.setDynamic=function(t){return console.warn("THREE.InterleavedBuffer: .setDynamic() has been deprecated. Use .setUsage() instead."),this.setUsage(!0===t?nt:et),this},Es.prototype.setArray=function(){console.error("THREE.InterleavedBuffer: .setArray has been removed. Use BufferGeometry .setAttribute to replace/resize attribute buffers")},go.prototype.getArrays=function(){console.error("THREE.ExtrudeGeometry: .getArrays() has been removed.")},go.prototype.addShapeList=function(){console.error("THREE.ExtrudeGeometry: .addShapeList() has been removed.")},go.prototype.addShape=function(){console.error("THREE.ExtrudeGeometry: .addShape() has been removed.")},Ts.prototype.dispose=function(){console.error("THREE.Scene: .dispose() has been removed.")},Zc.prototype.onUpdate=function(){return console.warn("THREE.Uniform: .onUpdate() has been removed. Use object.onBeforeRender() instead."),this},Object.defineProperties(Xe.prototype,{wrapAround:{get:function(){console.warn("THREE.Material: .wrapAround has been removed.")},set:function(){console.warn("THREE.Material: .wrapAround has been removed.")}},overdraw:{get:function(){console.warn("THREE.Material: .overdraw has been removed.")},set:function(){console.warn("THREE.Material: .overdraw has been removed.")}},wrapRGB:{get:function(){return console.warn("THREE.Material: .wrapRGB has been removed."),new tn}},shading:{get:function(){console.error("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead.")},set:function(t){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===t}},stencilMask:{get:function(){return console.warn("THREE."+this.type+": .stencilMask has been removed. Use .stencilFuncMask instead."),this.stencilFuncMask},set:function(t){console.warn("THREE."+this.type+": .stencilMask has been removed. Use .stencilFuncMask instead."),this.stencilFuncMask=t}}}),Object.defineProperties(Jn.prototype,{derivatives:{get:function(){return console.warn("THREE.ShaderMaterial: .derivatives has been moved to .extensions.derivatives."),this.extensions.derivatives},set:function(t){console.warn("THREE. ShaderMaterial: .derivatives has been moved to .extensions.derivatives."),this.extensions.derivatives=t}}}),ws.prototype.clearTarget=function(t,e,n,i){console.warn("THREE.WebGLRenderer: .clearTarget() has been deprecated. Use .setRenderTarget() and .clear() instead."),this.setRenderTarget(t),this.clear(e,n,i)},ws.prototype.animate=function(t){console.warn("THREE.WebGLRenderer: .animate() is now .setAnimationLoop()."),this.setAnimationLoop(t)},ws.prototype.getCurrentRenderTarget=function(){return console.warn("THREE.WebGLRenderer: .getCurrentRenderTarget() is now .getRenderTarget()."),this.getRenderTarget()},ws.prototype.getMaxAnisotropy=function(){return console.warn("THREE.WebGLRenderer: .getMaxAnisotropy() is now .capabilities.getMaxAnisotropy()."),this.capabilities.getMaxAnisotropy()},ws.prototype.getPrecision=function(){return console.warn("THREE.WebGLRenderer: .getPrecision() is now .capabilities.precision."),this.capabilities.precision},ws.prototype.resetGLState=function(){return console.warn("THREE.WebGLRenderer: .resetGLState() is now .state.reset()."),this.state.reset()},ws.prototype.supportsFloatTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsFloatTextures() is now .extensions.get( 'OES_texture_float' )."),this.extensions.get("OES_texture_float")},ws.prototype.supportsHalfFloatTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsHalfFloatTextures() is now .extensions.get( 'OES_texture_half_float' )."),this.extensions.get("OES_texture_half_float")},ws.prototype.supportsStandardDerivatives=function(){return console.warn("THREE.WebGLRenderer: .supportsStandardDerivatives() is now .extensions.get( 'OES_standard_derivatives' )."),this.extensions.get("OES_standard_derivatives")},ws.prototype.supportsCompressedTextureS3TC=function(){return console.warn("THREE.WebGLRenderer: .supportsCompressedTextureS3TC() is now .extensions.get( 'WEBGL_compressed_texture_s3tc' )."),this.extensions.get("WEBGL_compressed_texture_s3tc")},ws.prototype.supportsCompressedTexturePVRTC=function(){return console.warn("THREE.WebGLRenderer: .supportsCompressedTexturePVRTC() is now .extensions.get( 'WEBGL_compressed_texture_pvrtc' )."),this.extensions.get("WEBGL_compressed_texture_pvrtc")},ws.prototype.supportsBlendMinMax=function(){return console.warn("THREE.WebGLRenderer: .supportsBlendMinMax() is now .extensions.get( 'EXT_blend_minmax' )."),this.extensions.get("EXT_blend_minmax")},ws.prototype.supportsVertexTextures=function(){return console.warn("THREE.WebGLRenderer: .supportsVertexTextures() is now .capabilities.vertexTextures."),this.capabilities.vertexTextures},ws.prototype.supportsInstancedArrays=function(){return console.warn("THREE.WebGLRenderer: .supportsInstancedArrays() is now .extensions.get( 'ANGLE_instanced_arrays' )."),this.extensions.get("ANGLE_instanced_arrays")},ws.prototype.enableScissorTest=function(t){console.warn("THREE.WebGLRenderer: .enableScissorTest() is now .setScissorTest()."),this.setScissorTest(t)},ws.prototype.initMaterial=function(){console.warn("THREE.WebGLRenderer: .initMaterial() has been removed.")},ws.prototype.addPrePlugin=function(){console.warn("THREE.WebGLRenderer: .addPrePlugin() has been removed.")},ws.prototype.addPostPlugin=function(){console.warn("THREE.WebGLRenderer: .addPostPlugin() has been removed.")},ws.prototype.updateShadowMap=function(){console.warn("THREE.WebGLRenderer: .updateShadowMap() has been removed.")},ws.prototype.setFaceCulling=function(){console.warn("THREE.WebGLRenderer: .setFaceCulling() has been removed.")},ws.prototype.allocTextureUnit=function(){console.warn("THREE.WebGLRenderer: .allocTextureUnit() has been removed.")},ws.prototype.setTexture=function(){console.warn("THREE.WebGLRenderer: .setTexture() has been removed.")},ws.prototype.setTexture2D=function(){console.warn("THREE.WebGLRenderer: .setTexture2D() has been removed.")},ws.prototype.setTextureCube=function(){console.warn("THREE.WebGLRenderer: .setTextureCube() has been removed.")},ws.prototype.getActiveMipMapLevel=function(){return console.warn("THREE.WebGLRenderer: .getActiveMipMapLevel() is now .getActiveMipmapLevel()."),this.getActiveMipmapLevel()},Object.defineProperties(ws.prototype,{shadowMapEnabled:{get:function(){return this.shadowMap.enabled},set:function(t){console.warn("THREE.WebGLRenderer: .shadowMapEnabled is now .shadowMap.enabled."),this.shadowMap.enabled=t}},shadowMapType:{get:function(){return this.shadowMap.type},set:function(t){console.warn("THREE.WebGLRenderer: .shadowMapType is now .shadowMap.type."),this.shadowMap.type=t}},shadowMapCullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMapCullFace has been removed. Set Material.shadowSide instead.")}},context:{get:function(){return console.warn("THREE.WebGLRenderer: .context has been removed. Use .getContext() instead."),this.getContext()}},vr:{get:function(){return console.warn("THREE.WebGLRenderer: .vr has been renamed to .xr"),this.xr}},gammaInput:{get:function(){return console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead."),!1},set:function(){console.warn("THREE.WebGLRenderer: .gammaInput has been removed. Set the encoding for textures via Texture.encoding instead.")}},gammaOutput:{get:function(){return console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."),!1},set:function(t){console.warn("THREE.WebGLRenderer: .gammaOutput has been removed. Set WebGLRenderer.outputEncoding instead."),this.outputEncoding=!0===t?Y:X}},toneMappingWhitePoint:{get:function(){return console.warn("THREE.WebGLRenderer: .toneMappingWhitePoint has been removed."),1},set:function(){console.warn("THREE.WebGLRenderer: .toneMappingWhitePoint has been removed.")}}}),Object.defineProperties(us.prototype,{cullFace:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.cullFace has been removed. Set Material.shadowSide instead.")}},renderReverseSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderReverseSided has been removed. Set Material.shadowSide instead.")}},renderSingleSided:{get:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")},set:function(){console.warn("THREE.WebGLRenderer: .shadowMap.renderSingleSided has been removed. Set Material.shadowSide instead.")}}}),Object.defineProperties(Tt.prototype,{wrapS:{get:function(){return console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."),this.texture.wrapS},set:function(t){console.warn("THREE.WebGLRenderTarget: .wrapS is now .texture.wrapS."),this.texture.wrapS=t}},wrapT:{get:function(){return console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."),this.texture.wrapT},set:function(t){console.warn("THREE.WebGLRenderTarget: .wrapT is now .texture.wrapT."),this.texture.wrapT=t}},magFilter:{get:function(){return console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."),this.texture.magFilter},set:function(t){console.warn("THREE.WebGLRenderTarget: .magFilter is now .texture.magFilter."),this.texture.magFilter=t}},minFilter:{get:function(){return console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."),this.texture.minFilter},set:function(t){console.warn("THREE.WebGLRenderTarget: .minFilter is now .texture.minFilter."),this.texture.minFilter=t}},anisotropy:{get:function(){return console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."),this.texture.anisotropy},set:function(t){console.warn("THREE.WebGLRenderTarget: .anisotropy is now .texture.anisotropy."),this.texture.anisotropy=t}},offset:{get:function(){return console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."),this.texture.offset},set:function(t){console.warn("THREE.WebGLRenderTarget: .offset is now .texture.offset."),this.texture.offset=t}},repeat:{get:function(){return console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."),this.texture.repeat},set:function(t){console.warn("THREE.WebGLRenderTarget: .repeat is now .texture.repeat."),this.texture.repeat=t}},format:{get:function(){return console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."),this.texture.format},set:function(t){console.warn("THREE.WebGLRenderTarget: .format is now .texture.format."),this.texture.format=t}},type:{get:function(){return console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."),this.texture.type},set:function(t){console.warn("THREE.WebGLRenderTarget: .type is now .texture.type."),this.texture.type=t}},generateMipmaps:{get:function(){return console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."),this.texture.generateMipmaps},set:function(t){console.warn("THREE.WebGLRenderTarget: .generateMipmaps is now .texture.generateMipmaps."),this.texture.generateMipmaps=t}}}),Lc.prototype.load=function(t){console.warn("THREE.Audio: .load has been deprecated. Use THREE.AudioLoader instead.");const e=this;return(new vc).load(t,(function(t){e.setBuffer(t)})),this},Ic.prototype.getData=function(){return console.warn("THREE.AudioAnalyser: .getData() is now .getFrequencyData()."),this.getFrequencyData()},ti.prototype.updateCubeMap=function(t,e){return console.warn("THREE.CubeCamera: .updateCubeMap() is now .update()."),this.update(t,e)},ti.prototype.clear=function(t,e,n,i){return console.warn("THREE.CubeCamera: .clear() is now .renderTarget.clear()."),this.renderTarget.clear(t,e,n,i)},_t.crossOrigin=void 0,_t.loadTexture=function(t,e,n,i){console.warn("THREE.ImageUtils.loadTexture has been deprecated. Use THREE.TextureLoader() instead.");const r=new pl;r.setCrossOrigin(this.crossOrigin);const s=r.load(t,n,void 0,i);return e&&(s.mapping=e),s},_t.loadTextureCube=function(t,e,n,i){console.warn("THREE.ImageUtils.loadTextureCube has been deprecated. Use THREE.CubeTextureLoader() instead.");const r=new ul;r.setCrossOrigin(this.crossOrigin);const s=r.load(t,n,void 0,i);return e&&(s.mapping=e),s},_t.loadCompressedTexture=function(){console.error("THREE.ImageUtils.loadCompressedTexture has been removed. Use THREE.DDSLoader instead.")},_t.loadCompressedTextureCube=function(){console.error("THREE.ImageUtils.loadCompressedTextureCube has been removed. Use THREE.DDSLoader instead.")};const eu={createMultiMaterialObject:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")},detach:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")},attach:function(){console.error("THREE.SceneUtils has been moved to /examples/jsm/utils/SceneUtils.js")}};"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("register",{detail:{revision:e}})),"undefined"!=typeof window&&(window.__THREE__?console.warn("WARNING: Multiple instances of Three.js being imported."):window.__THREE__=e),t.ACESFilmicToneMapping=4,t.AddEquation=n,t.AddOperation=2,t.AdditiveAnimationBlendMode=q,t.AdditiveBlending=2,t.AlphaFormat=1021,t.AlwaysDepth=1,t.AlwaysStencilFunc=519,t.AmbientLight=$l,t.AmbientLightProbe=xc,t.AnimationClip=nl,t.AnimationLoader=class extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=new cl(this.manager);s.setPath(this.path),s.setRequestHeader(this.requestHeader),s.setWithCredentials(this.withCredentials),s.load(t,(function(n){try{e(r.parse(JSON.parse(n)))}catch(e){i?i(e):console.error(e),r.manager.itemError(t)}}),n,i)}parse(t){const e=[];for(let n=0;n<t.length;n++){const i=nl.parse(t[n]);e.push(i)}return e}},t.AnimationMixer=Yc,t.AnimationObjectGroup=qc,t.AnimationUtils=Vo,t.ArcCurve=gl,t.ArrayCamera=fs,t.ArrowHelper=class extends Ce{constructor(t=new Lt(0,0,1),e=new Lt(0,0,0),n=1,i=16776960,r=.2*n,s=.2*r){super(),this.type="ArrowHelper",void 0===Th&&(Th=new En,Th.setAttribute("position",new mn([0,0,0,0,1,0],3)),Eh=new Da(0,.5,1,5,1),Eh.translate(0,-.5,0)),this.position.copy(e),this.line=new fa(Th,new ca({color:i,toneMapped:!1})),this.line.matrixAutoUpdate=!1,this.add(this.line),this.cone=new Wn(Eh,new en({color:i,toneMapped:!1})),this.cone.matrixAutoUpdate=!1,this.add(this.cone),this.setDirection(t),this.setLength(n,r,s)}setDirection(t){if(t.y>.99999)this.quaternion.set(0,0,0,1);else if(t.y<-.99999)this.quaternion.set(1,0,0,0);else{Sh.set(t.z,0,-t.x).normalize();const e=Math.acos(t.y);this.quaternion.setFromAxisAngle(Sh,e)}}setLength(t,e=.2*t,n=.2*e){this.line.scale.set(1,Math.max(1e-4,t-e),1),this.line.updateMatrix(),this.cone.scale.set(n,e,n),this.cone.position.y=t,this.cone.updateMatrix()}setColor(t){this.line.material.color.set(t),this.cone.material.color.set(t)}copy(t){return super.copy(t,!1),this.line.copy(t.line),this.cone.copy(t.cone),this}},t.Audio=Lc,t.AudioAnalyser=Ic,t.AudioContext=gc,t.AudioListener=class extends Ce{constructor(){super(),this.type="AudioListener",this.context=gc.getContext(),this.gain=this.context.createGain(),this.gain.connect(this.context.destination),this.filter=null,this.timeDelta=0,this._clock=new bc}getInput(){return this.gain}removeFilter(){return null!==this.filter&&(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination),this.gain.connect(this.context.destination),this.filter=null),this}getFilter(){return this.filter}setFilter(t){return null!==this.filter?(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination)):this.gain.disconnect(this.context.destination),this.filter=t,this.gain.connect(this.filter),this.filter.connect(this.context.destination),this}getMasterVolume(){return this.gain.gain.value}setMasterVolume(t){return this.gain.gain.setTargetAtTime(t,this.context.currentTime,.01),this}updateMatrixWorld(t){super.updateMatrixWorld(t);const e=this.context.listener,n=this.up;if(this.timeDelta=this._clock.getDelta(),this.matrixWorld.decompose(Sc,Tc,Ec),Ac.set(0,0,-1).applyQuaternion(Tc),e.positionX){const t=this.context.currentTime+this.timeDelta;e.positionX.linearRampToValueAtTime(Sc.x,t),e.positionY.linearRampToValueAtTime(Sc.y,t),e.positionZ.linearRampToValueAtTime(Sc.z,t),e.forwardX.linearRampToValueAtTime(Ac.x,t),e.forwardY.linearRampToValueAtTime(Ac.y,t),e.forwardZ.linearRampToValueAtTime(Ac.z,t),e.upX.linearRampToValueAtTime(n.x,t),e.upY.linearRampToValueAtTime(n.y,t),e.upZ.linearRampToValueAtTime(n.z,t)}else e.setPosition(Sc.x,Sc.y,Sc.z),e.setOrientation(Ac.x,Ac.y,Ac.z,n.x,n.y,n.z)}},t.AudioLoader=vc,t.AxesHelper=Ah,t.AxisHelper=function(t){return console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper."),new Ah(t)},t.BackSide=1,t.BasicDepthPacking=3200,t.BasicShadowMap=0,t.BinaryTextureLoader=function(t){return console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader."),new dl(t)},t.Bone=ta,t.BooleanKeyframeTrack=Zo,t.BoundingBoxHelper=function(t,e){return console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead."),new Mh(t,e)},t.Box2=eh,t.Box3=Pt,t.Box3Helper=class extends ya{constructor(t,e=16776960){const n=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]),i=new En;i.setIndex(new sn(n,1)),i.setAttribute("position",new mn([1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],3)),super(i,new ca({color:e,toneMapped:!1})),this.box=t,this.type="Box3Helper",this.geometry.computeBoundingSphere()}updateMatrixWorld(t){const e=this.box;e.isEmpty()||(e.getCenter(this.position),e.getSize(this.scale),this.scale.multiplyScalar(.5),super.updateMatrixWorld(t))}},t.BoxBufferGeometry=qn,t.BoxGeometry=qn,t.BoxHelper=Mh,t.BufferAttribute=sn,t.BufferGeometry=En,t.BufferGeometryLoader=oc,t.ByteType=1010,t.Cache=rl,t.Camera=Qn,t.CameraHelper=class extends ya{constructor(t){const e=new En,n=new ca({color:16777215,vertexColors:!0,toneMapped:!1}),i=[],r=[],s={},a=new tn(16755200),o=new tn(16711680),l=new tn(43775),c=new tn(16777215),h=new tn(3355443);function u(t,e,n){d(t,n),d(e,n)}function d(t,e){i.push(0,0,0),r.push(e.r,e.g,e.b),void 0===s[t]&&(s[t]=[]),s[t].push(i.length/3-1)}u("n1","n2",a),u("n2","n4",a),u("n4","n3",a),u("n3","n1",a),u("f1","f2",a),u("f2","f4",a),u("f4","f3",a),u("f3","f1",a),u("n1","f1",a),u("n2","f2",a),u("n3","f3",a),u("n4","f4",a),u("p","n1",o),u("p","n2",o),u("p","n3",o),u("p","n4",o),u("u1","u2",l),u("u2","u3",l),u("u3","u1",l),u("c","t",c),u("p","c",h),u("cn1","cn2",h),u("cn3","cn4",h),u("cf1","cf2",h),u("cf3","cf4",h),e.setAttribute("position",new mn(i,3)),e.setAttribute("color",new mn(r,3)),super(e,n),this.type="CameraHelper",this.camera=t,this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.pointMap=s,this.update()}update(){const t=this.geometry,e=this.pointMap;_h.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),wh("c",e,t,_h,0,0,-1),wh("t",e,t,_h,0,0,1),wh("n1",e,t,_h,-1,-1,-1),wh("n2",e,t,_h,1,-1,-1),wh("n3",e,t,_h,-1,1,-1),wh("n4",e,t,_h,1,1,-1),wh("f1",e,t,_h,-1,-1,1),wh("f2",e,t,_h,1,-1,1),wh("f3",e,t,_h,-1,1,1),wh("f4",e,t,_h,1,1,1),wh("u1",e,t,_h,.7,1.1,-1),wh("u2",e,t,_h,-.7,1.1,-1),wh("u3",e,t,_h,0,2,-1),wh("cf1",e,t,_h,-1,0,1),wh("cf2",e,t,_h,1,0,1),wh("cf3",e,t,_h,0,-1,1),wh("cf4",e,t,_h,0,1,1),wh("cn1",e,t,_h,-1,0,-1),wh("cn2",e,t,_h,1,0,-1),wh("cn3",e,t,_h,0,-1,-1),wh("cn4",e,t,_h,0,1,-1),t.getAttribute("position").needsUpdate=!0}dispose(){this.geometry.dispose(),this.material.dispose()}},t.CanvasRenderer=function(){console.error("THREE.CanvasRenderer has been removed")},t.CanvasTexture=Ra,t.CatmullRomCurve3=bl,t.CineonToneMapping=3,t.CircleBufferGeometry=Pa,t.CircleGeometry=Pa,t.ClampToEdgeWrapping=u,t.Clock=bc,t.Color=tn,t.ColorKeyframeTrack=Jo,t.CompressedTexture=La,t.CompressedTextureLoader=class extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=[],a=new La,o=new cl(this.manager);o.setPath(this.path),o.setResponseType("arraybuffer"),o.setRequestHeader(this.requestHeader),o.setWithCredentials(r.withCredentials);let l=0;function c(c){o.load(t[c],(function(t){const n=r.parse(t,!0);s[c]={width:n.width,height:n.height,format:n.format,mipmaps:n.mipmaps},l+=1,6===l&&(1===n.mipmapCount&&(a.minFilter=g),a.image=s,a.format=n.format,a.needsUpdate=!0,e&&e(a))}),n,i)}if(Array.isArray(t))for(let e=0,n=t.length;e<n;++e)c(e);else o.load(t,(function(t){const n=r.parse(t,!0);if(n.isCubemap){const t=n.mipmaps.length/n.mipmapCount;for(let e=0;e<t;e++){s[e]={mipmaps:[]};for(let t=0;t<n.mipmapCount;t++)s[e].mipmaps.push(n.mipmaps[e*n.mipmapCount+t]),s[e].format=n.format,s[e].width=n.width,s[e].height=n.height}a.image=s}else a.image.width=n.width,a.image.height=n.height,a.mipmaps=n.mipmaps;1===n.mipmapCount&&(a.minFilter=g),a.format=n.format,a.needsUpdate=!0,e&&e(a)}),n,i);return a}},t.ConeBufferGeometry=Ia,t.ConeGeometry=Ia,t.CubeCamera=ti,t.CubeReflectionMapping=r,t.CubeRefractionMapping=s,t.CubeTexture=ei,t.CubeTextureLoader=ul,t.CubeUVReflectionMapping=l,t.CubeUVRefractionMapping=c,t.CubicBezierCurve=El,t.CubicBezierCurve3=Al,t.CubicInterpolant=jo,t.CullFaceBack=1,t.CullFaceFront=2,t.CullFaceFrontBack=3,t.CullFaceNone=0,t.Curve=ml,t.CurvePath=Nl,t.CustomBlending=5,t.CustomToneMapping=5,t.CylinderBufferGeometry=Da,t.CylinderGeometry=Da,t.Cylindrical=class{constructor(t=1,e=0,n=0){return this.radius=t,this.theta=e,this.y=n,this}set(t,e,n){return this.radius=t,this.theta=e,this.y=n,this}copy(t){return this.radius=t.radius,this.theta=t.theta,this.y=t.y,this}setFromVector3(t){return this.setFromCartesianCoords(t.x,t.y,t.z)}setFromCartesianCoords(t,e,n){return this.radius=Math.sqrt(t*t+n*n),this.theta=Math.atan2(t,n),this.y=e,this}clone(){return(new this.constructor).copy(this)}},t.DataTexture=ii,t.DataTexture2DArray=Ai,t.DataTexture3D=Li,t.DataTextureLoader=dl,t.DataUtils=class{static toHalfFloat(t){Lh[0]=t;const e=Rh[0];let n=e>>16&32768,i=e>>12&2047;const r=e>>23&255;return r<103?n:r>142?(n|=31744,n|=(255==r?0:1)&&8388607&e,n):r<113?(i|=2048,n|=(i>>114-r)+(i>>113-r&1),n):(n|=r-112<<10|i>>1,n+=1&i,n)}},t.DecrementStencilOp=7683,t.DecrementWrapStencilOp=34056,t.DefaultLoadingManager=al,t.DepthFormat=A,t.DepthStencilFormat=L,t.DepthTexture=Ca,t.DirectionalLight=Kl,t.DirectionalLightHelper=class extends Ce{constructor(t,e,n){super(),this.light=t,this.light.updateMatrixWorld(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.color=n,void 0===e&&(e=1);let i=new En;i.setAttribute("position",new mn([-e,e,0,e,e,0,e,-e,0,-e,-e,0,-e,e,0],3));const r=new ca({fog:!1,toneMapped:!1});this.lightPlane=new fa(i,r),this.add(this.lightPlane),i=new En,i.setAttribute("position",new mn([0,0,0,0,0,1],3)),this.targetLine=new fa(i,r),this.add(this.targetLine),this.update()}dispose(){this.lightPlane.geometry.dispose(),this.lightPlane.material.dispose(),this.targetLine.geometry.dispose(),this.targetLine.material.dispose()}update(){gh.setFromMatrixPosition(this.light.matrixWorld),vh.setFromMatrixPosition(this.light.target.matrixWorld),yh.subVectors(vh,gh),this.lightPlane.lookAt(vh),void 0!==this.color?(this.lightPlane.material.color.set(this.color),this.targetLine.material.color.set(this.color)):(this.lightPlane.material.color.copy(this.light.color),this.targetLine.material.color.copy(this.light.color)),this.targetLine.lookAt(vh),this.targetLine.scale.z=yh.length()}},t.DiscreteInterpolant=Xo,t.DodecahedronBufferGeometry=Ba,t.DodecahedronGeometry=Ba,t.DoubleSide=2,t.DstAlphaFactor=206,t.DstColorFactor=208,t.DynamicBufferAttribute=function(t,e){return console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead."),new sn(t,e).setUsage(nt)},t.DynamicCopyUsage=35050,t.DynamicDrawUsage=nt,t.DynamicReadUsage=35049,t.EdgesGeometry=Ga,t.EdgesHelper=function(t,e){return console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead."),new ya(new Ga(t.geometry),new ca({color:void 0!==e?e:16777215}))},t.EllipseCurve=fl,t.EqualDepth=4,t.EqualStencilFunc=514,t.EquirectangularReflectionMapping=a,t.EquirectangularRefractionMapping=o,t.Euler=fe,t.EventDispatcher=rt,t.ExtrudeBufferGeometry=go,t.ExtrudeGeometry=go,t.FaceColors=1,t.FileLoader=cl,t.FlatShading=1,t.Float16BufferAttribute=pn,t.Float32Attribute=function(t,e){return console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead."),new mn(t,e)},t.Float32BufferAttribute=mn,t.Float64Attribute=function(t,e){return console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead."),new fn(t,e)},t.Float64BufferAttribute=fn,t.FloatType=b,t.Fog=Ss,t.FogExp2=Ms,t.Font=pc,t.FontLoader=class extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=new cl(this.manager);s.setPath(this.path),s.setRequestHeader(this.requestHeader),s.setWithCredentials(r.withCredentials),s.load(t,(function(t){let n;try{n=JSON.parse(t)}catch(e){console.warn("THREE.FontLoader: typeface.js support is being deprecated. Use typeface.json instead."),n=JSON.parse(t.substring(65,t.length-2))}const i=r.parse(n);e&&e(i)}),n,i)}parse(t){return new pc(t)}},t.FrontSide=0,t.Frustum=ai,t.GLBufferAttribute=Qc,t.GLSL1="100",t.GLSL3=it,t.GammaEncoding=Z,t.GreaterDepth=6,t.GreaterEqualDepth=5,t.GreaterEqualStencilFunc=518,t.GreaterStencilFunc=516,t.GridHelper=fh,t.Group=gs,t.HalfFloatType=M,t.HemisphereLight=Ol,t.HemisphereLightHelper=class extends Ce{constructor(t,e,n){super(),this.light=t,this.light.updateMatrixWorld(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.color=n;const i=new _o(e);i.rotateY(.5*Math.PI),this.material=new en({wireframe:!0,fog:!1,toneMapped:!1}),void 0===this.color&&(this.material.vertexColors=!0);const r=i.getAttribute("position"),s=new Float32Array(3*r.count);i.setAttribute("color",new sn(s,3)),this.add(new Wn(i,this.material)),this.update()}dispose(){this.children[0].geometry.dispose(),this.children[0].material.dispose()}update(){const t=this.children[0];if(void 0!==this.color)this.material.color.set(this.color);else{const e=t.geometry.getAttribute("color");ph.copy(this.light.color),mh.copy(this.light.groundColor);for(let t=0,n=e.count;t<n;t++){const i=t<n/2?ph:mh;e.setXYZ(t,i.r,i.g,i.b)}e.needsUpdate=!0}t.lookAt(dh.setFromMatrixPosition(this.light.matrixWorld).negate())}},t.HemisphereLightProbe=yc,t.IcosahedronBufferGeometry=yo,t.IcosahedronGeometry=yo,t.ImageBitmapLoader=uc,t.ImageLoader=hl,t.ImageUtils=_t,t.ImmediateRenderObject=sh,t.IncrementStencilOp=7682,t.IncrementWrapStencilOp=34055,t.InstancedBufferAttribute=ac,t.InstancedBufferGeometry=sc,t.InstancedInterleavedBuffer=Jc,t.InstancedMesh=la,t.Int16Attribute=function(t,e){return console.warn("THREE.Int16Attribute has been removed. Use new THREE.Int16BufferAttribute() instead."),new cn(t,e)},t.Int16BufferAttribute=cn,t.Int32Attribute=function(t,e){return console.warn("THREE.Int32Attribute has been removed. Use new THREE.Int32BufferAttribute() instead."),new un(t,e)},t.Int32BufferAttribute=un,t.Int8Attribute=function(t,e){return console.warn("THREE.Int8Attribute has been removed. Use new THREE.Int8BufferAttribute() instead."),new an(t,e)},t.Int8BufferAttribute=an,t.IntType=1013,t.InterleavedBuffer=Es,t.InterleavedBufferAttribute=Ls,t.Interpolant=Wo,t.InterpolateDiscrete=H,t.InterpolateLinear=G,t.InterpolateSmooth=U,t.InvertStencilOp=5386,t.JSONLoader=function(){console.error("THREE.JSONLoader has been removed.")},t.KeepStencilOp=tt,t.KeyframeTrack=Yo,t.LOD=Xs,t.LatheBufferGeometry=xo,t.LatheGeometry=xo,t.Layers=ge,t.LensFlare=function(){console.error("THREE.LensFlare has been moved to /examples/jsm/objects/Lensflare.js")},t.LessDepth=2,t.LessEqualDepth=3,t.LessEqualStencilFunc=515,t.LessStencilFunc=513,t.Light=Fl,t.LightProbe=nc,t.Line=fa,t.Line3=rh,t.LineBasicMaterial=ca,t.LineCurve=Ll,t.LineCurve3=Rl,t.LineDashedMaterial=Uo,t.LineLoop=xa,t.LinePieces=1,t.LineSegments=ya,t.LineStrip=0,t.LinearEncoding=X,t.LinearFilter=g,t.LinearInterpolant=qo,t.LinearMipMapLinearFilter=1008,t.LinearMipMapNearestFilter=1007,t.LinearMipmapLinearFilter=y,t.LinearMipmapNearestFilter=v,t.LinearToneMapping=1,t.Loader=ol,t.LoaderUtils=rc,t.LoadingManager=sl,t.LogLuvEncoding=3003,t.LoopOnce=2200,t.LoopPingPong=2202,t.LoopRepeat=2201,t.LuminanceAlphaFormat=1025,t.LuminanceFormat=1024,t.MOUSE={LEFT:0,MIDDLE:1,RIGHT:2,ROTATE:0,DOLLY:1,PAN:2},t.Material=Xe,t.MaterialLoader=ic,t.Math=gt,t.MathUtils=gt,t.Matrix3=yt,t.Matrix4=se,t.MaxEquation=104,t.Mesh=Wn,t.MeshBasicMaterial=en,t.MeshDepthMaterial=cs,t.MeshDistanceMaterial=hs,t.MeshFaceMaterial=function(t){return console.warn("THREE.MeshFaceMaterial has been removed. Use an Array instead."),t},t.MeshLambertMaterial=Ho,t.MeshMatcapMaterial=Go,t.MeshNormalMaterial=Oo,t.MeshPhongMaterial=zo,t.MeshPhysicalMaterial=Bo,t.MeshStandardMaterial=No,t.MeshToonMaterial=Fo,t.MinEquation=103,t.MirroredRepeatWrapping=d,t.MixOperation=1,t.MultiMaterial=function(t=[]){return console.warn("THREE.MultiMaterial has been removed. Use an Array instead."),t.isMultiMaterial=!0,t.materials=t,t.clone=function(){return t.slice()},t},t.MultiplyBlending=4,t.MultiplyOperation=0,t.NearestFilter=p,t.NearestMipMapLinearFilter=1005,t.NearestMipMapNearestFilter=1004,t.NearestMipmapLinearFilter=f,t.NearestMipmapNearestFilter=m,t.NeverDepth=0,t.NeverStencilFunc=512,t.NoBlending=0,t.NoColors=0,t.NoToneMapping=0,t.NormalAnimationBlendMode=j,t.NormalBlending=1,t.NotEqualDepth=7,t.NotEqualStencilFunc=517,t.NumberKeyframeTrack=Qo,t.Object3D=Ce,t.ObjectLoader=class extends ol{constructor(t){super(t)}load(t,e,n,i){const r=this,s=""===this.path?rc.extractUrlBase(t):this.path;this.resourcePath=this.resourcePath||s;const a=new cl(this.manager);a.setPath(this.path),a.setRequestHeader(this.requestHeader),a.setWithCredentials(this.withCredentials),a.load(t,(function(n){let s=null;try{s=JSON.parse(n)}catch(e){return void 0!==i&&i(e),void console.error("THREE:ObjectLoader: Can't parse "+t+".",e.message)}const a=s.metadata;void 0!==a&&void 0!==a.type&&"geometry"!==a.type.toLowerCase()?r.parse(s,e):console.error("THREE.ObjectLoader: Can't load "+t)}),n,i)}parse(t,e){const n=this.parseAnimations(t.animations),i=this.parseShapes(t.shapes),r=this.parseGeometries(t.geometries,i),s=this.parseImages(t.images,(function(){void 0!==e&&e(l)})),a=this.parseTextures(t.textures,s),o=this.parseMaterials(t.materials,a),l=this.parseObject(t.object,r,o,n),c=this.parseSkeletons(t.skeletons,l);if(this.bindSkeletons(l,c),void 0!==e){let t=!1;for(const e in s)if(s[e]instanceof HTMLImageElement){t=!0;break}!1===t&&e(l)}return l}parseShapes(t){const e={};if(void 0!==t)for(let n=0,i=t.length;n<i;n++){const i=(new zl).fromJSON(t[n]);e[i.uuid]=i}return e}parseSkeletons(t,e){const n={},i={};if(e.traverse((function(t){t.isBone&&(i[t.uuid]=t)})),void 0!==t)for(let e=0,r=t.length;e<r;e++){const r=(new ia).fromJSON(t[e],i);n[r.uuid]=r}return n}parseGeometries(t,e){const n={};let i;if(void 0!==t){const r=new oc;for(let s=0,a=t.length;s<a;s++){let a;const o=t[s];switch(o.type){case"PlaneGeometry":case"PlaneBufferGeometry":a=new Po[o.type](o.width,o.height,o.widthSegments,o.heightSegments);break;case"BoxGeometry":case"BoxBufferGeometry":a=new Po[o.type](o.width,o.height,o.depth,o.widthSegments,o.heightSegments,o.depthSegments);break;case"CircleGeometry":case"CircleBufferGeometry":a=new Po[o.type](o.radius,o.segments,o.thetaStart,o.thetaLength);break;case"CylinderGeometry":case"CylinderBufferGeometry":a=new Po[o.type](o.radiusTop,o.radiusBottom,o.height,o.radialSegments,o.heightSegments,o.openEnded,o.thetaStart,o.thetaLength);break;case"ConeGeometry":case"ConeBufferGeometry":a=new Po[o.type](o.radius,o.height,o.radialSegments,o.heightSegments,o.openEnded,o.thetaStart,o.thetaLength);break;case"SphereGeometry":case"SphereBufferGeometry":a=new Po[o.type](o.radius,o.widthSegments,o.heightSegments,o.phiStart,o.phiLength,o.thetaStart,o.thetaLength);break;case"DodecahedronGeometry":case"DodecahedronBufferGeometry":case"IcosahedronGeometry":case"IcosahedronBufferGeometry":case"OctahedronGeometry":case"OctahedronBufferGeometry":case"TetrahedronGeometry":case"TetrahedronBufferGeometry":a=new Po[o.type](o.radius,o.detail);break;case"RingGeometry":case"RingBufferGeometry":a=new Po[o.type](o.innerRadius,o.outerRadius,o.thetaSegments,o.phiSegments,o.thetaStart,o.thetaLength);break;case"TorusGeometry":case"TorusBufferGeometry":a=new Po[o.type](o.radius,o.tube,o.radialSegments,o.tubularSegments,o.arc);break;case"TorusKnotGeometry":case"TorusKnotBufferGeometry":a=new Po[o.type](o.radius,o.tube,o.tubularSegments,o.radialSegments,o.p,o.q);break;case"TubeGeometry":case"TubeBufferGeometry":a=new Po[o.type]((new Il[o.path.type]).fromJSON(o.path),o.tubularSegments,o.radius,o.radialSegments,o.closed);break;case"LatheGeometry":case"LatheBufferGeometry":a=new Po[o.type](o.points,o.segments,o.phiStart,o.phiLength);break;case"PolyhedronGeometry":case"PolyhedronBufferGeometry":a=new Po[o.type](o.vertices,o.indices,o.radius,o.details);break;case"ShapeGeometry":case"ShapeBufferGeometry":i=[];for(let t=0,n=o.shapes.length;t<n;t++){const n=e[o.shapes[t]];i.push(n)}a=new Po[o.type](i,o.curveSegments);break;case"ExtrudeGeometry":case"ExtrudeBufferGeometry":i=[];for(let t=0,n=o.shapes.length;t<n;t++){const n=e[o.shapes[t]];i.push(n)}const t=o.options.extrudePath;void 0!==t&&(o.options.extrudePath=(new Il[t.type]).fromJSON(t)),a=new Po[o.type](i,o.options);break;case"BufferGeometry":case"InstancedBufferGeometry":a=r.parse(o);break;case"Geometry":console.error('THREE.ObjectLoader: Loading "Geometry" is not supported anymore.');break;default:console.warn('THREE.ObjectLoader: Unsupported geometry type "'+o.type+'"');continue}a.uuid=o.uuid,void 0!==o.name&&(a.name=o.name),!0===a.isBufferGeometry&&void 0!==o.userData&&(a.userData=o.userData),n[o.uuid]=a}}return n}parseMaterials(t,e){const n={},i={};if(void 0!==t){const r=new ic;r.setTextures(e);for(let e=0,s=t.length;e<s;e++){const s=t[e];if("MultiMaterial"===s.type){const t=[];for(let e=0;e<s.materials.length;e++){const i=s.materials[e];void 0===n[i.uuid]&&(n[i.uuid]=r.parse(i)),t.push(n[i.uuid])}i[s.uuid]=t}else void 0===n[s.uuid]&&(n[s.uuid]=r.parse(s)),i[s.uuid]=n[s.uuid]}}return i}parseAnimations(t){const e={};if(void 0!==t)for(let n=0;n<t.length;n++){const i=t[n],r=nl.parse(i);e[r.uuid]=r}return e}parseImages(t,e){const n=this,i={};let r;function s(t){if("string"==typeof t){const e=t;return function(t){return n.manager.itemStart(t),r.load(t,(function(){n.manager.itemEnd(t)}),void 0,(function(){n.manager.itemError(t),n.manager.itemEnd(t)}))}(/^(\/\/)|([a-z]+:(\/\/)?)/i.test(e)?e:n.resourcePath+e)}return t.data?{data:yn(t.type,t.data),width:t.width,height:t.height}:null}if(void 0!==t&&t.length>0){const n=new sl(e);r=new hl(n),r.setCrossOrigin(this.crossOrigin);for(let e=0,n=t.length;e<n;e++){const n=t[e],r=n.url;if(Array.isArray(r)){i[n.uuid]=[];for(let t=0,e=r.length;t<e;t++){const e=s(r[t]);null!==e&&(e instanceof HTMLImageElement?i[n.uuid].push(e):i[n.uuid].push(new ii(e.data,e.width,e.height)))}}else{const t=s(n.url);null!==t&&(i[n.uuid]=t)}}}return i}parseTextures(t,e){function n(t,e){return"number"==typeof t?t:(console.warn("THREE.ObjectLoader.parseTexture: Constant should be in numeric form.",t),e[t])}const i={};if(void 0!==t)for(let r=0,s=t.length;r<s;r++){const s=t[r];let a;void 0===s.image&&console.warn('THREE.ObjectLoader: No "image" specified for',s.uuid),void 0===e[s.image]&&console.warn("THREE.ObjectLoader: Undefined image",s.image);const o=e[s.image];Array.isArray(o)?(a=new ei(o),6===o.length&&(a.needsUpdate=!0)):(a=o&&o.data?new ii(o.data,o.width,o.height):new bt(o),o&&(a.needsUpdate=!0)),a.uuid=s.uuid,void 0!==s.name&&(a.name=s.name),void 0!==s.mapping&&(a.mapping=n(s.mapping,lc)),void 0!==s.offset&&a.offset.fromArray(s.offset),void 0!==s.repeat&&a.repeat.fromArray(s.repeat),void 0!==s.center&&a.center.fromArray(s.center),void 0!==s.rotation&&(a.rotation=s.rotation),void 0!==s.wrap&&(a.wrapS=n(s.wrap[0],cc),a.wrapT=n(s.wrap[1],cc)),void 0!==s.format&&(a.format=s.format),void 0!==s.type&&(a.type=s.type),void 0!==s.encoding&&(a.encoding=s.encoding),void 0!==s.minFilter&&(a.minFilter=n(s.minFilter,hc)),void 0!==s.magFilter&&(a.magFilter=n(s.magFilter,hc)),void 0!==s.anisotropy&&(a.anisotropy=s.anisotropy),void 0!==s.flipY&&(a.flipY=s.flipY),void 0!==s.premultiplyAlpha&&(a.premultiplyAlpha=s.premultiplyAlpha),void 0!==s.unpackAlignment&&(a.unpackAlignment=s.unpackAlignment),i[s.uuid]=a}return i}parseObject(t,e,n,i){let r,s,a;function o(t){return void 0===e[t]&&console.warn("THREE.ObjectLoader: Undefined geometry",t),e[t]}function l(t){if(void 0!==t){if(Array.isArray(t)){const e=[];for(let i=0,r=t.length;i<r;i++){const r=t[i];void 0===n[r]&&console.warn("THREE.ObjectLoader: Undefined material",r),e.push(n[r])}return e}return void 0===n[t]&&console.warn("THREE.ObjectLoader: Undefined material",t),n[t]}}switch(t.type){case"Scene":r=new Ts,void 0!==t.background&&Number.isInteger(t.background)&&(r.background=new tn(t.background)),void 0!==t.fog&&("Fog"===t.fog.type?r.fog=new Ss(t.fog.color,t.fog.near,t.fog.far):"FogExp2"===t.fog.type&&(r.fog=new Ms(t.fog.color,t.fog.density)));break;case"PerspectiveCamera":r=new Kn(t.fov,t.aspect,t.near,t.far),void 0!==t.focus&&(r.focus=t.focus),void 0!==t.zoom&&(r.zoom=t.zoom),void 0!==t.filmGauge&&(r.filmGauge=t.filmGauge),void 0!==t.filmOffset&&(r.filmOffset=t.filmOffset),void 0!==t.view&&(r.view=Object.assign({},t.view));break;case"OrthographicCamera":r=new Jl(t.left,t.right,t.top,t.bottom,t.near,t.far),void 0!==t.zoom&&(r.zoom=t.zoom),void 0!==t.view&&(r.view=Object.assign({},t.view));break;case"AmbientLight":r=new $l(t.color,t.intensity);break;case"DirectionalLight":r=new Kl(t.color,t.intensity);break;case"PointLight":r=new Zl(t.color,t.intensity,t.distance,t.decay);break;case"RectAreaLight":r=new tc(t.color,t.intensity,t.width,t.height);break;case"SpotLight":r=new Wl(t.color,t.intensity,t.distance,t.angle,t.penumbra,t.decay);break;case"HemisphereLight":r=new Ol(t.color,t.groundColor,t.intensity);break;case"LightProbe":r=(new nc).fromJSON(t);break;case"SkinnedMesh":s=o(t.geometry),a=l(t.material),r=new $s(s,a),void 0!==t.bindMode&&(r.bindMode=t.bindMode),void 0!==t.bindMatrix&&r.bindMatrix.fromArray(t.bindMatrix),void 0!==t.skeleton&&(r.skeleton=t.skeleton);break;case"Mesh":s=o(t.geometry),a=l(t.material),r=new Wn(s,a);break;case"InstancedMesh":s=o(t.geometry),a=l(t.material);const e=t.count,n=t.instanceMatrix,i=t.instanceColor;r=new la(s,a,e),r.instanceMatrix=new sn(new Float32Array(n.array),16),void 0!==i&&(r.instanceColor=new sn(new Float32Array(i.array),i.itemSize));break;case"LOD":r=new Xs;break;case"Line":r=new fa(o(t.geometry),l(t.material));break;case"LineLoop":r=new xa(o(t.geometry),l(t.material));break;case"LineSegments":r=new ya(o(t.geometry),l(t.material));break;case"PointCloud":case"Points":r=new Ta(o(t.geometry),l(t.material));break;case"Sprite":r=new Vs(l(t.material));break;case"Group":r=new gs;break;case"Bone":r=new ta;break;default:r=new Ce}if(r.uuid=t.uuid,void 0!==t.name&&(r.name=t.name),void 0!==t.matrix?(r.matrix.fromArray(t.matrix),void 0!==t.matrixAutoUpdate&&(r.matrixAutoUpdate=t.matrixAutoUpdate),r.matrixAutoUpdate&&r.matrix.decompose(r.position,r.quaternion,r.scale)):(void 0!==t.position&&r.position.fromArray(t.position),void 0!==t.rotation&&r.rotation.fromArray(t.rotation),void 0!==t.quaternion&&r.quaternion.fromArray(t.quaternion),void 0!==t.scale&&r.scale.fromArray(t.scale)),void 0!==t.castShadow&&(r.castShadow=t.castShadow),void 0!==t.receiveShadow&&(r.receiveShadow=t.receiveShadow),t.shadow&&(void 0!==t.shadow.bias&&(r.shadow.bias=t.shadow.bias),void 0!==t.shadow.normalBias&&(r.shadow.normalBias=t.shadow.normalBias),void 0!==t.shadow.radius&&(r.shadow.radius=t.shadow.radius),void 0!==t.shadow.mapSize&&r.shadow.mapSize.fromArray(t.shadow.mapSize),void 0!==t.shadow.camera&&(r.shadow.camera=this.parseObject(t.shadow.camera))),void 0!==t.visible&&(r.visible=t.visible),void 0!==t.frustumCulled&&(r.frustumCulled=t.frustumCulled),void 0!==t.renderOrder&&(r.renderOrder=t.renderOrder),void 0!==t.userData&&(r.userData=t.userData),void 0!==t.layers&&(r.layers.mask=t.layers),void 0!==t.children){const s=t.children;for(let t=0;t<s.length;t++)r.add(this.parseObject(s[t],e,n,i))}if(void 0!==t.animations){const e=t.animations;for(let t=0;t<e.length;t++){const n=e[t];r.animations.push(i[n])}}if("LOD"===t.type){void 0!==t.autoUpdate&&(r.autoUpdate=t.autoUpdate);const e=t.levels;for(let t=0;t<e.length;t++){const n=e[t],i=r.getObjectByProperty("uuid",n.object);void 0!==i&&r.addLevel(i,n.distance)}}return r}bindSkeletons(t,e){0!==Object.keys(e).length&&t.traverse((function(t){if(!0===t.isSkinnedMesh&&void 0!==t.skeleton){const n=e[t.skeleton];void 0===n?console.warn("THREE.ObjectLoader: No skeleton found with UUID:",t.skeleton):t.bind(n,t.bindMatrix)}}))}setTexturePath(t){return console.warn("THREE.ObjectLoader: .setTexturePath() has been renamed to .setResourcePath()."),this.setResourcePath(t)}},t.ObjectSpaceNormalMap=1,t.OctahedronBufferGeometry=_o,t.OctahedronGeometry=_o,t.OneFactor=201,t.OneMinusDstAlphaFactor=207,t.OneMinusDstColorFactor=209,t.OneMinusSrcAlphaFactor=205,t.OneMinusSrcColorFactor=203,t.OrthographicCamera=Jl,t.PCFShadowMap=1,t.PCFSoftShadowMap=2,t.PMREMGenerator=class{constructor(t){this._renderer=t,this._pingPongRenderTarget=null,this._blurMaterial=function(t){const e=new Float32Array(t),n=new Lt(0,1,0);return new Io({name:"SphericalGaussianBlur",defines:{n:t},uniforms:{envMap:{value:null},samples:{value:1},weights:{value:e},latitudinal:{value:!1},dTheta:{value:0},mipInt:{value:0},poleAxis:{value:n},inputEncoding:{value:Nh[3e3]},outputEncoding:{value:Nh[3e3]}},vertexShader:$h(),fragmentShader:`\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${tu()}\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include <cube_uv_reflection_fragment>\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\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}(Ih),this._equirectShader=null,this._cubemapShader=null,this._compileMaterial(this._blurMaterial)}fromScene(t,e=0,n=.1,i=100){kh=this._renderer.getRenderTarget();const r=this._allocateTargets();return this._sceneToCubeUV(t,n,i,r),e>0&&this._blur(r,0,0,e),this._applyPMREM(r),this._cleanup(r),r}fromEquirectangular(t){return this._fromTexture(t)}fromCubemap(t){return this._fromTexture(t)}compileCubemapShader(){null===this._cubemapShader&&(this._cubemapShader=Kh(),this._compileMaterial(this._cubemapShader))}compileEquirectangularShader(){null===this._equirectShader&&(this._equirectShader=Qh(),this._compileMaterial(this._equirectShader))}dispose(){this._blurMaterial.dispose(),null!==this._cubemapShader&&this._cubemapShader.dispose(),null!==this._equirectShader&&this._equirectShader.dispose();for(let t=0;t<Oh.length;t++)Oh[t].dispose()}_cleanup(t){this._pingPongRenderTarget.dispose(),this._renderer.setRenderTarget(kh),t.scissorTest=!1,Jh(t,0,0,t.width,t.height)}_fromTexture(t){kh=this._renderer.getRenderTarget();const e=this._allocateTargets(t);return this._textureToCubeUV(t,e),this._applyPMREM(e),this._cleanup(e),e}_allocateTargets(t){const e={magFilter:p,minFilter:p,generateMipmaps:!1,type:x,format:1023,encoding:Xh(t)?t.encoding:J,depthBuffer:!1},n=Zh(e);return n.depthBuffer=!t,this._pingPongRenderTarget=Zh(e),n}_compileMaterial(t){const e=new Wn(Oh[0],t);this._renderer.compile(e,Fh)}_sceneToCubeUV(t,e,n,i){const r=new Kn(90,1,e,n),s=[1,-1,1,1,1,1],a=[1,1,1,-1,-1,-1],o=this._renderer,l=o.autoClear,c=o.outputEncoding,h=o.toneMapping;o.getClearColor(Uh),o.toneMapping=0,o.outputEncoding=X,o.autoClear=!1;let u=!1;const d=t.background;if(d){if(d.isColor){Bh.color.copy(d).convertSRGBToLinear(),t.background=null;const e=qh(Bh.color);Bh.opacity=e,u=!0}}else{Bh.color.copy(Uh).convertSRGBToLinear();const t=qh(Bh.color);Bh.opacity=t,u=!0}for(let e=0;e<6;e++){const n=e%3;0==n?(r.up.set(0,s[e],0),r.lookAt(a[e],0,0)):1==n?(r.up.set(0,0,s[e]),r.lookAt(0,a[e],0)):(r.up.set(0,s[e],0),r.lookAt(0,0,a[e])),Jh(i,n*Ch,e>2?Ch:0,Ch,Ch),o.setRenderTarget(i),u&&o.render(zh,r),o.render(t,r)}o.toneMapping=h,o.outputEncoding=c,o.autoClear=l}_textureToCubeUV(t,e){const n=this._renderer;t.isCubeTexture?null==this._cubemapShader&&(this._cubemapShader=Kh()):null==this._equirectShader&&(this._equirectShader=Qh());const i=t.isCubeTexture?this._cubemapShader:this._equirectShader,r=new Wn(Oh[0],i),s=i.uniforms;s.envMap.value=t,t.isCubeTexture||s.texelSize.value.set(1/t.image.width,1/t.image.height),s.inputEncoding.value=Nh[t.encoding],s.outputEncoding.value=Nh[e.texture.encoding],Jh(e,0,0,3*Ch,2*Ch),n.setRenderTarget(e),n.render(r,Fh)}_applyPMREM(t){const e=this._renderer,n=e.autoClear;e.autoClear=!1;for(let e=1;e<Dh;e++){const n=Math.sqrt(Gh[e]*Gh[e]-Gh[e-1]*Gh[e-1]),i=jh[(e-1)%jh.length];this._blur(t,e-1,e,n,i)}e.autoClear=n}_blur(t,e,n,i,r){const s=this._pingPongRenderTarget;this._halfBlur(t,s,e,n,i,"latitudinal",r),this._halfBlur(s,t,n,n,i,"longitudinal",r)}_halfBlur(t,e,n,i,r,s,a){const o=this._renderer,l=this._blurMaterial;"latitudinal"!==s&&"longitudinal"!==s&&console.error("blur direction must be either latitudinal or longitudinal!");const c=new Wn(Oh[i],l),h=l.uniforms,u=Hh[n]-1,d=isFinite(r)?Math.PI/(2*u):2*Math.PI/39,p=r/d,m=isFinite(r)?1+Math.floor(3*p):Ih;m>Ih&&console.warn(`sigmaRadians, ${r}, is too large and will clip, as it requested ${m} samples when the maximum is set to 20`);const f=[];let g=0;for(let t=0;t<Ih;++t){const e=t/p,n=Math.exp(-e*e/2);f.push(n),0==t?g+=n:t<m&&(g+=2*n)}for(let t=0;t<f.length;t++)f[t]=f[t]/g;h.envMap.value=t.texture,h.samples.value=m,h.weights.value=f,h.latitudinal.value="latitudinal"===s,a&&(h.poleAxis.value=a),h.dTheta.value=d,h.mipInt.value=8-n,h.inputEncoding.value=Nh[t.texture.encoding],h.outputEncoding.value=Nh[t.texture.encoding];const v=Hh[i];Jh(e,3*Math.max(0,Ch-2*v),(0===i?0:2*Ch)+2*v*(i>4?i-8+4:0),3*v,2*v),o.setRenderTarget(e),o.render(c,Fh)}},t.ParametricBufferGeometry=wo,t.ParametricGeometry=wo,t.Particle=function(t){return console.warn("THREE.Particle has been renamed to THREE.Sprite."),new Vs(t)},t.ParticleBasicMaterial=function(t){return console.warn("THREE.ParticleBasicMaterial has been renamed to THREE.PointsMaterial."),new _a(t)},t.ParticleSystem=function(t,e){return console.warn("THREE.ParticleSystem has been renamed to THREE.Points."),new Ta(t,e)},t.ParticleSystemMaterial=function(t){return console.warn("THREE.ParticleSystemMaterial has been renamed to THREE.PointsMaterial."),new _a(t)},t.Path=Bl,t.PerspectiveCamera=Kn,t.Plane=Ne,t.PlaneBufferGeometry=ci,t.PlaneGeometry=ci,t.PlaneHelper=class extends fa{constructor(t,e=1,n=16776960){const i=n,r=new En;r.setAttribute("position",new mn([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],3)),r.computeBoundingSphere(),super(r,new ca({color:i,toneMapped:!1})),this.type="PlaneHelper",this.plane=t,this.size=e;const s=new En;s.setAttribute("position",new mn([1,1,1,-1,1,1,-1,-1,1,1,1,1,-1,-1,1,1,-1,1],3)),s.computeBoundingSphere(),this.add(new Wn(s,new en({color:i,opacity:.2,transparent:!0,depthWrite:!1,toneMapped:!1})))}updateMatrixWorld(t){let e=-this.plane.constant;Math.abs(e)<1e-8&&(e=1e-8),this.scale.set(.5*this.size,.5*this.size,e),this.children[0].material.side=e<0?1:0,this.lookAt(this.plane.normal),super.updateMatrixWorld(t)}},t.PointCloud=function(t,e){return console.warn("THREE.PointCloud has been renamed to THREE.Points."),new Ta(t,e)},t.PointCloudMaterial=function(t){return console.warn("THREE.PointCloudMaterial has been renamed to THREE.PointsMaterial."),new _a(t)},t.PointLight=Zl,t.PointLightHelper=class extends Wn{constructor(t,e,n){super(new So(e,4,2),new en({wireframe:!0,fog:!1,toneMapped:!1})),this.light=t,this.light.updateMatrixWorld(),this.color=n,this.type="PointLightHelper",this.matrix=this.light.matrixWorld,this.matrixAutoUpdate=!1,this.update()}dispose(){this.geometry.dispose(),this.material.dispose()}update(){void 0!==this.color?this.material.color.set(this.color):this.material.color.copy(this.light.color)}},t.Points=Ta,t.PointsMaterial=_a,t.PolarGridHelper=class extends ya{constructor(t=10,e=16,n=8,i=64,r=4473924,s=8947848){r=new tn(r),s=new tn(s);const a=[],o=[];for(let n=0;n<=e;n++){const i=n/e*(2*Math.PI),l=Math.sin(i)*t,c=Math.cos(i)*t;a.push(0,0,0),a.push(l,0,c);const h=1&n?r:s;o.push(h.r,h.g,h.b),o.push(h.r,h.g,h.b)}for(let e=0;e<=n;e++){const l=1&e?r:s,c=t-t/n*e;for(let t=0;t<i;t++){let e=t/i*(2*Math.PI),n=Math.sin(e)*c,r=Math.cos(e)*c;a.push(n,0,r),o.push(l.r,l.g,l.b),e=(t+1)/i*(2*Math.PI),n=Math.sin(e)*c,r=Math.cos(e)*c,a.push(n,0,r),o.push(l.r,l.g,l.b)}}const l=new En;l.setAttribute("position",new mn(a,3)),l.setAttribute("color",new mn(o,3));super(l,new ca({vertexColors:!0,toneMapped:!1})),this.type="PolarGridHelper"}},t.PolyhedronBufferGeometry=Na,t.PolyhedronGeometry=Na,t.PositionalAudio=class extends Lc{constructor(t){super(t),this.panner=this.context.createPanner(),this.panner.panningModel="HRTF",this.panner.connect(this.gain)}getOutput(){return this.panner}getRefDistance(){return this.panner.refDistance}setRefDistance(t){return this.panner.refDistance=t,this}getRolloffFactor(){return this.panner.rolloffFactor}setRolloffFactor(t){return this.panner.rolloffFactor=t,this}getDistanceModel(){return this.panner.distanceModel}setDistanceModel(t){return this.panner.distanceModel=t,this}getMaxDistance(){return this.panner.maxDistance}setMaxDistance(t){return this.panner.maxDistance=t,this}setDirectionalCone(t,e,n){return this.panner.coneInnerAngle=t,this.panner.coneOuterAngle=e,this.panner.coneOuterGain=n,this}updateMatrixWorld(t){if(super.updateMatrixWorld(t),!0===this.hasPlaybackControl&&!1===this.isPlaying)return;this.matrixWorld.decompose(Rc,Cc,Pc),Dc.set(0,0,1).applyQuaternion(Cc);const e=this.panner;if(e.positionX){const t=this.context.currentTime+this.listener.timeDelta;e.positionX.linearRampToValueAtTime(Rc.x,t),e.positionY.linearRampToValueAtTime(Rc.y,t),e.positionZ.linearRampToValueAtTime(Rc.z,t),e.orientationX.linearRampToValueAtTime(Dc.x,t),e.orientationY.linearRampToValueAtTime(Dc.y,t),e.orientationZ.linearRampToValueAtTime(Dc.z,t)}else e.setPosition(Rc.x,Rc.y,Rc.z),e.setOrientation(Dc.x,Dc.y,Dc.z)}},t.PropertyBinding=jc,t.PropertyMixer=Nc,t.QuadraticBezierCurve=Cl,t.QuadraticBezierCurve3=Pl,t.Quaternion=At,t.QuaternionKeyframeTrack=$o,t.QuaternionLinearInterpolant=Ko,t.REVISION=e,t.RGBADepthPacking=3201,t.RGBAFormat=E,t.RGBAIntegerFormat=1033,t.RGBA_ASTC_10x10_Format=37819,t.RGBA_ASTC_10x5_Format=37816,t.RGBA_ASTC_10x6_Format=37817,t.RGBA_ASTC_10x8_Format=37818,t.RGBA_ASTC_12x10_Format=37820,t.RGBA_ASTC_12x12_Format=37821,t.RGBA_ASTC_4x4_Format=37808,t.RGBA_ASTC_5x4_Format=37809,t.RGBA_ASTC_5x5_Format=37810,t.RGBA_ASTC_6x5_Format=37811,t.RGBA_ASTC_6x6_Format=37812,t.RGBA_ASTC_8x5_Format=37813,t.RGBA_ASTC_8x6_Format=37814,t.RGBA_ASTC_8x8_Format=37815,t.RGBA_BPTC_Format=36492,t.RGBA_ETC2_EAC_Format=O,t.RGBA_PVRTC_2BPPV1_Format=z,t.RGBA_PVRTC_4BPPV1_Format=B,t.RGBA_S3TC_DXT1_Format=C,t.RGBA_S3TC_DXT3_Format=P,t.RGBA_S3TC_DXT5_Format=D,t.RGBDEncoding=$,t.RGBEEncoding=J,t.RGBEFormat=1023,t.RGBFormat=T,t.RGBIntegerFormat=1032,t.RGBM16Encoding=K,t.RGBM7Encoding=Q,t.RGB_ETC1_Format=36196,t.RGB_ETC2_Format=F,t.RGB_PVRTC_2BPPV1_Format=N,t.RGB_PVRTC_4BPPV1_Format=I,t.RGB_S3TC_DXT1_Format=R,t.RGFormat=1030,t.RGIntegerFormat=1031,t.RawShaderMaterial=Io,t.Ray=re,t.Raycaster=class{constructor(t,e,n=0,i=1/0){this.ray=new re(t,e),this.near=n,this.far=i,this.camera=null,this.layers=new ge,this.params={Mesh:{},Line:{threshold:1},LOD:{},Points:{threshold:1},Sprite:{}}}set(t,e){this.ray.set(t,e)}setFromCamera(t,e){e&&e.isPerspectiveCamera?(this.ray.origin.setFromMatrixPosition(e.matrixWorld),this.ray.direction.set(t.x,t.y,.5).unproject(e).sub(this.ray.origin).normalize(),this.camera=e):e&&e.isOrthographicCamera?(this.ray.origin.set(t.x,t.y,(e.near+e.far)/(e.near-e.far)).unproject(e),this.ray.direction.set(0,0,-1).transformDirection(e.matrixWorld),this.camera=e):console.error("THREE.Raycaster: Unsupported camera type: "+e.type)}intersectObject(t,e=!1,n=[]){return $c(t,this,n,e),n.sort(Kc),n}intersectObjects(t,e=!1,n=[]){for(let i=0,r=t.length;i<r;i++)$c(t[i],this,n,e);return n.sort(Kc),n}},t.RectAreaLight=tc,t.RedFormat=1028,t.RedIntegerFormat=1029,t.ReinhardToneMapping=2,t.RepeatWrapping=h,t.ReplaceStencilOp=7681,t.ReverseSubtractEquation=102,t.RingBufferGeometry=bo,t.RingGeometry=bo,t.SRGB8_ALPHA8_ASTC_10x10_Format=37851,t.SRGB8_ALPHA8_ASTC_10x5_Format=37848,t.SRGB8_ALPHA8_ASTC_10x6_Format=37849,t.SRGB8_ALPHA8_ASTC_10x8_Format=37850,t.SRGB8_ALPHA8_ASTC_12x10_Format=37852,t.SRGB8_ALPHA8_ASTC_12x12_Format=37853,t.SRGB8_ALPHA8_ASTC_4x4_Format=37840,t.SRGB8_ALPHA8_ASTC_5x4_Format=37841,t.SRGB8_ALPHA8_ASTC_5x5_Format=37842,t.SRGB8_ALPHA8_ASTC_6x5_Format=37843,t.SRGB8_ALPHA8_ASTC_6x6_Format=37844,t.SRGB8_ALPHA8_ASTC_8x5_Format=37845,t.SRGB8_ALPHA8_ASTC_8x6_Format=37846,t.SRGB8_ALPHA8_ASTC_8x8_Format=37847,t.Scene=Ts,t.SceneUtils=eu,t.ShaderChunk=hi,t.ShaderLib=di,t.ShaderMaterial=Jn,t.ShadowMaterial=Do,t.Shape=zl,t.ShapeBufferGeometry=Mo,t.ShapeGeometry=Mo,t.ShapePath=dc,t.ShapeUtils=po,t.ShortType=1011,t.Skeleton=ia,t.SkeletonHelper=hh,t.SkinnedMesh=$s,t.SmoothShading=2,t.Sphere=Jt,t.SphereBufferGeometry=So,t.SphereGeometry=So,t.Spherical=class{constructor(t=1,e=0,n=0){return this.radius=t,this.phi=e,this.theta=n,this}set(t,e,n){return this.radius=t,this.phi=e,this.theta=n,this}copy(t){return this.radius=t.radius,this.phi=t.phi,this.theta=t.theta,this}makeSafe(){const t=1e-6;return this.phi=Math.max(t,Math.min(Math.PI-t,this.phi)),this}setFromVector3(t){return this.setFromCartesianCoords(t.x,t.y,t.z)}setFromCartesianCoords(t,e,n){return this.radius=Math.sqrt(t*t+e*e+n*n),0===this.radius?(this.theta=0,this.phi=0):(this.theta=Math.atan2(t,n),this.phi=Math.acos(ht(e/this.radius,-1,1))),this}clone(){return(new this.constructor).copy(this)}},t.SphericalHarmonics3=ec,t.SplineCurve=Dl,t.SpotLight=Wl,t.SpotLightHelper=class extends Ce{constructor(t,e){super(),this.light=t,this.light.updateMatrixWorld(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.color=e;const n=new En,i=[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];for(let t=0,e=1,n=32;t<n;t++,e++){const r=t/n*Math.PI*2,s=e/n*Math.PI*2;i.push(Math.cos(r),Math.sin(r),1,Math.cos(s),Math.sin(s),1)}n.setAttribute("position",new mn(i,3));const r=new ca({fog:!1,toneMapped:!1});this.cone=new ya(n,r),this.add(this.cone),this.update()}dispose(){this.cone.geometry.dispose(),this.cone.material.dispose()}update(){this.light.updateMatrixWorld();const t=this.light.distance?this.light.distance:1e3,e=t*Math.tan(this.light.angle);this.cone.scale.set(e,e,t),ah.setFromMatrixPosition(this.light.target.matrixWorld),this.cone.lookAt(ah),void 0!==this.color?this.cone.material.color.set(this.color):this.cone.material.color.copy(this.light.color)}},t.Sprite=Vs,t.SpriteMaterial=Rs,t.SrcAlphaFactor=204,t.SrcAlphaSaturateFactor=210,t.SrcColorFactor=202,t.StaticCopyUsage=35046,t.StaticDrawUsage=et,t.StaticReadUsage=35045,t.StereoCamera=class{constructor(){this.type="StereoCamera",this.aspect=1,this.eyeSep=.064,this.cameraL=new Kn,this.cameraL.layers.enable(1),this.cameraL.matrixAutoUpdate=!1,this.cameraR=new Kn,this.cameraR.layers.enable(2),this.cameraR.matrixAutoUpdate=!1,this._cache={focus:null,fov:null,aspect:null,near:null,far:null,zoom:null,eyeSep:null}}update(t){const e=this._cache;if(e.focus!==t.focus||e.fov!==t.fov||e.aspect!==t.aspect*this.aspect||e.near!==t.near||e.far!==t.far||e.zoom!==t.zoom||e.eyeSep!==this.eyeSep){e.focus=t.focus,e.fov=t.fov,e.aspect=t.aspect*this.aspect,e.near=t.near,e.far=t.far,e.zoom=t.zoom,e.eyeSep=this.eyeSep;const n=t.projectionMatrix.clone(),i=e.eyeSep/2,r=i*e.near/e.focus,s=e.near*Math.tan(ot*e.fov*.5)/e.zoom;let a,o;wc.elements[12]=-i,_c.elements[12]=i,a=-s*e.aspect+r,o=s*e.aspect+r,n.elements[0]=2*e.near/(o-a),n.elements[8]=(o+a)/(o-a),this.cameraL.projectionMatrix.copy(n),a=-s*e.aspect-r,o=s*e.aspect-r,n.elements[0]=2*e.near/(o-a),n.elements[8]=(o+a)/(o-a),this.cameraR.projectionMatrix.copy(n)}this.cameraL.matrixWorld.copy(t.matrixWorld).multiply(wc),this.cameraR.matrixWorld.copy(t.matrixWorld).multiply(_c)}},t.StreamCopyUsage=35042,t.StreamDrawUsage=35040,t.StreamReadUsage=35041,t.StringKeyframeTrack=tl,t.SubtractEquation=101,t.SubtractiveBlending=3,t.TOUCH={ROTATE:0,PAN:1,DOLLY_PAN:2,DOLLY_ROTATE:3},t.TangentSpaceNormalMap=0,t.TetrahedronBufferGeometry=To,t.TetrahedronGeometry=To,t.TextBufferGeometry=Eo,t.TextGeometry=Eo,t.Texture=bt,t.TextureLoader=pl,t.TorusBufferGeometry=Ao,t.TorusGeometry=Ao,t.TorusKnotBufferGeometry=Lo,t.TorusKnotGeometry=Lo,t.Triangle=je,t.TriangleFanDrawMode=2,t.TriangleStripDrawMode=1,t.TrianglesDrawMode=0,t.TubeBufferGeometry=Ro,t.TubeGeometry=Ro,t.UVMapping=i,t.Uint16Attribute=function(t,e){return console.warn("THREE.Uint16Attribute has been removed. Use new THREE.Uint16BufferAttribute() instead."),new hn(t,e)},t.Uint16BufferAttribute=hn,t.Uint32Attribute=function(t,e){return console.warn("THREE.Uint32Attribute has been removed. Use new THREE.Uint32BufferAttribute() instead."),new dn(t,e)},t.Uint32BufferAttribute=dn,t.Uint8Attribute=function(t,e){return console.warn("THREE.Uint8Attribute has been removed. Use new THREE.Uint8BufferAttribute() instead."),new on(t,e)},t.Uint8BufferAttribute=on,t.Uint8ClampedAttribute=function(t,e){return console.warn("THREE.Uint8ClampedAttribute has been removed. Use new THREE.Uint8ClampedBufferAttribute() instead."),new ln(t,e)},t.Uint8ClampedBufferAttribute=ln,t.Uniform=Zc,t.UniformsLib=ui,t.UniformsUtils=Zn,t.UnsignedByteType=x,t.UnsignedInt248Type=S,t.UnsignedIntType=w,t.UnsignedShort4444Type=1017,t.UnsignedShort5551Type=1018,t.UnsignedShort565Type=1019,t.UnsignedShortType=_,t.VSMShadowMap=3,t.Vector2=vt,t.Vector3=Lt,t.Vector4=St,t.VectorKeyframeTrack=el,t.Vertex=function(t,e,n){return console.warn("THREE.Vertex has been removed. Use THREE.Vector3 instead."),new Lt(t,e,n)},t.VertexColors=2,t.VideoTexture=Aa,t.WebGL1Renderer=bs,t.WebGLCubeRenderTarget=ni,t.WebGLMultisampleRenderTarget=Et,t.WebGLRenderTarget=Tt,t.WebGLRenderTargetCube=function(t,e,n){return console.warn("THREE.WebGLRenderTargetCube( width, height, options ) is now WebGLCubeRenderTarget( size, options )."),new ni(t,n)},t.WebGLRenderer=ws,t.WebGLUtils=ms,t.WireframeGeometry=Co,t.WireframeHelper=function(t,e){return console.warn("THREE.WireframeHelper has been removed. Use THREE.WireframeGeometry instead."),new ya(new Co(t.geometry),new ca({color:void 0!==e?e:16777215}))},t.WrapAroundEnding=W,t.XHRLoader=function(t){return console.warn("THREE.XHRLoader has been renamed to THREE.FileLoader."),new cl(t)},t.ZeroCurvatureEnding=k,t.ZeroFactor=200,t.ZeroSlopeEnding=V,t.ZeroStencilOp=0,t.sRGBEncoding=Y,Object.defineProperty(t,"__esModule",{value:!0})}));
diff --git a/src/imports/welcome.png b/src/imports/welcome.png
deleted file mode 100644 (file)
index 85e112e..0000000
Binary files a/src/imports/welcome.png and /dev/null differ