Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

math.gl

Package Overview
Dependencies
Maintainers
5
Versions
105
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

math.gl - npm Package Compare versions

Comparing version 1.0.0-alpha.8 to 1.0.0

dist-es6/vector.js

64

dist-es6/math-array.js

@@ -54,3 +54,3 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

import { config, formatValue, equals as _equals, checkNumber } from './common';
import { config, formatValue, equals as _equals } from './common';

@@ -80,4 +80,3 @@ var MathArray = function (_extendableBuiltin2) {

}
this.check();
return this;
return this.check();
}

@@ -94,4 +93,3 @@ }, {

}
this.check();
return this;
return this.check();
}

@@ -106,4 +104,3 @@ }, {

}
this.check();
return this;
return this.check();
}

@@ -166,44 +163,29 @@ }, {

}
// Modifiers
}, {
key: 'length',
value: function length() {
return Math.sqrt(this.lengthSquared());
}
}, {
key: 'lengthSquared',
value: function lengthSquared() {
var length = 0;
if (length !== 0) {
for (var i = 0; i < this.ELEMENTS; ++i) {
length += this[i] * this[i];
}
key: 'negate',
value: function negate() {
for (var i = 0; i < this.ELEMENTS; ++i) {
this[i] = -this[i];
}
return checkNumber(this);
return this.check();
}
}, {
key: 'distance',
value: function distance(mathArray) {
return Math.sqrt(this.distanceSquared(mathArray));
}
}, {
key: 'distanceSquared',
value: function distanceSquared(mathArray) {
var length = 0;
key: 'inverse',
value: function inverse() {
for (var i = 0; i < this.ELEMENTS; ++i) {
var dist = this[i] - mathArray[i];
length += dist * dist;
this[i] = 1 / this[i];
}
return checkNumber(length);
return this.check();
}
}, {
key: 'normalize',
value: function normalize() {
var length = this.length();
if (length !== 0) {
for (var i = 0; i < this.ELEMENTS; ++i) {
this[i] /= length;
}
key: 'lerp',
value: function lerp(vector, coeff) {
for (var i = 0; i < this.ELEMENTS; ++i) {
var coord = this[i];
this[i] = coord + coeff * (vector[0] - coord);
}
this.check();
return this;
return this.check();
}

@@ -240,2 +222,2 @@

export default MathArray;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/math-array.js"],"names":["config","formatValue","equals","checkNumber","MathArray","Subclass","constructor","clone","copy","check","array","i","ELEMENTS","args","offset","formatString","opts","string","printTypes","name","Float32Array","length","Math","sqrt","lengthSquared","mathArray","distanceSquared","dist","valid","Number","isFinite","debug","validate","Error","Array"],"mappings":"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","file":"math-array.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport {config, formatValue, equals, checkNumber} from './common';\n\nexport default class MathArray extends Array {\n\n  clone() {\n    const Subclass = this.constructor;\n    const clone = new Subclass().copy(this);\n    clone.check();\n    return clone;\n  }\n\n  copy(array) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i];\n    }\n    this.check();\n    return this;\n  }\n\n  set(...args) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = args[i] || 0;\n    }\n    this.check();\n    return this;\n  }\n\n  fromArray(array, offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i + offset];\n    }\n    this.check();\n    return this;\n  }\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString(opts) {\n    let string = '';\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      string += (i > 0 ? ', ' : '') + formatValue(this[i], opts);\n    }\n    return `${opts.printTypes ? this.constructor.name : ''}[${string}]`;\n  }\n\n  toArray(array = [], offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      array[offset + i] = this[i];\n    }\n    return array;\n  }\n\n  toFloat32Array() {\n    return new Float32Array(this);\n  }\n\n  equals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (!equals(this[i], array[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  exactEquals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (this[i] !== array[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  length() {\n    return Math.sqrt(this.lengthSquared());\n  }\n\n  lengthSquared() {\n    let length = 0;\n    if (length !== 0) {\n      for (let i = 0; i < this.ELEMENTS; ++i) {\n        length += this[i] * this[i];\n      }\n    }\n    return checkNumber(this);\n  }\n\n  distance(mathArray) {\n    return Math.sqrt(this.distanceSquared(mathArray));\n  }\n\n  distanceSquared(mathArray) {\n    let length = 0;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      const dist = this[i] - mathArray[i];\n      length += dist * dist;\n    }\n    return checkNumber(length);\n  }\n\n  normalize() {\n    const length = this.length();\n    if (length !== 0) {\n      for (let i = 0; i < this.ELEMENTS; ++i) {\n        this[i] /= length;\n      }\n    }\n    this.check();\n    return this;\n  }\n\n  // Debug checks\n\n  validate(array = this) {\n    let valid = array && array.length === this.ELEMENTS;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      valid = valid && Number.isFinite(array[i]);\n    }\n    return valid;\n  }\n\n  check(array = this) {\n    if (config.debug && !this.validate(array)) {\n      throw new Error(`Invalid ${this.constructor.name}`);\n    }\n    return this;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/math-array.js"],"names":["config","formatValue","equals","MathArray","Subclass","constructor","clone","copy","check","array","i","ELEMENTS","args","offset","formatString","opts","string","printTypes","name","Float32Array","length","vector","coeff","coord","valid","Number","isFinite","debug","validate","Error","Array"],"mappings":"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","file":"math-array.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport {config, formatValue, equals} from './common';\n\nexport default class MathArray extends Array {\n\n  clone() {\n    const Subclass = this.constructor;\n    const clone = new Subclass().copy(this);\n    clone.check();\n    return clone;\n  }\n\n  copy(array) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i];\n    }\n    return this.check();\n  }\n\n  set(...args) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = args[i] || 0;\n    }\n    return this.check();\n  }\n\n  fromArray(array, offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i + offset];\n    }\n    return this.check();\n  }\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString(opts) {\n    let string = '';\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      string += (i > 0 ? ', ' : '') + formatValue(this[i], opts);\n    }\n    return `${opts.printTypes ? this.constructor.name : ''}[${string}]`;\n  }\n\n  toArray(array = [], offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      array[offset + i] = this[i];\n    }\n    return array;\n  }\n\n  toFloat32Array() {\n    return new Float32Array(this);\n  }\n\n  equals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (!equals(this[i], array[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  exactEquals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (this[i] !== array[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  // Modifiers\n\n  negate() {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = -this[i];\n    }\n    return this.check();\n  }\n\n  inverse() {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = 1 / this[i];\n    }\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      const coord = this[i];\n      this[i] = coord + coeff * (vector[0] - coord);\n    }\n    return this.check();\n  }\n\n  // Debug checks\n\n  validate(array = this) {\n    let valid = array && array.length === this.ELEMENTS;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      valid = valid && Number.isFinite(array[i]);\n    }\n    return valid;\n  }\n\n  check(array = this) {\n    if (config.debug && !this.validate(array)) {\n      throw new Error(`Invalid ${this.constructor.name}`);\n    }\n    return this;\n  }\n}\n"]}

@@ -56,2 +56,4 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

var IDENTITY_QUATERNION = [0, 0, 0, 1];
export function validateQuaternion(q) {

@@ -328,4 +330,9 @@ return q.length === 4 && Number.isFinite(q[0]) && Number.isFinite(q[1]) && Number.isFinite(q[2]) && Number.isFinite(q[3]);

key: 'slerp',
value: function slerp(a, b, t) {
quat_slerp(this, a, b, t);
value: function slerp(_ref) {
var _ref$start = _ref.start,
start = _ref$start === undefined ? IDENTITY_QUATERNION : _ref$start,
target = _ref.target,
ratio = _ref.ratio;
quat_slerp(this, start, target, ratio);
this.check();

@@ -377,2 +384,2 @@ return this;

export default Quaternion;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/quaternion.js"],"names":["MathArray","checkNumber","quat_fromMat3","quat_identity","quat_length","quat_squaredLength","quat_dot","quat_rotationTo","quat_add","quat_calculateW","quat_conjugate","quat_invert","quat_lerp","quat_multiply","quat_normalize","quat_rotateX","quat_rotateY","quat_rotateZ","quat_scale","quat_set","quat_setAxisAngle","quat_slerp","validateQuaternion","q","length","Number","isFinite","Quaternion","x","y","z","w","Array","isArray","arguments","copy","set","m","check","a","b","undefined","Error","vectorA","vectorB","t","rad","i","j","k","l","axis","value"],"mappings":"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","file":"quaternion.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport quat_fromMat3 from 'gl-quat/fromMat3';\nimport quat_identity from 'gl-quat/identity';\nimport quat_length from 'gl-quat/length';\nimport quat_squaredLength from 'gl-quat/squaredLength';\nimport quat_dot from 'gl-quat/dot';\n// import quat_getAxisAngle from 'gl-quat/getAxisAngle';\nimport quat_rotationTo from 'gl-quat/rotationTo';\nimport quat_add from 'gl-quat/add';\nimport quat_calculateW from 'gl-quat/calculateW';\nimport quat_conjugate from 'gl-quat/conjugate';\nimport quat_invert from 'gl-quat/invert';\nimport quat_lerp from 'gl-quat/lerp';\nimport quat_multiply from 'gl-quat/multiply';\nimport quat_normalize from 'gl-quat/normalize';\nimport quat_rotateX from 'gl-quat/rotateX';\nimport quat_rotateY from 'gl-quat/rotateY';\nimport quat_rotateZ from 'gl-quat/rotateZ';\nimport quat_scale from 'gl-quat/scale';\nimport quat_set from 'gl-quat/set';\nimport quat_setAxisAngle from 'gl-quat/setAxisAngle';\nimport quat_slerp from 'gl-quat/slerp';\n\nexport function validateQuaternion(q) {\n  return q.length === 4 &&\n    Number.isFinite(q[0]) && Number.isFinite(q[1]) &&\n    Number.isFinite(q[2]) && Number.isFinite(q[3]);\n}\n\nexport default class Quaternion extends MathArray {\n  // Creates a new identity quat\n  constructor(x = 0, y = 0, z = 0, w = 1) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z, w);\n    }\n  }\n\n  // Creates a quaternion from the given 3x3 rotation matrix.\n  // NOTE: The resultant quaternion is not normalized, so you should\n  // be sure to renormalize the quaternion yourself where necessary.\n  fromMatrix3(m) {\n    quat_fromMat3(this, m);\n    this.check();\n    return this;\n  }\n\n  // Creates a new quat initialized with the given values\n  fromValues(x, y, z, w) {\n    return this.set(x, y, z, w);\n  }\n\n  // Set a quat to the identity quaternion\n  identity() {\n    quat_identity(this);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 4; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  get w()      { return this[3]; }\n  set w(value) { return this[3] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Calculates the length of a quat\n  length() {\n    return quat_length(this);\n  }\n\n  // Calculates the squared length of a quat\n  squaredLength(a) {\n    return quat_squaredLength(this);\n  }\n\n  // Calculates the dot product of two quat's\n  // @return {Number}\n  dot(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.dot only takes one argument');\n    }\n    return quat_dot(this, a);\n  }\n\n  // Gets the rotation axis and angle for a given quaternion.\n  // If a quaternion is created with setAxisAngle, this method will\n  // return the same values as providied in the original parameter\n  // list OR functionally equivalent values.\n  // Example: The quaternion formed by axis [0, 0, 1] and angle -90\n  // is the same as the quaternion formed by [0, 0, 1] and 270.\n  // This method favors the latter.\n  // @return {{[x,y,z], Number}}\n  // getAxisAngle() {\n  //   const axis = [];\n  //   const angle = quat_getAxisAngle(axis, this);\n  //   return {axis, angle};\n  // }\n\n  // MODIFIERS\n\n  // Sets a quaternion to represent the shortest rotation from one vector\n  // to another. Both vectors are assumed to be unit length.\n  rotationTo(vectorA, vectorB) {\n    quat_rotationTo(this, vectorA, vectorB);\n    this.check();\n    return this;\n  }\n\n  // Sets the specified quaternion with values corresponding to the given axes.\n  // Each axis is a vec3 and is expected to be unit length and perpendicular\n  // to all other specified axes.\n  // setAxes() {\n  //   Number\n  // }\n\n  // Performs a spherical linear interpolation with two control points\n  // sqlerp() {\n  //   Number;\n  // }\n\n  // Adds two quat's\n  add(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.add only takes one argument');\n    }\n    quat_add(this, a);\n    this.check();\n    return this;\n  }\n\n  // Calculates the W component of a quat from the X, Y, and Z components.\n  // Any existing W component will be ignored.\n  calculateW() {\n    quat_calculateW(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the conjugate of a quat If the quaternion is normalized,\n  // this function is faster than quat_inverse and produces the same result.\n  conjugate() {\n    quat_conjugate(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the inverse of a quat\n  invert() {\n    quat_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Performs a linear interpolation between two quat's\n  lerp(a, b, t) {\n    quat_lerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n\n  // Multiplies two quat's\n  multiply(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.multiply only takes one argument');\n    }\n    quat_multiply(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Normalize a quat\n  normalize() {\n    quat_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the X axis\n  rotateX(rad) {\n    quat_rotateX(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Y axis\n  rotateY(rad) {\n    quat_rotateY(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Z axis\n  rotateZ(rad) {\n    quat_rotateZ(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Scales a quat by a scalar number\n  scale(b) {\n    quat_scale(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Set the components of a quat to the given values\n  set(i, j, k, l) {\n    quat_set(this, i, j, k, l);\n    this.check();\n    return this;\n  }\n\n  // Sets a quat from the given angle and rotation axis, then returns it.\n  setAxisAngle(axis, rad) {\n    quat_setAxisAngle(this, axis, rad);\n    this.check();\n    return this;\n  }\n\n  // Performs a spherical linear interpolation between two quat\n  slerp(a, b, t) {\n    quat_slerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/quaternion.js"],"names":["MathArray","checkNumber","quat_fromMat3","quat_identity","quat_length","quat_squaredLength","quat_dot","quat_rotationTo","quat_add","quat_calculateW","quat_conjugate","quat_invert","quat_lerp","quat_multiply","quat_normalize","quat_rotateX","quat_rotateY","quat_rotateZ","quat_scale","quat_set","quat_setAxisAngle","quat_slerp","IDENTITY_QUATERNION","validateQuaternion","q","length","Number","isFinite","Quaternion","x","y","z","w","Array","isArray","arguments","copy","set","m","check","a","b","undefined","Error","vectorA","vectorB","t","rad","i","j","k","l","axis","start","target","ratio","value"],"mappings":"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","file":"quaternion.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport quat_fromMat3 from 'gl-quat/fromMat3';\nimport quat_identity from 'gl-quat/identity';\nimport quat_length from 'gl-quat/length';\nimport quat_squaredLength from 'gl-quat/squaredLength';\nimport quat_dot from 'gl-quat/dot';\n// import quat_getAxisAngle from 'gl-quat/getAxisAngle';\nimport quat_rotationTo from 'gl-quat/rotationTo';\nimport quat_add from 'gl-quat/add';\nimport quat_calculateW from 'gl-quat/calculateW';\nimport quat_conjugate from 'gl-quat/conjugate';\nimport quat_invert from 'gl-quat/invert';\nimport quat_lerp from 'gl-quat/lerp';\nimport quat_multiply from 'gl-quat/multiply';\nimport quat_normalize from 'gl-quat/normalize';\nimport quat_rotateX from 'gl-quat/rotateX';\nimport quat_rotateY from 'gl-quat/rotateY';\nimport quat_rotateZ from 'gl-quat/rotateZ';\nimport quat_scale from 'gl-quat/scale';\nimport quat_set from 'gl-quat/set';\nimport quat_setAxisAngle from 'gl-quat/setAxisAngle';\nimport quat_slerp from 'gl-quat/slerp';\n\nconst IDENTITY_QUATERNION = [0, 0, 0, 1];\n\nexport function validateQuaternion(q) {\n  return q.length === 4 &&\n    Number.isFinite(q[0]) && Number.isFinite(q[1]) &&\n    Number.isFinite(q[2]) && Number.isFinite(q[3]);\n}\n\nexport default class Quaternion extends MathArray {\n  // Creates a new identity quat\n  constructor(x = 0, y = 0, z = 0, w = 1) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z, w);\n    }\n  }\n\n  // Creates a quaternion from the given 3x3 rotation matrix.\n  // NOTE: The resultant quaternion is not normalized, so you should\n  // be sure to renormalize the quaternion yourself where necessary.\n  fromMatrix3(m) {\n    quat_fromMat3(this, m);\n    this.check();\n    return this;\n  }\n\n  // Creates a new quat initialized with the given values\n  fromValues(x, y, z, w) {\n    return this.set(x, y, z, w);\n  }\n\n  // Set a quat to the identity quaternion\n  identity() {\n    quat_identity(this);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 4; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  get w()      { return this[3]; }\n  set w(value) { return this[3] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Calculates the length of a quat\n  length() {\n    return quat_length(this);\n  }\n\n  // Calculates the squared length of a quat\n  squaredLength(a) {\n    return quat_squaredLength(this);\n  }\n\n  // Calculates the dot product of two quat's\n  // @return {Number}\n  dot(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.dot only takes one argument');\n    }\n    return quat_dot(this, a);\n  }\n\n  // Gets the rotation axis and angle for a given quaternion.\n  // If a quaternion is created with setAxisAngle, this method will\n  // return the same values as providied in the original parameter\n  // list OR functionally equivalent values.\n  // Example: The quaternion formed by axis [0, 0, 1] and angle -90\n  // is the same as the quaternion formed by [0, 0, 1] and 270.\n  // This method favors the latter.\n  // @return {{[x,y,z], Number}}\n  // getAxisAngle() {\n  //   const axis = [];\n  //   const angle = quat_getAxisAngle(axis, this);\n  //   return {axis, angle};\n  // }\n\n  // MODIFIERS\n\n  // Sets a quaternion to represent the shortest rotation from one vector\n  // to another. Both vectors are assumed to be unit length.\n  rotationTo(vectorA, vectorB) {\n    quat_rotationTo(this, vectorA, vectorB);\n    this.check();\n    return this;\n  }\n\n  // Sets the specified quaternion with values corresponding to the given axes.\n  // Each axis is a vec3 and is expected to be unit length and perpendicular\n  // to all other specified axes.\n  // setAxes() {\n  //   Number\n  // }\n\n  // Performs a spherical linear interpolation with two control points\n  // sqlerp() {\n  //   Number;\n  // }\n\n  // Adds two quat's\n  add(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.add only takes one argument');\n    }\n    quat_add(this, a);\n    this.check();\n    return this;\n  }\n\n  // Calculates the W component of a quat from the X, Y, and Z components.\n  // Any existing W component will be ignored.\n  calculateW() {\n    quat_calculateW(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the conjugate of a quat If the quaternion is normalized,\n  // this function is faster than quat_inverse and produces the same result.\n  conjugate() {\n    quat_conjugate(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the inverse of a quat\n  invert() {\n    quat_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Performs a linear interpolation between two quat's\n  lerp(a, b, t) {\n    quat_lerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n\n  // Multiplies two quat's\n  multiply(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.multiply only takes one argument');\n    }\n    quat_multiply(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Normalize a quat\n  normalize() {\n    quat_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the X axis\n  rotateX(rad) {\n    quat_rotateX(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Y axis\n  rotateY(rad) {\n    quat_rotateY(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Z axis\n  rotateZ(rad) {\n    quat_rotateZ(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Scales a quat by a scalar number\n  scale(b) {\n    quat_scale(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Set the components of a quat to the given values\n  set(i, j, k, l) {\n    quat_set(this, i, j, k, l);\n    this.check();\n    return this;\n  }\n\n  // Sets a quat from the given angle and rotation axis, then returns it.\n  setAxisAngle(axis, rad) {\n    quat_setAxisAngle(this, axis, rad);\n    this.check();\n    return this;\n  }\n\n  // Performs a spherical linear interpolation between two quat\n  slerp({start = IDENTITY_QUATERNION, target, ratio}) {\n    quat_slerp(this, start, target, ratio);\n    this.check();\n    return this;\n  }\n}\n"]}

@@ -35,4 +35,2 @@ var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

import vec3_set from 'gl-vec3/set';
import vec3_length from 'gl-vec3/length';
import vec3_distance from 'gl-vec3/distance';
import vec3_angle from 'gl-vec3/angle';

@@ -45,8 +43,3 @@ import vec3_add from 'gl-vec3/add';

import vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';
import vec3_negate from 'gl-vec3/negate';
import vec3_inverse from 'gl-vec3/inverse';
import vec3_normalize from 'gl-vec3/normalize';
import vec3_dot from 'gl-vec3/dot';
import vec3_cross from 'gl-vec3/cross';
import vec3_lerp from 'gl-vec3/lerp';
import vec3_rotateX from 'gl-vec3/rotateX';

@@ -83,9 +76,2 @@ import vec3_rotateY from 'gl-vec3/rotateY';

// fromArray(array) {
// if (array instanceof Vector3) {
// return array;
// }
// return new Vector3(...array);
// }
_createClass(Vector3, [{

@@ -102,24 +88,9 @@ key: 'set',

}, {
key: 'length',
key: 'angle',
/* eslint-enable no-multi-spaces, brace-style, no-return-assign */
value: function length() {
return vec3_length(this);
}
}, {
key: 'distance',
value: function distance(vector) {
return vec3_distance(this, vector);
}
}, {
key: 'angle',
value: function angle(vector) {
return vec3_angle(this, vector);
}
}, {
key: 'dot',
value: function dot(vector) {
return vec3_dot(this, vector);
}

@@ -241,20 +212,2 @@ // MODIFIERS

}, {
key: 'negate',
value: function negate() {
vec3_negate(this, this);
return this.check();
}
}, {
key: 'inverse',
value: function inverse() {
vec3_inverse(this, this);
return this.check();
}
}, {
key: 'normalize',
value: function normalize() {
vec3_normalize(this, this);
return this.check();
}
}, {
key: 'cross',

@@ -266,8 +219,2 @@ value: function cross(vector) {

}, {
key: 'lerp',
value: function lerp(vector, coeff) {
vec3_lerp(this, this, vector, coeff);
return this.check();
}
}, {
key: 'rotateX',

@@ -390,2 +337,2 @@ value: function rotateX(_ref) {

export default Vector3;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["MathArray","checkNumber","vec3_set","vec3_length","vec3_distance","vec3_angle","vec3_add","vec3_subtract","vec3_multiply","vec3_divide","vec3_scale","vec3_scaleAndAdd","vec3_negate","vec3_inverse","vec3_normalize","vec3_dot","vec3_cross","vec3_lerp","vec3_rotateX","vec3_rotateY","vec3_rotateZ","ORIGIN","validateVector3","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    return this.check();\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    return this.check();\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["MathArray","checkNumber","vec3_set","vec3_angle","vec3_add","vec3_subtract","vec3_multiply","vec3_divide","vec3_scale","vec3_scaleAndAdd","vec3_cross","vec3_rotateX","vec3_rotateY","vec3_rotateZ","ORIGIN","validateVector3","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]}

@@ -83,4 +83,3 @@ 'use strict';

}
this.check();
return this;
return this.check();
}

@@ -97,4 +96,3 @@ }, {

}
this.check();
return this;
return this.check();
}

@@ -109,4 +107,3 @@ }, {

}
this.check();
return this;
return this.check();
}

@@ -169,44 +166,29 @@ }, {

}
// Modifiers
}, {
key: 'length',
value: function length() {
return Math.sqrt(this.lengthSquared());
}
}, {
key: 'lengthSquared',
value: function lengthSquared() {
var length = 0;
if (length !== 0) {
for (var i = 0; i < this.ELEMENTS; ++i) {
length += this[i] * this[i];
}
key: 'negate',
value: function negate() {
for (var i = 0; i < this.ELEMENTS; ++i) {
this[i] = -this[i];
}
return (0, _common.checkNumber)(this);
return this.check();
}
}, {
key: 'distance',
value: function distance(mathArray) {
return Math.sqrt(this.distanceSquared(mathArray));
}
}, {
key: 'distanceSquared',
value: function distanceSquared(mathArray) {
var length = 0;
key: 'inverse',
value: function inverse() {
for (var i = 0; i < this.ELEMENTS; ++i) {
var dist = this[i] - mathArray[i];
length += dist * dist;
this[i] = 1 / this[i];
}
return (0, _common.checkNumber)(length);
return this.check();
}
}, {
key: 'normalize',
value: function normalize() {
var length = this.length();
if (length !== 0) {
for (var i = 0; i < this.ELEMENTS; ++i) {
this[i] /= length;
}
key: 'lerp',
value: function lerp(vector, coeff) {
for (var i = 0; i < this.ELEMENTS; ++i) {
var coord = this[i];
this[i] = coord + coeff * (vector[0] - coord);
}
this.check();
return this;
return this.check();
}

@@ -243,2 +225,2 @@

exports.default = MathArray;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/math-array.js"],"names":["MathArray","Subclass","constructor","clone","copy","check","array","i","ELEMENTS","args","offset","formatString","opts","string","printTypes","name","Float32Array","length","Math","sqrt","lengthSquared","mathArray","distanceSquared","dist","valid","Number","isFinite","debug","validate","Error","Array"],"mappings":"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","file":"math-array.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport {config, formatValue, equals, checkNumber} from './common';\n\nexport default class MathArray extends Array {\n\n  clone() {\n    const Subclass = this.constructor;\n    const clone = new Subclass().copy(this);\n    clone.check();\n    return clone;\n  }\n\n  copy(array) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i];\n    }\n    this.check();\n    return this;\n  }\n\n  set(...args) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = args[i] || 0;\n    }\n    this.check();\n    return this;\n  }\n\n  fromArray(array, offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i + offset];\n    }\n    this.check();\n    return this;\n  }\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString(opts) {\n    let string = '';\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      string += (i > 0 ? ', ' : '') + formatValue(this[i], opts);\n    }\n    return `${opts.printTypes ? this.constructor.name : ''}[${string}]`;\n  }\n\n  toArray(array = [], offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      array[offset + i] = this[i];\n    }\n    return array;\n  }\n\n  toFloat32Array() {\n    return new Float32Array(this);\n  }\n\n  equals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (!equals(this[i], array[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  exactEquals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (this[i] !== array[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  length() {\n    return Math.sqrt(this.lengthSquared());\n  }\n\n  lengthSquared() {\n    let length = 0;\n    if (length !== 0) {\n      for (let i = 0; i < this.ELEMENTS; ++i) {\n        length += this[i] * this[i];\n      }\n    }\n    return checkNumber(this);\n  }\n\n  distance(mathArray) {\n    return Math.sqrt(this.distanceSquared(mathArray));\n  }\n\n  distanceSquared(mathArray) {\n    let length = 0;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      const dist = this[i] - mathArray[i];\n      length += dist * dist;\n    }\n    return checkNumber(length);\n  }\n\n  normalize() {\n    const length = this.length();\n    if (length !== 0) {\n      for (let i = 0; i < this.ELEMENTS; ++i) {\n        this[i] /= length;\n      }\n    }\n    this.check();\n    return this;\n  }\n\n  // Debug checks\n\n  validate(array = this) {\n    let valid = array && array.length === this.ELEMENTS;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      valid = valid && Number.isFinite(array[i]);\n    }\n    return valid;\n  }\n\n  check(array = this) {\n    if (config.debug && !this.validate(array)) {\n      throw new Error(`Invalid ${this.constructor.name}`);\n    }\n    return this;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/math-array.js"],"names":["MathArray","Subclass","constructor","clone","copy","check","array","i","ELEMENTS","args","offset","formatString","opts","string","printTypes","name","Float32Array","length","vector","coeff","coord","valid","Number","isFinite","debug","validate","Error","Array"],"mappings":"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","file":"math-array.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport {config, formatValue, equals} from './common';\n\nexport default class MathArray extends Array {\n\n  clone() {\n    const Subclass = this.constructor;\n    const clone = new Subclass().copy(this);\n    clone.check();\n    return clone;\n  }\n\n  copy(array) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i];\n    }\n    return this.check();\n  }\n\n  set(...args) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = args[i] || 0;\n    }\n    return this.check();\n  }\n\n  fromArray(array, offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = array[i + offset];\n    }\n    return this.check();\n  }\n\n  toString() {\n    return this.formatString(config);\n  }\n\n  formatString(opts) {\n    let string = '';\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      string += (i > 0 ? ', ' : '') + formatValue(this[i], opts);\n    }\n    return `${opts.printTypes ? this.constructor.name : ''}[${string}]`;\n  }\n\n  toArray(array = [], offset = 0) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      array[offset + i] = this[i];\n    }\n    return array;\n  }\n\n  toFloat32Array() {\n    return new Float32Array(this);\n  }\n\n  equals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (!equals(this[i], array[i])) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  exactEquals(array) {\n    if (!array || this.length !== array.length) {\n      return false;\n    }\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      if (this[i] !== array[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  // Modifiers\n\n  negate() {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = -this[i];\n    }\n    return this.check();\n  }\n\n  inverse() {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      this[i] = 1 / this[i];\n    }\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      const coord = this[i];\n      this[i] = coord + coeff * (vector[0] - coord);\n    }\n    return this.check();\n  }\n\n  // Debug checks\n\n  validate(array = this) {\n    let valid = array && array.length === this.ELEMENTS;\n    for (let i = 0; i < this.ELEMENTS; ++i) {\n      valid = valid && Number.isFinite(array[i]);\n    }\n    return valid;\n  }\n\n  check(array = this) {\n    if (config.debug && !this.validate(array)) {\n      throw new Error(`Invalid ${this.constructor.name}`);\n    }\n    return this;\n  }\n}\n"]}

@@ -129,2 +129,4 @@ 'use strict';

var IDENTITY_QUATERNION = [0, 0, 0, 1];
function validateQuaternion(q) {

@@ -401,4 +403,9 @@ return q.length === 4 && Number.isFinite(q[0]) && Number.isFinite(q[1]) && Number.isFinite(q[2]) && Number.isFinite(q[3]);

key: 'slerp',
value: function slerp(a, b, t) {
(0, _slerp2.default)(this, a, b, t);
value: function slerp(_ref) {
var _ref$start = _ref.start,
start = _ref$start === undefined ? IDENTITY_QUATERNION : _ref$start,
target = _ref.target,
ratio = _ref.ratio;
(0, _slerp2.default)(this, start, target, ratio);
this.check();

@@ -450,2 +457,2 @@ return this;

exports.default = Quaternion;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/quaternion.js"],"names":["validateQuaternion","q","length","Number","isFinite","Quaternion","x","y","z","w","Array","isArray","arguments","copy","set","m","check","a","b","undefined","Error","vectorA","vectorB","t","rad","i","j","k","l","axis","value"],"mappings":";;;;;;;;QA+CgBA,kB,GAAAA,kB;;AA3BhB;;;;AACA;;AAIA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;;;+eA7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKA;AACA;;AAMA;;;AAiBO,SAASA,kBAAT,CAA4BC,CAA5B,EAA+B;AACpC,SAAOA,EAAEC,MAAF,KAAa,CAAb,IACLC,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADK,IACoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CADpB,IAELE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAFK,IAEoBE,OAAOC,QAAP,CAAgBH,EAAE,CAAF,CAAhB,CAF3B;AAGD;;IAEoBI,U;;;AACnB;AACA,wBAAwC;AAAA,QAA5BC,CAA4B,uEAAxB,CAAwB;AAAA,QAArBC,CAAqB,uEAAjB,CAAiB;AAAA,QAAdC,CAAc,uEAAV,CAAU;AAAA,QAAPC,CAAO,uEAAH,CAAG;;AAAA;;AAAA;;AAEtC,QAAIC,MAAMC,OAAN,CAAcL,CAAd,KAAoBM,UAAUV,MAAV,KAAqB,CAA7C,EAAgD;AAC9C,YAAKW,IAAL,CAAUP,CAAV;AACD,KAFD,MAEO;AACL,YAAKQ,GAAL,CAASR,CAAT,EAAYC,CAAZ,EAAeC,CAAf,EAAkBC,CAAlB;AACD;AANqC;AAOvC;;AAED;AACA;AACA;;;;;gCACYM,C,EAAG;AACb,6BAAc,IAAd,EAAoBA,CAApB;AACA,WAAKC,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;+BACWV,C,EAAGC,C,EAAGC,C,EAAGC,C,EAAG;AACrB,aAAO,KAAKK,GAAL,CAASR,CAAT,EAAYC,CAAZ,EAAeC,CAAf,EAAkBC,CAAlB,CAAP;AACD;;AAED;;;;+BACW;AACT,8BAAc,IAAd;AACA,WAAKO,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;;;;;AAUA;;AAEA;6BACS;AACP,aAAO,sBAAY,IAAZ,CAAP;AACD;;AAED;;;;kCACcC,C,EAAG;AACf,aAAO,6BAAmB,IAAnB,CAAP;AACD;;AAED;AACA;;;;wBACIA,C,EAAGC,C,EAAG;AACR,UAAIA,MAAMC,SAAV,EAAqB;AACnB,cAAM,IAAIC,KAAJ,CAAU,wCAAV,CAAN;AACD;AACD,aAAO,mBAAS,IAAT,EAAeH,CAAf,CAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;;;+BACWI,O,EAASC,O,EAAS;AAC3B,gCAAgB,IAAhB,EAAsBD,OAAtB,EAA+BC,OAA/B;AACA,WAAKN,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;;;wBACIC,C,EAAGC,C,EAAG;AACR,UAAIA,MAAMC,SAAV,EAAqB;AACnB,cAAM,IAAIC,KAAJ,CAAU,wCAAV,CAAN;AACD;AACD,yBAAS,IAAT,EAAeH,CAAf;AACA,WAAKD,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;;;;iCACa;AACX,gCAAgB,IAAhB,EAAsB,IAAtB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;AAED;AACA;;;;gCACY;AACV,+BAAe,IAAf,EAAqB,IAArB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;6BACS;AACP,4BAAY,IAAZ,EAAkB,IAAlB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;yBACKC,C,EAAGC,C,EAAGK,C,EAAG;AACZ,0BAAU,IAAV,EAAgBN,CAAhB,EAAmBC,CAAnB,EAAsBK,CAAtB;AACA,WAAKP,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;6BACSC,C,EAAGC,C,EAAG;AACb,UAAIA,MAAMC,SAAV,EAAqB;AACnB,cAAM,IAAIC,KAAJ,CAAU,6CAAV,CAAN;AACD;AACD,8BAAc,IAAd,EAAoB,IAApB,EAA0BF,CAA1B;AACA,WAAKF,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;gCACY;AACV,+BAAe,IAAf,EAAqB,IAArB;AACA,WAAKA,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQQ,G,EAAK;AACX,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,GAAzB;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQQ,G,EAAK;AACX,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,GAAzB;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;4BACQQ,G,EAAK;AACX,6BAAa,IAAb,EAAmB,IAAnB,EAAyBA,GAAzB;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;0BACME,C,EAAG;AACP,2BAAW,IAAX,EAAiB,IAAjB,EAAuBA,CAAvB;AACA,WAAKF,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;wBACIS,C,EAAGC,C,EAAGC,C,EAAGC,C,EAAG;AACd,yBAAS,IAAT,EAAeH,CAAf,EAAkBC,CAAlB,EAAqBC,CAArB,EAAwBC,CAAxB;AACA,WAAKZ,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;iCACaa,I,EAAML,G,EAAK;AACtB,kCAAkB,IAAlB,EAAwBK,IAAxB,EAA8BL,GAA9B;AACA,WAAKR,KAAL;AACA,aAAO,IAAP;AACD;;AAED;;;;0BACMC,C,EAAGC,C,EAAGK,C,EAAG;AACb,2BAAW,IAAX,EAAiBN,CAAjB,EAAoBC,CAApB,EAAuBK,CAAvB;AACA,WAAKP,KAAL;AACA,aAAO,IAAP;AACD;;;wBA1Kc;AAAE,aAAO,CAAP;AAAW;;;wBACf;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1Bc,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;wBACxC;AAAE,aAAO,KAAK,CAAL,CAAP;AAAiB,K;sBAC1BA,K,EAAO;AAAE,aAAO,KAAK,CAAL,IAAU,yBAAYA,KAAZ,CAAjB;AAAsC;;;;;;kBA1ClCzB,U","file":"quaternion.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport quat_fromMat3 from 'gl-quat/fromMat3';\nimport quat_identity from 'gl-quat/identity';\nimport quat_length from 'gl-quat/length';\nimport quat_squaredLength from 'gl-quat/squaredLength';\nimport quat_dot from 'gl-quat/dot';\n// import quat_getAxisAngle from 'gl-quat/getAxisAngle';\nimport quat_rotationTo from 'gl-quat/rotationTo';\nimport quat_add from 'gl-quat/add';\nimport quat_calculateW from 'gl-quat/calculateW';\nimport quat_conjugate from 'gl-quat/conjugate';\nimport quat_invert from 'gl-quat/invert';\nimport quat_lerp from 'gl-quat/lerp';\nimport quat_multiply from 'gl-quat/multiply';\nimport quat_normalize from 'gl-quat/normalize';\nimport quat_rotateX from 'gl-quat/rotateX';\nimport quat_rotateY from 'gl-quat/rotateY';\nimport quat_rotateZ from 'gl-quat/rotateZ';\nimport quat_scale from 'gl-quat/scale';\nimport quat_set from 'gl-quat/set';\nimport quat_setAxisAngle from 'gl-quat/setAxisAngle';\nimport quat_slerp from 'gl-quat/slerp';\n\nexport function validateQuaternion(q) {\n  return q.length === 4 &&\n    Number.isFinite(q[0]) && Number.isFinite(q[1]) &&\n    Number.isFinite(q[2]) && Number.isFinite(q[3]);\n}\n\nexport default class Quaternion extends MathArray {\n  // Creates a new identity quat\n  constructor(x = 0, y = 0, z = 0, w = 1) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z, w);\n    }\n  }\n\n  // Creates a quaternion from the given 3x3 rotation matrix.\n  // NOTE: The resultant quaternion is not normalized, so you should\n  // be sure to renormalize the quaternion yourself where necessary.\n  fromMatrix3(m) {\n    quat_fromMat3(this, m);\n    this.check();\n    return this;\n  }\n\n  // Creates a new quat initialized with the given values\n  fromValues(x, y, z, w) {\n    return this.set(x, y, z, w);\n  }\n\n  // Set a quat to the identity quaternion\n  identity() {\n    quat_identity(this);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 4; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  get w()      { return this[3]; }\n  set w(value) { return this[3] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Calculates the length of a quat\n  length() {\n    return quat_length(this);\n  }\n\n  // Calculates the squared length of a quat\n  squaredLength(a) {\n    return quat_squaredLength(this);\n  }\n\n  // Calculates the dot product of two quat's\n  // @return {Number}\n  dot(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.dot only takes one argument');\n    }\n    return quat_dot(this, a);\n  }\n\n  // Gets the rotation axis and angle for a given quaternion.\n  // If a quaternion is created with setAxisAngle, this method will\n  // return the same values as providied in the original parameter\n  // list OR functionally equivalent values.\n  // Example: The quaternion formed by axis [0, 0, 1] and angle -90\n  // is the same as the quaternion formed by [0, 0, 1] and 270.\n  // This method favors the latter.\n  // @return {{[x,y,z], Number}}\n  // getAxisAngle() {\n  //   const axis = [];\n  //   const angle = quat_getAxisAngle(axis, this);\n  //   return {axis, angle};\n  // }\n\n  // MODIFIERS\n\n  // Sets a quaternion to represent the shortest rotation from one vector\n  // to another. Both vectors are assumed to be unit length.\n  rotationTo(vectorA, vectorB) {\n    quat_rotationTo(this, vectorA, vectorB);\n    this.check();\n    return this;\n  }\n\n  // Sets the specified quaternion with values corresponding to the given axes.\n  // Each axis is a vec3 and is expected to be unit length and perpendicular\n  // to all other specified axes.\n  // setAxes() {\n  //   Number\n  // }\n\n  // Performs a spherical linear interpolation with two control points\n  // sqlerp() {\n  //   Number;\n  // }\n\n  // Adds two quat's\n  add(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.add only takes one argument');\n    }\n    quat_add(this, a);\n    this.check();\n    return this;\n  }\n\n  // Calculates the W component of a quat from the X, Y, and Z components.\n  // Any existing W component will be ignored.\n  calculateW() {\n    quat_calculateW(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the conjugate of a quat If the quaternion is normalized,\n  // this function is faster than quat_inverse and produces the same result.\n  conjugate() {\n    quat_conjugate(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the inverse of a quat\n  invert() {\n    quat_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Performs a linear interpolation between two quat's\n  lerp(a, b, t) {\n    quat_lerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n\n  // Multiplies two quat's\n  multiply(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.multiply only takes one argument');\n    }\n    quat_multiply(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Normalize a quat\n  normalize() {\n    quat_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the X axis\n  rotateX(rad) {\n    quat_rotateX(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Y axis\n  rotateY(rad) {\n    quat_rotateY(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Z axis\n  rotateZ(rad) {\n    quat_rotateZ(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Scales a quat by a scalar number\n  scale(b) {\n    quat_scale(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Set the components of a quat to the given values\n  set(i, j, k, l) {\n    quat_set(this, i, j, k, l);\n    this.check();\n    return this;\n  }\n\n  // Sets a quat from the given angle and rotation axis, then returns it.\n  setAxisAngle(axis, rad) {\n    quat_setAxisAngle(this, axis, rad);\n    this.check();\n    return this;\n  }\n\n  // Performs a spherical linear interpolation between two quat\n  slerp(a, b, t) {\n    quat_slerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/quaternion.js"],"names":["validateQuaternion","IDENTITY_QUATERNION","q","length","Number","isFinite","Quaternion","x","y","z","w","Array","isArray","arguments","copy","set","m","check","a","b","undefined","Error","vectorA","vectorB","t","rad","i","j","k","l","axis","start","target","ratio","value"],"mappings":"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","file":"quaternion.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport quat_fromMat3 from 'gl-quat/fromMat3';\nimport quat_identity from 'gl-quat/identity';\nimport quat_length from 'gl-quat/length';\nimport quat_squaredLength from 'gl-quat/squaredLength';\nimport quat_dot from 'gl-quat/dot';\n// import quat_getAxisAngle from 'gl-quat/getAxisAngle';\nimport quat_rotationTo from 'gl-quat/rotationTo';\nimport quat_add from 'gl-quat/add';\nimport quat_calculateW from 'gl-quat/calculateW';\nimport quat_conjugate from 'gl-quat/conjugate';\nimport quat_invert from 'gl-quat/invert';\nimport quat_lerp from 'gl-quat/lerp';\nimport quat_multiply from 'gl-quat/multiply';\nimport quat_normalize from 'gl-quat/normalize';\nimport quat_rotateX from 'gl-quat/rotateX';\nimport quat_rotateY from 'gl-quat/rotateY';\nimport quat_rotateZ from 'gl-quat/rotateZ';\nimport quat_scale from 'gl-quat/scale';\nimport quat_set from 'gl-quat/set';\nimport quat_setAxisAngle from 'gl-quat/setAxisAngle';\nimport quat_slerp from 'gl-quat/slerp';\n\nconst IDENTITY_QUATERNION = [0, 0, 0, 1];\n\nexport function validateQuaternion(q) {\n  return q.length === 4 &&\n    Number.isFinite(q[0]) && Number.isFinite(q[1]) &&\n    Number.isFinite(q[2]) && Number.isFinite(q[3]);\n}\n\nexport default class Quaternion extends MathArray {\n  // Creates a new identity quat\n  constructor(x = 0, y = 0, z = 0, w = 1) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z, w);\n    }\n  }\n\n  // Creates a quaternion from the given 3x3 rotation matrix.\n  // NOTE: The resultant quaternion is not normalized, so you should\n  // be sure to renormalize the quaternion yourself where necessary.\n  fromMatrix3(m) {\n    quat_fromMat3(this, m);\n    this.check();\n    return this;\n  }\n\n  // Creates a new quat initialized with the given values\n  fromValues(x, y, z, w) {\n    return this.set(x, y, z, w);\n  }\n\n  // Set a quat to the identity quaternion\n  identity() {\n    quat_identity(this);\n    this.check();\n    return this;\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 4; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  get w()      { return this[3]; }\n  set w(value) { return this[3] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  // Calculates the length of a quat\n  length() {\n    return quat_length(this);\n  }\n\n  // Calculates the squared length of a quat\n  squaredLength(a) {\n    return quat_squaredLength(this);\n  }\n\n  // Calculates the dot product of two quat's\n  // @return {Number}\n  dot(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.dot only takes one argument');\n    }\n    return quat_dot(this, a);\n  }\n\n  // Gets the rotation axis and angle for a given quaternion.\n  // If a quaternion is created with setAxisAngle, this method will\n  // return the same values as providied in the original parameter\n  // list OR functionally equivalent values.\n  // Example: The quaternion formed by axis [0, 0, 1] and angle -90\n  // is the same as the quaternion formed by [0, 0, 1] and 270.\n  // This method favors the latter.\n  // @return {{[x,y,z], Number}}\n  // getAxisAngle() {\n  //   const axis = [];\n  //   const angle = quat_getAxisAngle(axis, this);\n  //   return {axis, angle};\n  // }\n\n  // MODIFIERS\n\n  // Sets a quaternion to represent the shortest rotation from one vector\n  // to another. Both vectors are assumed to be unit length.\n  rotationTo(vectorA, vectorB) {\n    quat_rotationTo(this, vectorA, vectorB);\n    this.check();\n    return this;\n  }\n\n  // Sets the specified quaternion with values corresponding to the given axes.\n  // Each axis is a vec3 and is expected to be unit length and perpendicular\n  // to all other specified axes.\n  // setAxes() {\n  //   Number\n  // }\n\n  // Performs a spherical linear interpolation with two control points\n  // sqlerp() {\n  //   Number;\n  // }\n\n  // Adds two quat's\n  add(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.add only takes one argument');\n    }\n    quat_add(this, a);\n    this.check();\n    return this;\n  }\n\n  // Calculates the W component of a quat from the X, Y, and Z components.\n  // Any existing W component will be ignored.\n  calculateW() {\n    quat_calculateW(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the conjugate of a quat If the quaternion is normalized,\n  // this function is faster than quat_inverse and produces the same result.\n  conjugate() {\n    quat_conjugate(this, this);\n    this.check();\n    return this;\n  }\n\n  // Calculates the inverse of a quat\n  invert() {\n    quat_invert(this, this);\n    this.check();\n    return this;\n  }\n\n  // Performs a linear interpolation between two quat's\n  lerp(a, b, t) {\n    quat_lerp(this, a, b, t);\n    this.check();\n    return this;\n  }\n\n  // Multiplies two quat's\n  multiply(a, b) {\n    if (b !== undefined) {\n      throw new Error('Quaternion.multiply only takes one argument');\n    }\n    quat_multiply(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Normalize a quat\n  normalize() {\n    quat_normalize(this, this);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the X axis\n  rotateX(rad) {\n    quat_rotateX(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Y axis\n  rotateY(rad) {\n    quat_rotateY(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Rotates a quaternion by the given angle about the Z axis\n  rotateZ(rad) {\n    quat_rotateZ(this, this, rad);\n    this.check();\n    return this;\n  }\n\n  // Scales a quat by a scalar number\n  scale(b) {\n    quat_scale(this, this, b);\n    this.check();\n    return this;\n  }\n\n  // Set the components of a quat to the given values\n  set(i, j, k, l) {\n    quat_set(this, i, j, k, l);\n    this.check();\n    return this;\n  }\n\n  // Sets a quat from the given angle and rotation axis, then returns it.\n  setAxisAngle(axis, rad) {\n    quat_setAxisAngle(this, axis, rad);\n    this.check();\n    return this;\n  }\n\n  // Performs a spherical linear interpolation between two quat\n  slerp({start = IDENTITY_QUATERNION, target, ratio}) {\n    quat_slerp(this, start, target, ratio);\n    this.check();\n    return this;\n  }\n}\n"]}

@@ -21,10 +21,2 @@ 'use strict';

var _length = require('gl-vec3/length');
var _length2 = _interopRequireDefault(_length);
var _distance = require('gl-vec3/distance');
var _distance2 = _interopRequireDefault(_distance);
var _angle = require('gl-vec3/angle');

@@ -58,18 +50,2 @@

var _negate = require('gl-vec3/negate');
var _negate2 = _interopRequireDefault(_negate);
var _inverse = require('gl-vec3/inverse');
var _inverse2 = _interopRequireDefault(_inverse);
var _normalize = require('gl-vec3/normalize');
var _normalize2 = _interopRequireDefault(_normalize);
var _dot = require('gl-vec3/dot');
var _dot2 = _interopRequireDefault(_dot);
var _cross = require('gl-vec3/cross');

@@ -79,6 +55,2 @@

var _lerp = require('gl-vec3/lerp');
var _lerp2 = _interopRequireDefault(_lerp);
var _rotateX = require('gl-vec3/rotateX');

@@ -153,9 +125,2 @@

// fromArray(array) {
// if (array instanceof Vector3) {
// return array;
// }
// return new Vector3(...array);
// }
_createClass(Vector3, [{

@@ -172,24 +137,9 @@ key: 'set',

}, {
key: 'length',
key: 'angle',
/* eslint-enable no-multi-spaces, brace-style, no-return-assign */
value: function length() {
return (0, _length2.default)(this);
}
}, {
key: 'distance',
value: function distance(vector) {
return (0, _distance2.default)(this, vector);
}
}, {
key: 'angle',
value: function angle(vector) {
return (0, _angle2.default)(this, vector);
}
}, {
key: 'dot',
value: function dot(vector) {
return (0, _dot2.default)(this, vector);
}

@@ -311,20 +261,2 @@ // MODIFIERS

}, {
key: 'negate',
value: function negate() {
(0, _negate2.default)(this, this);
return this.check();
}
}, {
key: 'inverse',
value: function inverse() {
(0, _inverse2.default)(this, this);
return this.check();
}
}, {
key: 'normalize',
value: function normalize() {
(0, _normalize2.default)(this, this);
return this.check();
}
}, {
key: 'cross',

@@ -336,8 +268,2 @@ value: function cross(vector) {

}, {
key: 'lerp',
value: function lerp(vector, coeff) {
(0, _lerp2.default)(this, this, vector, coeff);
return this.check();
}
}, {
key: 'rotateX',

@@ -460,2 +386,2 @@ value: function rotateX(_ref) {

exports.default = Vector3;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["validateVector3","ORIGIN","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","coeff","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_length from 'gl-vec3/length';\nimport vec3_distance from 'gl-vec3/distance';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_negate from 'gl-vec3/negate';\nimport vec3_inverse from 'gl-vec3/inverse';\nimport vec3_normalize from 'gl-vec3/normalize';\nimport vec3_dot from 'gl-vec3/dot';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_lerp from 'gl-vec3/lerp';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  // fromArray(array) {\n  //   if (array instanceof Vector3) {\n  //     return array;\n  //   }\n  //   return new Vector3(...array);\n  // }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  length() {\n    return vec3_length(this);\n  }\n\n  distance(vector) {\n    return vec3_distance(this, vector);\n  }\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  dot(vector) {\n    return vec3_dot(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  negate() {\n    vec3_negate(this, this);\n    return this.check();\n  }\n\n  inverse() {\n    vec3_inverse(this, this);\n    return this.check();\n  }\n\n  normalize() {\n    vec3_normalize(this, this);\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  lerp(vector, coeff) {\n    vec3_lerp(this, this, vector, coeff);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/vector3.js"],"names":["validateVector3","ORIGIN","v","length","Number","isFinite","Vector3","x","y","z","Array","isArray","arguments","copy","set","check","vector","vectors","scale","radians","origin","operation","args","value"],"mappings":"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","file":"vector3.js","sourcesContent":["// Copyright (c) 2017 Uber Technologies, Inc.\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\nimport MathArray from './math-array';\nimport {checkNumber} from './common';\n\n// gl-matrix is too big. Cherry-pick individual imports from stack.gl version\n/* eslint-disable camelcase */\nimport vec3_set from 'gl-vec3/set';\nimport vec3_angle from 'gl-vec3/angle';\nimport vec3_add from 'gl-vec3/add';\nimport vec3_subtract from 'gl-vec3/subtract';\nimport vec3_multiply from 'gl-vec3/multiply';\nimport vec3_divide from 'gl-vec3/divide';\nimport vec3_scale from 'gl-vec3/scale';\nimport vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';\nimport vec3_cross from 'gl-vec3/cross';\nimport vec3_rotateX from 'gl-vec3/rotateX';\nimport vec3_rotateY from 'gl-vec3/rotateY';\nimport vec3_rotateZ from 'gl-vec3/rotateZ';\n\nconst ORIGIN = [0, 0, 0];\n\nexport function validateVector3(v) {\n  return v.length === 3 &&\n    Number.isFinite(v[0]) && Number.isFinite(v[1]) && Number.isFinite(v[2]);\n}\n\nexport default class Vector3 extends MathArray {\n  // Creates a new vec3, either empty, or from an array or from values\n  constructor(x = 0, y = 0, z = 0) {\n    super();\n    if (Array.isArray(x) && arguments.length === 1) {\n      this.copy(x);\n    } else {\n      this.set(x, y, z);\n    }\n  }\n\n  set(x, y, z) {\n    vec3_set(this, x, y, z);\n    return this.check();\n  }\n\n  // Getters/setters\n  /* eslint-disable no-multi-spaces, brace-style, no-return-assign */\n  get ELEMENTS() { return 3; }\n  get x()      { return this[0]; }\n  set x(value) { return this[0] = checkNumber(value); }\n  get y()      { return this[1]; }\n  set y(value) { return this[1] = checkNumber(value); }\n  get z()      { return this[2]; }\n  set z(value) { return this[2] = checkNumber(value); }\n  /* eslint-enable no-multi-spaces, brace-style, no-return-assign */\n\n  angle(vector) {\n    return vec3_angle(this, vector);\n  }\n\n  // MODIFIERS\n\n  add(...vectors) {\n    for (const vector of vectors) {\n      vec3_add(this, this, vector);\n    }\n    return this.check();\n  }\n\n  subtract(...vectors) {\n    for (const vector of vectors) {\n      vec3_subtract(this, this, vector);\n    }\n    return this.check();\n  }\n\n  multiply(...vectors) {\n    for (const vector of vectors) {\n      vec3_multiply(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scale(scale) {\n    if (Number.isFinite(scale)) {\n      vec3_scale(this, this, scale);\n    } else {\n      vec3_multiply(this, this, scale);\n    }\n    return this.check();\n  }\n\n  cross(vector) {\n    vec3_cross(this, this, vector);\n    return this.check();\n  }\n\n  rotateX({radians, origin = ORIGIN}) {\n    vec3_rotateX(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateY({radians, origin = ORIGIN}) {\n    vec3_rotateY(this, this, origin, radians);\n    return this.check();\n  }\n\n  rotateZ({radians, origin = ORIGIN}) {\n    vec3_rotateZ(this, this, origin, radians);\n    return this.check();\n  }\n\n  operation(operation, ...args) {\n    operation(this, this, ...args);\n    return this.check();\n  }\n\n  // TBD - do we really need these?\n  divide(...vectors) {\n    for (const vector of vectors) {\n      vec3_divide(this, this, vector);\n    }\n    return this.check();\n  }\n\n  scaleAndAdd(vector, scale) {\n    vec3_scaleAndAdd(this, this, vector, scale);\n    return this.check();\n  }\n}\n"]}
{
"name": "math.gl",
"description": "Class wrappers for gl-matrix",
"description": "Array-based 3D Math Classes optimized for WebGL applications",
"license": "MIT",
"version": "1.0.0-alpha.8",
"version": "1.0.0",
"keywords": [

@@ -7,0 +7,0 @@ "webgl",

@@ -18,75 +18,45 @@ <p align="right">

<h1 align="center">math.gl | <a href="https://uber-web.github.io/math.gl">Docs</a></h1>
Array-based ES6 math classes built on the amazing [gl-matrix](http://glmatrix.net/) and THREE.js math libraries.
# math.gl
math.gl is an `Array`-based JavaScript 3D math library. In spite of its name it has no hard WebGL dependencies, but however both API and design are focused on focused on the needs of typical WebGL applications
## Overview
math.gl is a JavaScript math library primarily intended to support WebGL applications. It is a generic library but was developed as a companion for [luma.gl](http://uber.github.io/luma.gl/) and [deck.gl](http://uber.github.io/deck.gl/).
math.gl contains a set of classes (Matrix4 etc) to complement the procedural interface of gl-matrix. It also imports a limited subset of the standard `gl-matrix` functions (to keep bundle size down), these can be used in parallel with the classes.
## Who is this for?
JavaScript WebGL programmers who:
* Need a great JavaScript math library for basic computional geometry purposes.
* like the functionality offered by the gl-matrix library
* need tree-shaking support
* want to use object orientated math programming style (ability to chain operations).
* want optional extra error checking
* do not need to support old (pre-IE10) browsers.
## Features
- **Array-based**
- All math objects can be used directly with any Javascript function that expects array arguments. No need to call `toArray` or similar.
This is a short list of feature high-lights to show what math.gl is about.
- **Error checking** to assist in debugging.
- Can be disabled when performance is critical.
- **Array-based Classes** - All math.gl classes (like `Vector3`, `Matrix4`) are subclasses of the built-in JavaScript `Array` class. This means that they can be used directly with any Javascript function that e.g. expects plain JavaScript `Array` arguments for Vectors, which is increasingly common.
- **WebGL-friendly**
- Matrices: while all accessors, `toString()` etc are row-major. Matrices are organized internally in the layout expected by WebGL (an array of contiguous floats in column-major order),
- `toArray` and `fromArray` functions take optional offsets allowing copying directly to and from vertex attribute arrays.
- GLSL math functions (radians, sin etc) made available in JavaScript and work both on scalars and vectors / math objects.
- **Debug Friendly** - JavaScript math can be frustrating to code and debug. math.gl offers **optional** error checking after every math operation which makes quick work of locating coding errors and bad data. Also, strong "printing support" (`toString`) simplifies debugging.
- **WebGL Support** - Matrices are stored internally in the format required by WebGL (array of contiguous values in column-major order), while exposing the more "natural" row-major API to the JavaScript programmer (e.g. through accessors, printing using `toString()` etc).
# Design Notes
- **Documentation** - Some JavaScript 3D math libraries come with reference documentation only. If you are new to 3D programming it can be hard to know where to start. math.gl comes with articles that try to show you the big picture and get you quickly up-to-speed on the mathematical concepts and the math.gl classes that support them.
- Math objects are `Arrays` - All math objects are subclasses of the built-in JavaScript `Array` class, which means that class instances can be used wherever an array is expected. I.e. these classes are not wrappers of `Array`s, they **are** `Array`s, just with additional methods.
- **Size Conscious** - A math library can quickly get big as a various classed and functions keep getting added. But for many 3D applications, only a few basic operations are necessary. math.gl has made a choices to restrict itself to a set of classes and functions that are likely to be most important in WebGL applications. The intention is to position math.gl as a "mid-size" 3D math library: reasonably full featured, but small enough that unless you are targeting a very small final bundle for your application, its size should not be a big concern.
- Focuses on needs of WebGL based applications and basic computational geometry, which includes 4x4 matrices, 2, 3 and 4 dimensional vectors and quaternions. May grow to include other classes, but is not intended to become a general math library.
## Supported Browsers and Node Versions
# History
math.gl is only supported on "evergreen" browsers, such as Chrome, Safari, Firefox, Edge etc. While not evergreen, IE11 should support the math.gl distribution's transpiled code, but Internet Explorer < 10 will not work. math.gl also works on recent versions of Node.js (tested on v6+).
- Started out as a set of object oriented wrappers for the procedural [gl-matrix](http://glmatrix.net/) library.
> Disclaimer: These restrictions are both due to real technical limitations with math.gl's `Array`subclassing approach, as well as a conscious decision by the maintainers to limit the support matrix for the library. So, if your application needs to support non-evergreen browsers, math.gl is unlikely to be the right choice for you. A good alternative option could be to use e.g. `gl-matrix` directly.
# Roadmap
## History
- Additional classes and functions. This library might grow beyond just providing `gl-matrix` wrappers if additional classes are deemed valuable for the target user group.
math.gl was developed as a companion 3D math library for the luma.gl and deck.gl WebGL frameworks, and the precursors of the math.gl classes were in fact part of luma.gl v4.0, but have now been broken out in this separate library.
In spite of its roots, the intention is that math.gl should be able to serve a general purpose 3D math library, and be used either directly or as a "starting point" by other projects with similar needs.
## Documentation
The [gl-matrix docs](http://glmatrix.net/docs/) are a good start.
## Attribution
math.gl heavily inspired by, and includes code, documentation and ideas from some of the most proven open source JavaScript math libraries, the awesome [`gl-matrix`](http://glmatrix.net/) and the THREE.js math library. Those libraries encouraged reuse which enabled math.gl to be built, and naturally math.gl does the same!
## API differences with gl-matrix
The class API is intentionally designed to remain intuitively similar to the wrapped `gl-matrix` procedures, usually just removing the first one or two parameters from each function (the out argument and the first input arguments, both are implictly set to this), and exposes the remaining arguments in the same order as the gl-matrix api.
## License
Only in a few cases where `gl-matrix` methods take a long list arguments (e.g. `mat4.perspective`, `mat4.ortho` etc) or return multiple values (e.g. `quat.getAxisRotation`) do methods provide a modified API that is more natural for modern ES6 applications to use, e.g. using named parameters, or collecting all results in one returned object.
Also, for transforming vectors with matrices, the `transformVector*` methods are offered in the matrix classes, instead of on the vector classes. They also (optionally) auto allocate the result vectors.
## Caveats
A technical caveat is that JavaScript `Array` subclassing, which is fundamental to the design of this library, is only supported on "evergreen" browsers, such as Chrome, Safari, Firefox, Edge etc, i.e. no Internet Explorer < 10 ([details](https://github.com/loganfsmyth/babel-plugin-transform-builtin-extend)).
If this is not acceptable, math.gl is not the right choice for you. As a fallback, you can always use `gl-matrix` directly.
MIT license. The libraries that math.gl are built on are also all open source and MIT licensed.

@@ -21,3 +21,3 @@ // Copyright (c) 2017 Uber Technologies, Inc.

import {config, formatValue, equals, checkNumber} from './common';
import {config, formatValue, equals} from './common';

@@ -37,4 +37,3 @@ export default class MathArray extends Array {

}
this.check();
return this;
return this.check();
}

@@ -46,4 +45,3 @@

}
this.check();
return this;
return this.check();
}

@@ -55,4 +53,3 @@

}
this.check();
return this;
return this.check();
}

@@ -107,38 +104,24 @@

length() {
return Math.sqrt(this.lengthSquared());
}
// Modifiers
lengthSquared() {
let length = 0;
if (length !== 0) {
for (let i = 0; i < this.ELEMENTS; ++i) {
length += this[i] * this[i];
}
negate() {
for (let i = 0; i < this.ELEMENTS; ++i) {
this[i] = -this[i];
}
return checkNumber(this);
return this.check();
}
distance(mathArray) {
return Math.sqrt(this.distanceSquared(mathArray));
}
distanceSquared(mathArray) {
let length = 0;
inverse() {
for (let i = 0; i < this.ELEMENTS; ++i) {
const dist = this[i] - mathArray[i];
length += dist * dist;
this[i] = 1 / this[i];
}
return checkNumber(length);
return this.check();
}
normalize() {
const length = this.length();
if (length !== 0) {
for (let i = 0; i < this.ELEMENTS; ++i) {
this[i] /= length;
}
lerp(vector, coeff) {
for (let i = 0; i < this.ELEMENTS; ++i) {
const coord = this[i];
this[i] = coord + coeff * (vector[0] - coord);
}
this.check();
return this;
return this.check();
}

@@ -145,0 +128,0 @@

@@ -48,2 +48,4 @@ // Copyright (c) 2017 Uber Technologies, Inc.

const IDENTITY_QUATERNION = [0, 0, 0, 1];
export function validateQuaternion(q) {

@@ -255,4 +257,4 @@ return q.length === 4 &&

// Performs a spherical linear interpolation between two quat
slerp(a, b, t) {
quat_slerp(this, a, b, t);
slerp({start = IDENTITY_QUATERNION, target, ratio}) {
quat_slerp(this, start, target, ratio);
this.check();

@@ -259,0 +261,0 @@ return this;

@@ -27,4 +27,2 @@ // Copyright (c) 2017 Uber Technologies, Inc.

import vec3_set from 'gl-vec3/set';
import vec3_length from 'gl-vec3/length';
import vec3_distance from 'gl-vec3/distance';
import vec3_angle from 'gl-vec3/angle';

@@ -37,8 +35,3 @@ import vec3_add from 'gl-vec3/add';

import vec3_scaleAndAdd from 'gl-vec3/scaleAndAdd';
import vec3_negate from 'gl-vec3/negate';
import vec3_inverse from 'gl-vec3/inverse';
import vec3_normalize from 'gl-vec3/normalize';
import vec3_dot from 'gl-vec3/dot';
import vec3_cross from 'gl-vec3/cross';
import vec3_lerp from 'gl-vec3/lerp';
import vec3_rotateX from 'gl-vec3/rotateX';

@@ -66,9 +59,2 @@ import vec3_rotateY from 'gl-vec3/rotateY';

// fromArray(array) {
// if (array instanceof Vector3) {
// return array;
// }
// return new Vector3(...array);
// }
set(x, y, z) {

@@ -90,10 +76,2 @@ vec3_set(this, x, y, z);

length() {
return vec3_length(this);
}
distance(vector) {
return vec3_distance(this, vector);
}
angle(vector) {

@@ -103,6 +81,2 @@ return vec3_angle(this, vector);

dot(vector) {
return vec3_dot(this, vector);
}
// MODIFIERS

@@ -140,17 +114,2 @@

negate() {
vec3_negate(this, this);
return this.check();
}
inverse() {
vec3_inverse(this, this);
return this.check();
}
normalize() {
vec3_normalize(this, this);
return this.check();
}
cross(vector) {

@@ -161,7 +120,2 @@ vec3_cross(this, this, vector);

lerp(vector, coeff) {
vec3_lerp(this, this, vector, coeff);
return this.check();
}
rotateX({radians, origin = ORIGIN}) {

@@ -168,0 +122,0 @@ vec3_rotateX(this, this, origin, radians);

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc