From 81efa40cc96357ad2d15b8a3cee67168fd55d8d5 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:19:26 +0300 Subject: [PATCH 01/10] Changing packaging for node. --- .gitignore | 4 +++- .npmignore | 7 +++++++ README.md | 2 ++ dist/tsm.js | 41 +++++++++++++++++++++++++++++++++++++++-- package.json | 15 ++++++--------- webpack.config.js | 23 ----------------------- 6 files changed, 57 insertions(+), 35 deletions(-) create mode 100644 .npmignore delete mode 100644 webpack.config.js diff --git a/.gitignore b/.gitignore index d133fc1..74b878d 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,5 @@ .vscode/ node_modules/ -package-lock.json \ No newline at end of file +package-lock.json +.idea +dist \ No newline at end of file diff --git a/.npmignore b/.npmignore new file mode 100644 index 0000000..bca697c --- /dev/null +++ b/.npmignore @@ -0,0 +1,7 @@ +.idea +.gitignore +tsm.iml +tsconfig.json +node_modules +src +test diff --git a/README.md b/README.md index c38831f..8073570 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,8 @@ tsm: A Typescript vector and matrix math library ================================================= +This is node packaged version of the library. + tsm is a a collection of vector, matrix and quaternion classes written in Typescript. The library's design is influenced by both [gl-matrix](https://github.com/toji/gl-matrix) and [glm](https://github.com/g-truc/glm). diff --git a/dist/tsm.js b/dist/tsm.js index b0b0e96..e3258dc 100644 --- a/dist/tsm.js +++ b/dist/tsm.js @@ -1,2 +1,39 @@ -var tsm=function(t){var e={};function s(i){if(e[i])return e[i].exports;var u=e[i]={i:i,l:!1,exports:{}};return t[i].call(u.exports,u,u.exports,s),u.l=!0,u.exports}return s.m=t,s.c=e,s.d=function(t,e,i){s.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:i})},s.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},s.t=function(t,e){if(1&e&&(t=s(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var i=Object.create(null);if(s.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var u in t)s.d(i,u,function(e){return t[e]}.bind(null,u));return i},s.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return s.d(e,"a",e),e},s.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},s.p="",s(s.s=7)}([function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.epsilon=1e-6},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(3),u=s(0),a=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(3),t&&(this.xyz=t)}return Object.defineProperty(t.prototype,"x",{get:function(){return this.values[0]},set:function(t){this.values[0]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"y",{get:function(){return this.values[1]},set:function(t){this.values[1]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"z",{get:function(){return this.values[2]},set:function(t){this.values[2]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xy",{get:function(){return[this.values[0],this.values[1]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xyz",{get:function(){return[this.values[0],this.values[1],this.values[2]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2]},enumerable:!0,configurable:!0}),t.prototype.at=function(t){return this.values[t]},t.prototype.reset=function(){this.x=0,this.y=0,this.z=0},t.prototype.copy=function(e){return void 0===e&&(e=null),e||(e=new t),e.x=this.x,e.y=this.y,e.z=this.z,e},t.prototype.negate=function(t){return void 0===t&&(t=null),t||(t=this),t.x=-this.x,t.y=-this.y,t.z=-this.z,t},t.prototype.equals=function(t,e){return void 0===e&&(e=u.epsilon),!(Math.abs(this.x-t.x)>e)&&(!(Math.abs(this.y-t.y)>e)&&!(Math.abs(this.z-t.z)>e))},t.prototype.length=function(){return Math.sqrt(this.squaredLength())},t.prototype.squaredLength=function(){var t=this.x,e=this.y,s=this.z;return t*t+e*e+s*s},t.prototype.add=function(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this},t.prototype.subtract=function(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this},t.prototype.multiply=function(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this},t.prototype.divide=function(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this},t.prototype.scale=function(t,e){return void 0===e&&(e=null),e||(e=this),e.x*=t,e.y*=t,e.z*=t,e},t.prototype.normalize=function(t){void 0===t&&(t=null),t||(t=this);var e=this.length();return 1===e?this:0===e?(t.x=0,t.y=0,t.z=0,t):(e=1/e,t.x*=e,t.y*=e,t.z*=e,t)},t.prototype.multiplyByMat3=function(t,e){return void 0===e&&(e=null),e||(e=this),t.multiplyVec3(this,e)},t.prototype.multiplyByQuat=function(t,e){return void 0===e&&(e=null),e||(e=this),t.multiplyVec3(this,e)},t.cross=function(e,s,i){void 0===i&&(i=null),i||(i=new t);var u=e.x,a=e.y,n=e.z,r=s.x,l=s.y,h=s.z;return i.x=a*h-n*l,i.y=n*r-u*h,i.z=u*l-a*r,i},t.dot=function(t,e){var s=t.x,i=t.y,u=t.z;return s*e.x+i*e.y+u*e.z},t.distance=function(t,e){e.x,t.x,e.y,t.y,e.z,t.z;return Math.sqrt(this.squaredDistance(t,e))},t.squaredDistance=function(t,e){var s=e.x-t.x,i=e.y-t.y,u=e.z-t.z;return s*s+i*i+u*u},t.direction=function(e,s,i){void 0===i&&(i=null),i||(i=new t);var u=e.x-s.x,a=e.y-s.y,n=e.z-s.z,r=Math.sqrt(u*u+a*a+n*n);return 0===r?(i.x=0,i.y=0,i.z=0,i):(r=1/r,i.x=u*r,i.y=a*r,i.z=n*r,i)},t.mix=function(e,s,i,u){return void 0===u&&(u=null),u||(u=new t),u.x=e.x+i*(s.x-e.x),u.y=e.y+i*(s.y-e.y),u.z=e.z+i*(s.z-e.z),u},t.sum=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x+s.x,i.y=e.y+s.y,i.z=e.z+s.z,i},t.difference=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x-s.x,i.y=e.y-s.y,i.z=e.z-s.z,i},t.product=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x*s.x,i.y=e.y*s.y,i.z=e.z*s.z,i},t.quotient=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x/s.x,i.y=e.y/s.y,i.z=e.z/s.z,i},t.prototype.toQuat=function(e){void 0===e&&(e=null),e||(e=new i.default);var s=new t,u=new t;return s.x=Math.cos(.5*this.x),u.x=Math.sin(.5*this.x),s.y=Math.cos(.5*this.y),u.y=Math.sin(.5*this.y),s.z=Math.cos(.5*this.z),u.z=Math.sin(.5*this.z),e.x=u.x*s.y*s.z-s.x*u.y*u.z,e.y=s.x*u.y*s.z+u.x*s.y*u.z,e.z=s.x*s.y*u.z-u.x*u.y*s.z,e.w=s.x*s.y*s.z+u.x*u.y*u.z,e},t.zero=new t([0,0,0]),t.up=new t([0,1,0]),t.right=new t([1,0,0]),t.forward=new t([0,0,1]),t}();e.default=a},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(1),u=s(0),a=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(2),t&&(this.xy=t)}return Object.defineProperty(t.prototype,"x",{get:function(){return this.values[0]},set:function(t){this.values[0]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"y",{get:function(){return this.values[1]},set:function(t){this.values[1]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xy",{get:function(){return[this.values[0],this.values[1]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1]},enumerable:!0,configurable:!0}),t.prototype.at=function(t){return this.values[t]},t.prototype.reset=function(){this.x=0,this.y=0},t.prototype.copy=function(e){return void 0===e&&(e=null),e||(e=new t),e.x=this.x,e.y=this.y,e},t.prototype.negate=function(t){return void 0===t&&(t=null),t||(t=this),t.x=-this.x,t.y=-this.y,t},t.prototype.equals=function(t,e){return void 0===e&&(e=u.epsilon),!(Math.abs(this.x-t.x)>e)&&!(Math.abs(this.y-t.y)>e)},t.prototype.length=function(){return Math.sqrt(this.squaredLength())},t.prototype.squaredLength=function(){var t=this.x,e=this.y;return t*t+e*e},t.prototype.add=function(t){return this.x+=t.x,this.y+=t.y,this},t.prototype.subtract=function(t){return this.x-=t.x,this.y-=t.y,this},t.prototype.multiply=function(t){return this.x*=t.x,this.y*=t.y,this},t.prototype.divide=function(t){return this.x/=t.x,this.y/=t.y,this},t.prototype.scale=function(t,e){return void 0===e&&(e=null),e||(e=this),e.x*=t,e.y*=t,e},t.prototype.normalize=function(t){void 0===t&&(t=null),t||(t=this);var e=this.length();return 1===e?this:0===e?(t.x=0,t.y=0,t):(e=1/e,t.x*=e,t.y*=e,t)},t.prototype.multiplyMat2=function(t,e){return void 0===e&&(e=null),e||(e=this),t.multiplyVec2(this,e)},t.prototype.multiplyMat3=function(t,e){return void 0===e&&(e=null),e||(e=this),t.multiplyVec2(this,e)},t.cross=function(t,e,s){void 0===s&&(s=null),s||(s=new i.default);var u=t.x,a=t.y,n=e.x,r=u*e.y-a*n;return s.x=0,s.y=0,s.z=r,s},t.dot=function(t,e){return t.x*e.x+t.y*e.y},t.distance=function(t,e){return Math.sqrt(this.squaredDistance(t,e))},t.squaredDistance=function(t,e){var s=e.x-t.x,i=e.y-t.y;return s*s+i*i},t.direction=function(e,s,i){void 0===i&&(i=null),i||(i=new t);var u=e.x-s.x,a=e.y-s.y,n=Math.sqrt(u*u+a*a);return 0===n?(i.x=0,i.y=0,i):(n=1/n,i.x=u*n,i.y=a*n,i)},t.mix=function(e,s,i,u){void 0===u&&(u=null),u||(u=new t);var a=e.x,n=e.y,r=s.x,l=s.y;return u.x=a+i*(r-a),u.y=n+i*(l-n),u},t.sum=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x+s.x,i.y=e.y+s.y,i},t.difference=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x-s.x,i.y=e.y-s.y,i},t.product=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x*s.x,i.y=e.y*s.y,i},t.quotient=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x/s.x,i.y=e.y/s.y,i},t.zero=new t([0,0]),t}();e.default=a},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(1),u=s(4),a=s(5),n=s(0),r=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(4),t&&(this.xyzw=t)}return Object.defineProperty(t.prototype,"x",{get:function(){return this.values[0]},set:function(t){this.values[0]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"y",{get:function(){return this.values[1]},set:function(t){this.values[1]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"z",{get:function(){return this.values[2]},set:function(t){this.values[2]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"w",{get:function(){return this.values[3]},set:function(t){this.values[3]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xy",{get:function(){return[this.values[0],this.values[1]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xyz",{get:function(){return[this.values[0],this.values[1],this.values[2]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xyzw",{get:function(){return[this.values[0],this.values[1],this.values[2],this.values[3]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2],this.values[3]=t[3]},enumerable:!0,configurable:!0}),t.prototype.at=function(t){return this.values[t]},t.prototype.reset=function(){for(var t=0;t<4;t++)this.values[t]=0},t.prototype.copy=function(e){void 0===e&&(e=null),e||(e=new t);for(var s=0;s<4;s++)e.values[s]=this.values[s];return e},t.prototype.roll=function(){var t=this.x,e=this.y,s=this.z,i=this.w;return Math.atan2(2*(t*e+i*s),i*i+t*t-e*e-s*s)},t.prototype.pitch=function(){var t=this.x,e=this.y,s=this.z,i=this.w;return Math.atan2(2*(e*s+i*t),i*i-t*t-e*e+s*s)},t.prototype.yaw=function(){return Math.asin(2*(this.x*this.z-this.w*this.y))},t.prototype.equals=function(t,e){void 0===e&&(e=n.epsilon);for(var s=0;s<4;s++)if(Math.abs(this.values[s]-t.at(s))>e)return!1;return!0},t.prototype.setIdentity=function(){return this.x=0,this.y=0,this.z=0,this.w=1,this},t.prototype.calculateW=function(){var t=this.x,e=this.y,s=this.z;return this.w=-Math.sqrt(Math.abs(1-t*t-e*e-s*s)),this},t.dot=function(t,e){return t.x*e.x+t.y*e.y+t.z*e.z+t.w*e.w},t.prototype.inverse=function(){var e=t.dot(this,this);if(!e)return this.xyzw=[0,0,0,0],this;var s=e?1/e:0;return this.x*=-s,this.y*=-s,this.z*=-s,this.w*=s,this},t.prototype.conjugate=function(){return this.values[0]*=-1,this.values[1]*=-1,this.values[2]*=-1,this},t.prototype.length=function(){var t=this.x,e=this.y,s=this.z,i=this.w;return Math.sqrt(t*t+e*e+s*s+i*i)},t.prototype.normalize=function(t){void 0===t&&(t=null),t||(t=this);var e=this.x,s=this.y,i=this.z,u=this.w,a=Math.sqrt(e*e+s*s+i*i+u*u);return a?(a=1/a,t.x=e*a,t.y=s*a,t.z=i*a,t.w=u*a,t):(t.x=0,t.y=0,t.z=0,t.w=0,t)},t.prototype.add=function(t){for(var e=0;e<4;e++)this.values[e]+=t.at(e);return this},t.prototype.multiply=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3],a=t.x,n=t.y,r=t.z,l=t.w;return this.x=e*l+u*a+s*r-i*n,this.y=s*l+u*n+i*a-e*r,this.z=i*l+u*r+e*n-s*a,this.w=u*l-e*a-s*n-i*r,this},t.prototype.multiplyVec3=function(t,e){void 0===e&&(e=null),e||(e=new i.default);var s=t.x,u=t.y,a=t.z,n=this.x,r=this.y,l=this.z,h=this.w,o=h*s+r*a-l*u,v=h*u+l*s-n*a,y=h*a+n*u-r*s,c=-n*s-r*u-l*a;return e.x=o*h+c*-n+v*-l-y*-r,e.y=v*h+c*-r+y*-n-o*-l,e.z=y*h+c*-l+o*-r-v*-n,e},t.prototype.toMat3=function(t){void 0===t&&(t=null),t||(t=new u.default);var e=this.x,s=this.y,i=this.z,a=this.w,n=e+e,r=s+s,l=i+i,h=e*n,o=e*r,v=e*l,y=s*r,c=s*l,f=i*l,p=a*n,d=a*r,x=a*l;return t.init([1-(y+f),o+x,v-d,o-x,1-(h+f),c+p,v+d,c-p,1-(h+y)]),t},t.prototype.toMat4=function(t){void 0===t&&(t=null),t||(t=new a.default);var e=this.x,s=this.y,i=this.z,u=this.w,n=e+e,r=s+s,l=i+i,h=e*n,o=e*r,v=e*l,y=s*r,c=s*l,f=i*l,p=u*n,d=u*r,x=u*l;return t.init([1-(y+f),o+x,v-d,0,o-x,1-(h+f),c+p,0,v+d,c-p,1-(h+y),0,0,0,0,1]),t},t.sum=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x+s.x,i.y=e.y+s.y,i.z=e.z+s.z,i.w=e.w+s.w,i},t.product=function(e,s,i){void 0===i&&(i=null),i||(i=new t);var u=e.x,a=e.y,n=e.z,r=e.w,l=s.x,h=s.y,o=s.z,v=s.w;return i.x=u*v+r*l+a*o-n*h,i.y=a*v+r*h+n*l-u*o,i.z=n*v+r*o+u*h-a*l,i.w=r*v-u*l-a*h-n*o,i},t.cross=function(e,s,i){void 0===i&&(i=null),i||(i=new t);var u=e.x,a=e.y,n=e.z,r=e.w,l=s.x,h=s.y,o=s.z,v=s.w;return i.x=r*o+n*v+u*h-a*l,i.y=r*v-u*l-a*h-n*o,i.z=r*l+u*v+a*o-n*h,i.w=r*h+a*v+n*l-u*o,i},t.shortMix=function(e,s,i,u){if(void 0===u&&(u=null),u||(u=new t),i<=0)return u.xyzw=e.xyzw,u;if(i>=1)return u.xyzw=s.xyzw,u;var a,n,r=t.dot(e,s),l=s.copy();if(r<0&&(l.inverse(),r=-r),r>.9999)a=1-i,n=0+i;else{var h=Math.sqrt(1-r*r),o=Math.atan2(h,r),v=1/h;a=Math.sin((1-i)*o)*v,n=Math.sin((0+i)*o)*v}return u.x=a*e.x+n*l.x,u.y=a*e.y+n*l.y,u.z=a*e.z+n*l.z,u.w=a*e.w+n*l.w,u},t.mix=function(e,s,i,u){void 0===u&&(u=null),u||(u=new t);var a=e.x*s.x+e.y*s.y+e.z*s.z+e.w*s.w;if(Math.abs(a)>=1)return u.xyzw=e.xyzw,u;var n=Math.acos(a),r=Math.sqrt(1-a*a);if(Math.abs(r)<.001)return u.x=.5*e.x+.5*s.x,u.y=.5*e.y+.5*s.y,u.z=.5*e.z+.5*s.z,u.w=.5*e.w+.5*s.w,u;var l=Math.sin((1-i)*n)/r,h=Math.sin(i*n)/r;return u.x=e.x*l+s.x*h,u.y=e.y*l+s.y*h,u.z=e.z*l+s.z*h,u.w=e.w*l+s.w*h,u},t.fromAxis=function(e,s,i){void 0===i&&(i=null),i||(i=new t),s*=.5;var u=Math.sin(s);return i.x=e.x*u,i.y=e.y*u,i.z=e.z*u,i.w=Math.cos(s),i},t.identity=(new t).setIdentity(),t}();e.default=r},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(2),u=s(1),a=s(5),n=s(3),r=s(0),l=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(9),t&&this.init(t)}return t.prototype.at=function(t){return this.values[t]},t.prototype.init=function(t){for(var e=0;e<9;e++)this.values[e]=t[e];return this},t.prototype.reset=function(){for(var t=0;t<9;t++)this.values[t]=0},t.prototype.copy=function(e){void 0===e&&(e=null),e||(e=new t);for(var s=0;s<9;s++)e.values[s]=this.values[s];return e},t.prototype.all=function(){for(var t=[],e=0;e<9;e++)t[e]=this.values[e];return t},t.prototype.row=function(t){return[this.values[3*t+0],this.values[3*t+1],this.values[3*t+2]]},t.prototype.col=function(t){return[this.values[t],this.values[t+3],this.values[t+6]]},t.prototype.equals=function(t,e){void 0===e&&(e=r.epsilon);for(var s=0;s<9;s++)if(Math.abs(this.values[s]-t.at(s))>e)return!1;return!0},t.prototype.determinant=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[3],u=this.values[4],a=this.values[5],n=this.values[6],r=this.values[7],l=this.values[8];return t*(l*u-a*r)+e*(-l*i+a*n)+s*(r*i-u*n)},t.prototype.setIdentity=function(){return this.values[0]=1,this.values[1]=0,this.values[2]=0,this.values[3]=0,this.values[4]=1,this.values[5]=0,this.values[6]=0,this.values[7]=0,this.values[8]=1,this},t.prototype.transpose=function(){var t=this.values[1],e=this.values[2],s=this.values[5];return this.values[1]=this.values[3],this.values[2]=this.values[6],this.values[3]=t,this.values[5]=this.values[7],this.values[6]=e,this.values[7]=s,this},t.prototype.inverse=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[3],u=this.values[4],a=this.values[5],n=this.values[6],r=this.values[7],l=this.values[8],h=l*u-a*r,o=-l*i+a*n,v=r*i-u*n,y=t*h+e*o+s*v;return y?(y=1/y,this.values[0]=h*y,this.values[1]=(-l*e+s*r)*y,this.values[2]=(a*e-s*u)*y,this.values[3]=o*y,this.values[4]=(l*t-s*n)*y,this.values[5]=(-a*t+s*i)*y,this.values[6]=v*y,this.values[7]=(-r*t+e*n)*y,this.values[8]=(u*t-e*i)*y,this):null},t.prototype.multiply=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3],a=this.values[4],n=this.values[5],r=this.values[6],l=this.values[7],h=this.values[8],o=t.at(0),v=t.at(1),y=t.at(2),c=t.at(3),f=t.at(4),p=t.at(5),d=t.at(6),x=t.at(7),z=t.at(8);return this.values[0]=o*e+v*u+y*r,this.values[1]=o*s+v*a+y*l,this.values[2]=o*i+v*n+y*h,this.values[3]=c*e+f*u+p*r,this.values[4]=c*s+f*a+p*l,this.values[5]=c*i+f*n+p*h,this.values[6]=d*e+x*u+z*r,this.values[7]=d*s+x*a+z*l,this.values[8]=d*i+x*n+z*h,this},t.prototype.multiplyVec2=function(t,e){void 0===e&&(e=null);var s=t.x,u=t.y;return e?(e.xy=[s*this.values[0]+u*this.values[3]+this.values[6],s*this.values[1]+u*this.values[4]+this.values[7]],e):new i.default([s*this.values[0]+u*this.values[3]+this.values[6],s*this.values[1]+u*this.values[4]+this.values[7]])},t.prototype.multiplyVec3=function(t,e){void 0===e&&(e=null);var s=t.x,i=t.y,a=t.z;return e?(e.xyz=[s*this.values[0]+i*this.values[3]+a*this.values[6],s*this.values[1]+i*this.values[4]+a*this.values[7],s*this.values[2]+i*this.values[5]+a*this.values[8]],e):new u.default([s*this.values[0]+i*this.values[3]+a*this.values[6],s*this.values[1]+i*this.values[4]+a*this.values[7],s*this.values[2]+i*this.values[5]+a*this.values[8]])},t.prototype.toMat4=function(t){return void 0===t&&(t=null),t?(t.init([this.values[0],this.values[1],this.values[2],0,this.values[3],this.values[4],this.values[5],0,this.values[6],this.values[7],this.values[8],0,0,0,0,1]),t):new a.default([this.values[0],this.values[1],this.values[2],0,this.values[3],this.values[4],this.values[5],0,this.values[6],this.values[7],this.values[8],0,0,0,0,1])},t.prototype.toQuat=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[3],u=this.values[4],a=this.values[5],r=this.values[6],l=this.values[7],h=this.values[8],o=t-u-h,v=u-t-h,y=h-t-u,c=0,f=t+u+h;o>f&&(f=o,c=1),v>f&&(f=v,c=2),y>f&&(f=y,c=3);var p=.5*Math.sqrt(f+1),d=.25/p,x=new n.default;switch(c){case 0:x.w=p,x.x=(a-l)*d,x.y=(r-s)*d,x.z=(e-i)*d;break;case 1:x.w=(a-l)*d,x.x=p,x.y=(e+i)*d,x.z=(r+s)*d;break;case 2:x.w=(r-s)*d,x.x=(e+i)*d,x.y=p,x.z=(a+l)*d;break;case 3:x.w=(e-i)*d,x.x=(r+s)*d,x.y=(a+l)*d,x.z=p}return x},t.prototype.rotate=function(t,e){var s=e.x,i=e.y,u=e.z,a=Math.sqrt(s*s+i*i+u*u);if(!a)return null;1!==a&&(s*=a=1/a,i*=a,u*=a);var n=Math.sin(t),r=Math.cos(t),l=1-r,h=this.values[0],o=this.values[1],v=this.values[2],y=this.values[4],c=this.values[5],f=this.values[6],p=this.values[8],d=this.values[9],x=this.values[10],z=s*s*l+r,w=i*s*l+u*n,b=u*s*l-i*n,g=s*i*l-u*n,m=i*i*l+r,M=u*i*l+s*n,j=s*u*l+i*n,O=i*u*l-s*n,P=u*u*l+r;return this.values[0]=h*z+y*w+p*b,this.values[1]=o*z+c*w+d*b,this.values[2]=v*z+f*w+x*b,this.values[3]=h*g+y*m+p*M,this.values[4]=o*g+c*m+d*M,this.values[5]=v*g+f*m+x*M,this.values[6]=h*j+y*O+p*P,this.values[7]=o*j+c*O+d*P,this.values[8]=v*j+f*O+x*P,this},t.product=function(e,s,i){void 0===i&&(i=null);var u=e.at(0),a=e.at(1),n=e.at(2),r=e.at(3),l=e.at(4),h=e.at(5),o=e.at(6),v=e.at(7),y=e.at(8),c=s.at(0),f=s.at(1),p=s.at(2),d=s.at(3),x=s.at(4),z=s.at(5),w=s.at(6),b=s.at(7),g=s.at(8);return i?(i.init([c*u+f*r+p*o,c*a+f*l+p*v,c*n+f*h+p*y,d*u+x*r+z*o,d*a+x*l+z*v,d*n+x*h+z*y,w*u+b*r+g*o,w*a+b*l+g*v,w*n+b*h+g*y]),i):new t([c*u+f*r+p*o,c*a+f*l+p*v,c*n+f*h+p*y,d*u+x*r+z*o,d*a+x*l+z*v,d*n+x*h+z*y,w*u+b*r+g*o,w*a+b*l+g*v,w*n+b*h+g*y])},t.identity=(new t).setIdentity(),t}();e.default=l},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(1),u=s(6),a=s(4),n=s(0),r=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(16),t&&this.init(t)}return t.prototype.at=function(t){return this.values[t]},t.prototype.init=function(t){for(var e=0;e<16;e++)this.values[e]=t[e];return this},t.prototype.reset=function(){for(var t=0;t<16;t++)this.values[t]=0},t.prototype.copy=function(e){void 0===e&&(e=null),e||(e=new t);for(var s=0;s<16;s++)e.values[s]=this.values[s];return e},t.prototype.all=function(){for(var t=[],e=0;e<16;e++)t[e]=this.values[e];return t},t.prototype.row=function(t){return[this.values[4*t+0],this.values[4*t+1],this.values[4*t+2],this.values[4*t+3]]},t.prototype.col=function(t){return[this.values[t],this.values[t+4],this.values[t+8],this.values[t+12]]},t.prototype.equals=function(t,e){void 0===e&&(e=n.epsilon);for(var s=0;s<16;s++)if(Math.abs(this.values[s]-t.at(s))>e)return!1;return!0},t.prototype.determinant=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[3],u=this.values[4],a=this.values[5],n=this.values[6],r=this.values[7],l=this.values[8],h=this.values[9],o=this.values[10],v=this.values[11],y=this.values[12],c=this.values[13],f=this.values[14],p=this.values[15];return(t*a-e*u)*(o*p-v*f)-(t*n-s*u)*(h*p-v*c)+(t*r-i*u)*(h*f-o*c)+(e*n-s*a)*(l*p-v*y)-(e*r-i*a)*(l*f-o*y)+(s*r-i*n)*(l*c-h*y)},t.prototype.setIdentity=function(){return this.values[0]=1,this.values[1]=0,this.values[2]=0,this.values[3]=0,this.values[4]=0,this.values[5]=1,this.values[6]=0,this.values[7]=0,this.values[8]=0,this.values[9]=0,this.values[10]=1,this.values[11]=0,this.values[12]=0,this.values[13]=0,this.values[14]=0,this.values[15]=1,this},t.prototype.transpose=function(){var t=this.values[1],e=this.values[2],s=this.values[3],i=this.values[6],u=this.values[7],a=this.values[11];return this.values[1]=this.values[4],this.values[2]=this.values[8],this.values[3]=this.values[12],this.values[4]=t,this.values[6]=this.values[9],this.values[7]=this.values[13],this.values[8]=e,this.values[9]=i,this.values[11]=this.values[14],this.values[12]=s,this.values[13]=u,this.values[14]=a,this},t.prototype.inverse=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[3],u=this.values[4],a=this.values[5],n=this.values[6],r=this.values[7],l=this.values[8],h=this.values[9],o=this.values[10],v=this.values[11],y=this.values[12],c=this.values[13],f=this.values[14],p=this.values[15],d=t*a-e*u,x=t*n-s*u,z=t*r-i*u,w=e*n-s*a,b=e*r-i*a,g=s*r-i*n,m=l*c-h*y,M=l*f-o*y,j=l*p-v*y,O=h*f-o*c,P=h*p-v*c,q=o*p-v*f,_=d*q-x*P+z*O+w*j-b*M+g*m;return _?(_=1/_,this.values[0]=(a*q-n*P+r*O)*_,this.values[1]=(-e*q+s*P-i*O)*_,this.values[2]=(c*g-f*b+p*w)*_,this.values[3]=(-h*g+o*b-v*w)*_,this.values[4]=(-u*q+n*j-r*M)*_,this.values[5]=(t*q-s*j+i*M)*_,this.values[6]=(-y*g+f*z-p*x)*_,this.values[7]=(l*g-o*z+v*x)*_,this.values[8]=(u*P-a*j+r*m)*_,this.values[9]=(-t*P+e*j-i*m)*_,this.values[10]=(y*b-c*z+p*d)*_,this.values[11]=(-l*b+h*z-v*d)*_,this.values[12]=(-u*O+a*M-n*m)*_,this.values[13]=(t*O-e*M+s*m)*_,this.values[14]=(-y*w+c*x-f*d)*_,this.values[15]=(l*w-h*x+o*d)*_,this):null},t.prototype.multiply=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3],a=this.values[4],n=this.values[5],r=this.values[6],l=this.values[7],h=this.values[8],o=this.values[9],v=this.values[10],y=this.values[11],c=this.values[12],f=this.values[13],p=this.values[14],d=this.values[15],x=t.at(0),z=t.at(1),w=t.at(2),b=t.at(3);return this.values[0]=x*e+z*a+w*h+b*c,this.values[1]=x*s+z*n+w*o+b*f,this.values[2]=x*i+z*r+w*v+b*p,this.values[3]=x*u+z*l+w*y+b*d,x=t.at(4),z=t.at(5),w=t.at(6),b=t.at(7),this.values[4]=x*e+z*a+w*h+b*c,this.values[5]=x*s+z*n+w*o+b*f,this.values[6]=x*i+z*r+w*v+b*p,this.values[7]=x*u+z*l+w*y+b*d,x=t.at(8),z=t.at(9),w=t.at(10),b=t.at(11),this.values[8]=x*e+z*a+w*h+b*c,this.values[9]=x*s+z*n+w*o+b*f,this.values[10]=x*i+z*r+w*v+b*p,this.values[11]=x*u+z*l+w*y+b*d,x=t.at(12),z=t.at(13),w=t.at(14),b=t.at(15),this.values[12]=x*e+z*a+w*h+b*c,this.values[13]=x*s+z*n+w*o+b*f,this.values[14]=x*i+z*r+w*v+b*p,this.values[15]=x*u+z*l+w*y+b*d,this},t.prototype.multiplyVec3=function(t){var e=t.x,s=t.y,u=t.z;return new i.default([this.values[0]*e+this.values[4]*s+this.values[8]*u+this.values[12],this.values[1]*e+this.values[5]*s+this.values[9]*u+this.values[13],this.values[2]*e+this.values[6]*s+this.values[10]*u+this.values[14]])},t.prototype.multiplyVec4=function(t,e){void 0===e&&(e=null),e||(e=new u.default);var s=t.x,i=t.y,a=t.z,n=t.w;return e.x=this.values[0]*s+this.values[4]*i+this.values[8]*a+this.values[12]*n,e.y=this.values[1]*s+this.values[5]*i+this.values[9]*a+this.values[13]*n,e.z=this.values[2]*s+this.values[6]*i+this.values[10]*a+this.values[14]*n,e.w=this.values[3]*s+this.values[7]*i+this.values[11]*a+this.values[15]*n,e},t.prototype.toMat3=function(){return new a.default([this.values[0],this.values[1],this.values[2],this.values[4],this.values[5],this.values[6],this.values[8],this.values[9],this.values[10]])},t.prototype.toInverseMat3=function(){var t=this.values[0],e=this.values[1],s=this.values[2],i=this.values[4],u=this.values[5],n=this.values[6],r=this.values[8],l=this.values[9],h=this.values[10],o=h*u-n*l,v=-h*i+n*r,y=l*i-u*r,c=t*o+e*v+s*y;return c?(c=1/c,new a.default([o*c,(-h*e+s*l)*c,(n*e-s*u)*c,v*c,(h*t-s*r)*c,(-n*t+s*i)*c,y*c,(-l*t+e*r)*c,(u*t-e*i)*c])):null},t.prototype.translate=function(t){var e=t.x,s=t.y,i=t.z;return this.values[12]+=this.values[0]*e+this.values[4]*s+this.values[8]*i,this.values[13]+=this.values[1]*e+this.values[5]*s+this.values[9]*i,this.values[14]+=this.values[2]*e+this.values[6]*s+this.values[10]*i,this.values[15]+=this.values[3]*e+this.values[7]*s+this.values[11]*i,this},t.prototype.scale=function(t){var e=t.x,s=t.y,i=t.z;return this.values[0]*=e,this.values[1]*=e,this.values[2]*=e,this.values[3]*=e,this.values[4]*=s,this.values[5]*=s,this.values[6]*=s,this.values[7]*=s,this.values[8]*=i,this.values[9]*=i,this.values[10]*=i,this.values[11]*=i,this},t.prototype.rotate=function(t,e){var s=e.x,i=e.y,u=e.z,a=Math.sqrt(s*s+i*i+u*u);if(!a)return null;1!==a&&(s*=a=1/a,i*=a,u*=a);var n=Math.sin(t),r=Math.cos(t),l=1-r,h=this.values[0],o=this.values[1],v=this.values[2],y=this.values[3],c=this.values[4],f=this.values[5],p=this.values[6],d=this.values[7],x=this.values[8],z=this.values[9],w=this.values[10],b=this.values[11],g=s*s*l+r,m=i*s*l+u*n,M=u*s*l-i*n,j=s*i*l-u*n,O=i*i*l+r,P=u*i*l+s*n,q=s*u*l+i*n,_=i*u*l-s*n,V=u*u*l+r;return this.values[0]=h*g+c*m+x*M,this.values[1]=o*g+f*m+z*M,this.values[2]=v*g+p*m+w*M,this.values[3]=y*g+d*m+b*M,this.values[4]=h*j+c*O+x*P,this.values[5]=o*j+f*O+z*P,this.values[6]=v*j+p*O+w*P,this.values[7]=y*j+d*O+b*P,this.values[8]=h*q+c*_+x*V,this.values[9]=o*q+f*_+z*V,this.values[10]=v*q+p*_+w*V,this.values[11]=y*q+d*_+b*V,this},t.frustum=function(e,s,i,u,a,n){var r=s-e,l=u-i,h=n-a;return new t([2*a/r,0,0,0,0,2*a/l,0,0,(s+e)/r,(u+i)/l,-(n+a)/h,-1,0,0,-n*a*2/h,0])},t.perspective=function(e,s,i,u){var a=i*Math.tan(e*Math.PI/360),n=a*s;return t.frustum(-n,n,-a,a,i,u)},t.orthographic=function(e,s,i,u,a,n){var r=s-e,l=u-i,h=n-a;return new t([2/r,0,0,0,0,2/l,0,0,0,0,-2/h,0,-(e+s)/r,-(u+i)/l,-(n+a)/h,1])},t.lookAt=function(e,s,u){if(void 0===u&&(u=i.default.up),e.equals(s))return this.identity;var a=i.default.difference(e,s).normalize(),n=i.default.cross(u,a).normalize(),r=i.default.cross(a,n).normalize();return new t([n.x,r.x,a.x,0,n.y,r.y,a.y,0,n.z,r.z,a.z,0,-i.default.dot(n,e),-i.default.dot(r,e),-i.default.dot(a,e),1])},t.product=function(e,s,i){void 0===i&&(i=null);var u=e.at(0),a=e.at(1),n=e.at(2),r=e.at(3),l=e.at(4),h=e.at(5),o=e.at(6),v=e.at(7),y=e.at(8),c=e.at(9),f=e.at(10),p=e.at(11),d=e.at(12),x=e.at(13),z=e.at(14),w=e.at(15),b=s.at(0),g=s.at(1),m=s.at(2),M=s.at(3),j=s.at(4),O=s.at(5),P=s.at(6),q=s.at(7),_=s.at(8),V=s.at(9),I=s.at(10),A=s.at(11),F=s.at(12),L=s.at(13),S=s.at(14),k=s.at(15);return i?(i.init([b*u+g*l+m*y+M*d,b*a+g*h+m*c+M*x,b*n+g*o+m*f+M*z,b*r+g*v+m*p+M*w,j*u+O*l+P*y+q*d,j*a+O*h+P*c+q*x,j*n+O*o+P*f+q*z,j*r+O*v+P*p+q*w,_*u+V*l+I*y+A*d,_*a+V*h+I*c+A*x,_*n+V*o+I*f+A*z,_*r+V*v+I*p+A*w,F*u+L*l+S*y+k*d,F*a+L*h+S*c+k*x,F*n+L*o+S*f+k*z,F*r+L*v+S*p+k*w]),i):new t([b*u+g*l+m*y+M*d,b*a+g*h+m*c+M*x,b*n+g*o+m*f+M*z,b*r+g*v+m*p+M*w,j*u+O*l+P*y+q*d,j*a+O*h+P*c+q*x,j*n+O*o+P*f+q*z,j*r+O*v+P*p+q*w,_*u+V*l+I*y+A*d,_*a+V*h+I*c+A*x,_*n+V*o+I*f+A*z,_*r+V*v+I*p+A*w,F*u+L*l+S*y+k*d,F*a+L*h+S*c+k*x,F*n+L*o+S*f+k*z,F*r+L*v+S*p+k*w])},t.identity=(new t).setIdentity(),t}();e.default=r},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(0),u=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(4),t&&(this.xyzw=t)}return Object.defineProperty(t.prototype,"x",{get:function(){return this.values[0]},set:function(t){this.values[0]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"y",{get:function(){return this.values[1]},set:function(t){this.values[1]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"z",{get:function(){return this.values[2]},set:function(t){this.values[2]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"w",{get:function(){return this.values[3]},set:function(t){this.values[3]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xy",{get:function(){return[this.values[0],this.values[1]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xyz",{get:function(){return[this.values[0],this.values[1],this.values[2]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"xyzw",{get:function(){return[this.values[0],this.values[1],this.values[2],this.values[3]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2],this.values[3]=t[3]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"r",{get:function(){return this.values[0]},set:function(t){this.values[0]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"g",{get:function(){return this.values[1]},set:function(t){this.values[1]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"b",{get:function(){return this.values[2]},set:function(t){this.values[2]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"a",{get:function(){return this.values[3]},set:function(t){this.values[3]=t},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rg",{get:function(){return[this.values[0],this.values[1]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rgb",{get:function(){return[this.values[0],this.values[1],this.values[2]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2]},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"rgba",{get:function(){return[this.values[0],this.values[1],this.values[2],this.values[3]]},set:function(t){this.values[0]=t[0],this.values[1]=t[1],this.values[2]=t[2],this.values[3]=t[3]},enumerable:!0,configurable:!0}),t.prototype.at=function(t){return this.values[t]},t.prototype.reset=function(){this.x=0,this.y=0,this.z=0,this.w=0},t.prototype.copy=function(e){return void 0===e&&(e=null),e||(e=new t),e.x=this.x,e.y=this.y,e.z=this.z,e.w=this.w,e},t.prototype.negate=function(t){return void 0===t&&(t=null),t||(t=this),t.x=-this.x,t.y=-this.y,t.z=-this.z,t.w=-this.w,t},t.prototype.equals=function(t,e){return void 0===e&&(e=i.epsilon),!(Math.abs(this.x-t.x)>e)&&(!(Math.abs(this.y-t.y)>e)&&(!(Math.abs(this.z-t.z)>e)&&!(Math.abs(this.w-t.w)>e)))},t.prototype.length=function(){return Math.sqrt(this.squaredLength())},t.prototype.squaredLength=function(){var t=this.x,e=this.y,s=this.z,i=this.w;return t*t+e*e+s*s+i*i},t.prototype.add=function(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this.w+=t.w,this},t.prototype.subtract=function(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this.w-=t.w,this},t.prototype.multiply=function(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this.w*=t.w,this},t.prototype.divide=function(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this.w/=t.w,this},t.prototype.scale=function(t,e){return void 0===e&&(e=null),e||(e=this),e.x*=t,e.y*=t,e.z*=t,e.w*=t,e},t.prototype.normalize=function(t){void 0===t&&(t=null),t||(t=this);var e=this.length();return 1===e?this:0===e?(t.x*=0,t.y*=0,t.z*=0,t.w*=0,t):(e=1/e,t.x*=e,t.y*=e,t.z*=e,t.w*=e,t)},t.prototype.multiplyMat4=function(t,e){return void 0===e&&(e=null),e||(e=this),t.multiplyVec4(this,e)},t.mix=function(e,s,i,u){return void 0===u&&(u=null),u||(u=new t),u.x=e.x+i*(s.x-e.x),u.y=e.y+i*(s.y-e.y),u.z=e.z+i*(s.z-e.z),u.w=e.w+i*(s.w-e.w),u},t.sum=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x+s.x,i.y=e.y+s.y,i.z=e.z+s.z,i.w=e.w+s.w,i},t.difference=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x-s.x,i.y=e.y-s.y,i.z=e.z-s.z,i.w=e.w-s.w,i},t.product=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x*s.x,i.y=e.y*s.y,i.z=e.z*s.z,i.w=e.w*s.w,i},t.quotient=function(e,s,i){return void 0===i&&(i=null),i||(i=new t),i.x=e.x/s.x,i.y=e.y/s.y,i.z=e.z/s.z,i.w=e.w/s.w,i},t.zero=new t([0,0,0,1]),t}();e.default=u},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(2),u=s(1),a=s(6),n=s(8),r=s(4),l=s(5),h=s(3);e.default={vec2:i.default,vec3:u.default,vec4:a.default,mat2:n.default,mat3:r.default,mat4:l.default,quat:h.default}},function(t,e,s){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=s(2),u=s(0),a=function(){function t(t){void 0===t&&(t=null),this.values=new Float32Array(4),t&&this.init(t)}return t.prototype.at=function(t){return this.values[t]},t.prototype.init=function(t){for(var e=0;e<4;e++)this.values[e]=t[e];return this},t.prototype.reset=function(){for(var t=0;t<4;t++)this.values[t]=0},t.prototype.copy=function(e){void 0===e&&(e=null),e||(e=new t);for(var s=0;s<4;s++)e.values[s]=this.values[s];return e},t.prototype.all=function(){for(var t=[],e=0;e<4;e++)t[e]=this.values[e];return t},t.prototype.row=function(t){return[this.values[2*t+0],this.values[2*t+1]]},t.prototype.col=function(t){return[this.values[t],this.values[t+2]]},t.prototype.equals=function(t,e){void 0===e&&(e=u.epsilon);for(var s=0;s<4;s++)if(Math.abs(this.values[s]-t.at(s))>e)return!1;return!0},t.prototype.determinant=function(){return this.values[0]*this.values[3]-this.values[2]*this.values[1]},t.prototype.setIdentity=function(){return this.values[0]=1,this.values[1]=0,this.values[2]=0,this.values[3]=1,this},t.prototype.transpose=function(){var t=this.values[1];return this.values[1]=this.values[2],this.values[2]=t,this},t.prototype.inverse=function(){var t=this.determinant();if(!t)return null;t=1/t;var e=this.values[0];return this.values[0]=t*this.values[3],this.values[1]=t*-this.values[1],this.values[2]=t*-this.values[2],this.values[3]=t*e,this},t.prototype.multiply=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3];return this.values[0]=e*t.at(0)+s*t.at(2),this.values[1]=e*t.at(1)+s*t.at(3),this.values[2]=i*t.at(0)+u*t.at(2),this.values[3]=i*t.at(1)+u*t.at(3),this},t.prototype.rotate=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3],a=Math.sin(t),n=Math.cos(t);return this.values[0]=e*n+s*a,this.values[1]=e*-a+s*n,this.values[2]=i*n+u*a,this.values[3]=i*-a+u*n,this},t.prototype.multiplyVec2=function(t,e){void 0===e&&(e=null);var s=t.x,u=t.y;return e?(e.xy=[s*this.values[0]+u*this.values[1],s*this.values[2]+u*this.values[3]],e):new i.default([s*this.values[0]+u*this.values[1],s*this.values[2]+u*this.values[3]])},t.prototype.scale=function(t){var e=this.values[0],s=this.values[1],i=this.values[2],u=this.values[3],a=t.x,n=t.y;return this.values[0]=e*a,this.values[1]=s*n,this.values[2]=i*a,this.values[3]=u*n,this},t.product=function(e,s,i){void 0===i&&(i=null);var u=e.at(0),a=e.at(1),n=e.at(2),r=e.at(3);return i?(i.init([u*s.at(0)+a*s.at(2),u*s.at(1)+a*s.at(3),n*s.at(0)+r*s.at(2),n*s.at(1)+r*s.at(3)]),i):new t([u*s.at(0)+a*s.at(2),u*s.at(1)+a*s.at(3),n*s.at(0)+r*s.at(2),n*s.at(1)+r*s.at(3)])},t.identity=(new t).setIdentity(),t}();e.default=a}]); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://tsm/webpack/bootstrap","webpack://tsm/./src/constants.ts","webpack://tsm/./src/vec3.ts","webpack://tsm/./src/vec2.ts","webpack://tsm/./src/quat.ts","webpack://tsm/./src/mat3.ts","webpack://tsm/./src/mat4.ts","webpack://tsm/./src/vec4.ts","webpack://tsm/./src/tsm.ts","webpack://tsm/./src/mat2.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","epsilon","quat_1","constants_1","vec3","values","this","Float32Array","xyz","at","index","reset","x","y","z","copy","dest","negate","equals","vector","threshold","Math","abs","length","sqrt","squaredLength","add","subtract","multiply","divide","scale","normalize","multiplyByMat3","matrix","multiplyVec3","multiplyByQuat","quat","cross","vector2","x2","y2","z2","dot","distance","squaredDistance","direction","mix","time","sum","difference","product","quotient","toQuat","default","cos","sin","w","zero","up","right","forward","vec3_1","vec2","xy","multiplyMat2","multiplyVec2","multiplyMat3","mat3_1","mat4_1","xyzw","roll","atan2","pitch","yaw","asin","setIdentity","calculateW","q1","q2","inverse","invDot","conjugate","other","q1x","q1y","q1z","q1w","q2x","q2y","q2z","q2w","qx","qy","qz","qw","ix","iy","iz","iw","toMat3","xx","xz","yy","yz","zz","wx","wy","wz","init","toMat4","shortMix","k0","k1","q2a","angle","oneOverSin","cosHalfTheta","halfTheta","acos","sinHalfTheta","ratioA","ratioB","fromAxis","axis","identity","vec2_1","mat3","all","data","row","col","determinant","a00","a01","a02","a10","a11","a12","a20","a21","a22","transpose","temp01","temp02","temp12","det01","det11","det21","det","b00","b01","b02","b10","b11","b12","b20","b21","b22","result","m00","m01","m02","m10","m11","m12","m20","m21","m22","fourXSquaredMinus1","fourYSquaredMinus1","fourZSquaredMinus1","biggestIndex","fourBiggestSquaredMinus1","biggestVal","mult","rotate","m1","m2","vec4_1","mat4","a03","a13","a23","a30","a31","a32","a33","temp03","temp13","temp23","det00","det02","det03","det04","det05","det06","det07","det08","det09","det10","b0","b1","b2","b3","multiplyVec4","toInverseMat3","translate","frustum","left","bottom","top","near","far","rl","tb","fn","perspective","fov","aspect","tan","PI","orthographic","lookAt","position","target","b03","b13","b23","b30","b31","b32","b33","vec4","multiplyMat4","mat2_1","mat2","temp"],"mappings":"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","file":"tsm.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 7);\n","export const epsilon = 0.000001;\n\n\n\n","import mat3 from './mat3';\nimport quat from './quat';\n\nimport { epsilon } from './constants';\n\nexport default class vec3 {\n\n    private values = new Float32Array(3);\n\n    get x(): number {\n        return this.values[0];\n    }\n\n    get y(): number {\n        return this.values[1];\n    }\n\n    get z(): number {\n        return this.values[2];\n    }\n\n    get xy(): number[] {\n        return [\n            this.values[0],\n            this.values[1]\n        ];\n    }\n\n    get xyz(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2]\n        ];\n    }\n\n    set x(value: number) {\n        this.values[0] = value;\n    }\n\n    set y(value: number) {\n        this.values[1] = value;\n    }\n\n    set z(value: number) {\n        this.values[2] = value;\n    }\n\n    set xy(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n    }\n\n    set xyz(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n    }\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.xyz = values;\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    reset(): void {\n        this.x = 0;\n        this.y = 0;\n        this.z = 0;\n    }\n\n    copy(dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = this.x;\n        dest.y = this.y;\n        dest.z = this.z;\n\n        return dest;\n    }\n\n    negate(dest: vec3 = null): vec3 {\n        if (!dest) dest = this;\n\n        dest.x = -this.x;\n        dest.y = -this.y;\n        dest.z = -this.z;\n\n        return dest;\n    }\n\n    equals(vector: vec3, threshold = epsilon): boolean {\n        if (Math.abs(this.x - vector.x) > threshold)\n            return false;\n\n        if (Math.abs(this.y - vector.y) > threshold)\n            return false;\n\n        if (Math.abs(this.z - vector.z) > threshold)\n            return false;\n\n        return true;\n    }\n\n    length(): number {\n        return Math.sqrt(this.squaredLength());\n    }\n\n    squaredLength(): number {\n        const x = this.x,\n            y = this.y,\n            z = this.z;\n\n        return (x * x + y * y + z * z);\n    }\n\n    add(vector: vec3): vec3 {\n        this.x += vector.x;\n        this.y += vector.y;\n        this.z += vector.z;\n\n        return this;\n    }\n\n    subtract(vector: vec3): vec3 {\n        this.x -= vector.x;\n        this.y -= vector.y;\n        this.z -= vector.z;\n\n        return this;\n    }\n\n    multiply(vector: vec3): vec3 {\n        this.x *= vector.x;\n        this.y *= vector.y;\n        this.z *= vector.z;\n\n        return this;\n    }\n\n    divide(vector: vec3): vec3 {\n        this.x /= vector.x;\n        this.y /= vector.y;\n        this.z /= vector.z;\n\n        return this;\n    }\n\n    scale(value: number, dest: vec3 = null): vec3 {\n        if (!dest) dest = this;\n\n        dest.x *= value;\n        dest.y *= value;\n        dest.z *= value;\n\n        return dest;\n    }\n\n    normalize(dest: vec3 = null): vec3 {\n        if (!dest) dest = this;\n\n        let length = this.length();\n\n        if (length === 1) {\n            return this;\n        }\n\n        if (length === 0) {\n            dest.x = 0;\n            dest.y = 0;\n            dest.z = 0;\n\n            return dest;\n        }\n\n        length = 1.0 / length;\n\n        dest.x *= length;\n        dest.y *= length;\n        dest.z *= length;\n\n        return dest;\n    }\n\n    multiplyByMat3(matrix: mat3, dest: vec3 = null): vec3 {\n        if (!dest) dest = this;\n\n        return matrix.multiplyVec3(this, dest);\n    }\n\n    multiplyByQuat(quat: quat, dest: vec3 = null): vec3 {\n        if (!dest) dest = this;\n\n        return quat.multiplyVec3(this, dest);\n    }\n\n    static cross(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        const x2 = vector2.x,\n            y2 = vector2.y,\n            z2 = vector2.z;\n\n        dest.x = y * z2 - z * y2;\n        dest.y = z * x2 - x * z2;\n        dest.z = x * y2 - y * x2;\n\n        return dest;\n    }\n\n    static dot(vector: vec3, vector2: vec3): number {\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        const x2 = vector2.x,\n            y2 = vector2.y,\n            z2 = vector2.z;\n\n        return (x * x2 + y * y2 + z * z2);\n    }\n\n    static distance(vector: vec3, vector2: vec3): number {\n        const x = vector2.x - vector.x,\n            y = vector2.y - vector.y,\n            z = vector2.z - vector.z;\n\n        return Math.sqrt(this.squaredDistance(vector, vector2));\n    }\n\n    static squaredDistance(vector: vec3, vector2: vec3): number {\n        const x = vector2.x - vector.x,\n            y = vector2.y - vector.y,\n            z = vector2.z - vector.z;\n\n        return (x * x + y * y + z * z);\n    }\n\n    static direction(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        const x = vector.x - vector2.x,\n            y = vector.y - vector2.y,\n            z = vector.z - vector2.z;\n\n        let length = Math.sqrt(x * x + y * y + z * z);\n\n        if (length === 0) {\n            dest.x = 0;\n            dest.y = 0;\n            dest.z = 0;\n\n            return dest;\n        }\n\n        length = 1 / length;\n\n        dest.x = x * length;\n        dest.y = y * length;\n        dest.z = z * length;\n\n        return dest;\n    }\n\n    static mix(vector: vec3, vector2: vec3, time: number, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = vector.x + time * (vector2.x - vector.x);\n        dest.y = vector.y + time * (vector2.y - vector.y);\n        dest.z = vector.z + time * (vector2.z - vector.z);\n\n        return dest;\n    }\n\n    static sum(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = vector.x + vector2.x;\n        dest.y = vector.y + vector2.y;\n        dest.z = vector.z + vector2.z;\n\n        return dest;\n    }\n\n    static difference(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = vector.x - vector2.x;\n        dest.y = vector.y - vector2.y;\n        dest.z = vector.z - vector2.z;\n\n        return dest;\n    }\n\n    static product(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = vector.x * vector2.x;\n        dest.y = vector.y * vector2.y;\n        dest.z = vector.z * vector2.z;\n\n        return dest;\n    }\n\n    static quotient(vector: vec3, vector2: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        dest.x = vector.x / vector2.x;\n        dest.y = vector.y / vector2.y;\n        dest.z = vector.z / vector2.z;\n\n        return dest;\n    }\n\n    toQuat(dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        const c = new vec3();\n        const s = new vec3();\n\n        c.x = Math.cos(this.x * 0.5);\n        s.x = Math.sin(this.x * 0.5);\n\n        c.y = Math.cos(this.y * 0.5);\n        s.y = Math.sin(this.y * 0.5);\n\n        c.z = Math.cos(this.z * 0.5);\n        s.z = Math.sin(this.z * 0.5);\n\n        dest.x = s.x * c.y * c.z - c.x * s.y * s.z;\n        dest.y = c.x * s.y * c.z + s.x * c.y * s.z;\n        dest.z = c.x * c.y * s.z - s.x * s.y * c.z;\n        dest.w = c.x * c.y * c.z + s.x * s.y * s.z;\n\n        return dest;\n    }\n\n    static zero = new vec3([0, 0, 0]);\n\n    static up = new vec3([0, 1, 0]);\n    static right = new vec3([1, 0, 0]);\n    static forward = new vec3([0, 0, 1]);\n}\n","import vec3 from './vec3';\nimport mat2 from './mat2';\nimport mat3 from './mat3';\n\nimport { epsilon } from './constants';\n\nexport default class vec2 {\n\n    private values = new Float32Array(2);\n\n    get x(): number {\n        return this.values[0];\n    }\n\n    get y(): number {\n        return this.values[1];\n    }\n\n    get xy(): number[] {\n        return [\n            this.values[0],\n            this.values[1]\n        ];\n    }\n\n    set x(value: number) {\n        this.values[0] = value;\n    }\n\n    set y(value: number) {\n        this.values[1] = value;\n    }\n\n    set xy(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n    }\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.xy = values;\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    reset(): void {\n        this.x = 0;\n        this.y = 0;\n    }\n\n    copy(dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        dest.x = this.x;\n        dest.y = this.y;\n\n        return dest;\n    }\n\n    negate(dest: vec2 = null): vec2 {\n        if (!dest) dest = this;\n\n        dest.x = -this.x;\n        dest.y = -this.y;\n\n        return dest;\n    }\n\n    equals(vector: vec2, threshold = epsilon): boolean {\n        if (Math.abs(this.x - vector.x) > threshold)\n            return false;\n\n        if (Math.abs(this.y - vector.y) > threshold)\n            return false;\n\n        return true;\n    }\n\n    length(): number {\n        return Math.sqrt(this.squaredLength());\n    }\n\n    squaredLength(): number {\n        const x = this.x,\n            y = this.y;\n\n        return (x * x + y * y);\n    }\n\n    add(vector: vec2): vec2 {\n        this.x += vector.x;\n        this.y += vector.y;\n\n        return this;\n    }\n\n    subtract(vector: vec2): vec2 {\n        this.x -= vector.x;\n        this.y -= vector.y;\n\n        return this;\n    }\n\n    multiply(vector: vec2): vec2 {\n        this.x *= vector.x;\n        this.y *= vector.y;\n\n        return this;\n    }\n\n    divide(vector: vec2): vec2 {\n        this.x /= vector.x;\n        this.y /= vector.y;\n\n        return this;\n    }\n\n    scale(value: number, dest: vec2 = null): vec2 {\n        if (!dest) dest = this;\n\n        dest.x *= value;\n        dest.y *= value;\n\n        return dest;\n    }\n\n    normalize(dest: vec2 = null): vec2 {\n        if (!dest) dest = this;\n\n        let length = this.length();\n\n        if (length === 1) {\n            return this;\n        }\n\n        if (length === 0) {\n            dest.x = 0;\n            dest.y = 0;\n\n            return dest;\n        }\n\n        length = 1.0 / length;\n\n        dest.x *= length;\n        dest.y *= length;\n\n        return dest;\n    }\n\n    multiplyMat2(matrix: mat2, dest: vec2 = null): vec2 {\n        if (!dest) dest = this;\n\n        return matrix.multiplyVec2(this, dest);\n    }\n\n    multiplyMat3(matrix: mat3, dest: vec2 = null): vec2 {\n        if (!dest) dest = this;\n\n        return matrix.multiplyVec2(this, dest);\n    }\n\n    static cross(vector: vec2, vector2: vec2, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        const x = vector.x,\n            y = vector.y;\n\n        const x2 = vector2.x,\n            y2 = vector2.y;\n\n        const z = x * y2 - y * x2;\n\n        dest.x = 0;\n        dest.y = 0;\n        dest.z = z;\n\n        return dest;\n    }\n\n    static dot(vector: vec2, vector2: vec2): number {\n        return (vector.x * vector2.x + vector.y * vector2.y);\n    }\n\n    static distance(vector: vec2, vector2: vec2): number {\n        return Math.sqrt(this.squaredDistance(vector, vector2));\n    }\n\n    static squaredDistance(vector: vec2, vector2: vec2): number {\n        const x = vector2.x - vector.x,\n            y = vector2.y - vector.y;\n\n        return (x * x + y * y);\n    }\n\n    static direction(vector: vec2, vector2: vec2, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        const x = vector.x - vector2.x,\n            y = vector.y - vector2.y;\n\n        let length = Math.sqrt(x * x + y * y);\n\n        if (length === 0) {\n            dest.x = 0;\n            dest.y = 0;\n\n            return dest;\n        }\n\n        length = 1 / length;\n\n        dest.x = x * length;\n        dest.y = y * length;\n\n        return dest;\n    }\n\n    static mix(vector: vec2, vector2: vec2, time: number, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        const x = vector.x,\n            y = vector.y;\n\n        const x2 = vector2.x,\n            y2 = vector2.y;\n\n        dest.x = x + time * (x2 - x);\n        dest.y = y + time * (y2 - y);\n\n        return dest;\n    }\n\n    static sum(vector: vec2, vector2: vec2, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        dest.x = vector.x + vector2.x;\n        dest.y = vector.y + vector2.y;\n\n        return dest;\n    }\n\n    static difference(vector: vec2, vector2: vec2, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        dest.x = vector.x - vector2.x;\n        dest.y = vector.y - vector2.y;\n\n        return dest;\n    }\n\n    static product(vector: vec2, vector2: vec2, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        dest.x = vector.x * vector2.x;\n        dest.y = vector.y * vector2.y;\n\n        return dest;\n    }\n\n    static quotient(vector: vec2, vector2: vec2, dest: vec2 = null): vec2 {\n        if (!dest) dest = new vec2();\n\n        dest.x = vector.x / vector2.x;\n        dest.y = vector.y / vector2.y;\n\n        return dest;\n    }\n\n    static zero = new vec2([0, 0]);\n\n}\n\n","import vec3 from './vec3';\nimport mat3 from './mat3';\nimport mat4 from './mat4';\n\nimport { epsilon } from './constants';\n\nexport default class quat {\n\n    private values = new Float32Array(4);\n\n    get x(): number {\n        return this.values[0];\n    }\n\n    get y(): number {\n        return this.values[1];\n    }\n\n    get z(): number {\n        return this.values[2];\n    }\n\n    get w(): number {\n        return this.values[3];\n    }\n\n    get xy(): number[] {\n        return [\n            this.values[0],\n            this.values[1]\n        ];\n    }\n\n    get xyz(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2]\n        ];\n    }\n\n    get xyzw(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2],\n            this.values[3]\n        ];\n    }\n\n    set x(value: number) {\n        this.values[0] = value;\n    }\n\n    set y(value: number) {\n        this.values[1] = value;\n    }\n\n    set z(value: number) {\n        this.values[2] = value;\n    }\n\n    set w(value: number) {\n        this.values[3] = value;\n    }\n\n    set xy(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n    }\n\n    set xyz(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n    }\n\n    set xyzw(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n        this.values[3] = values[3];\n    }\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.xyzw = values;\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    reset(): void {\n        for (let i = 0; i < 4; i++) {\n            this.values[i] = 0;\n        }\n    }\n\n    copy(dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        for (let i = 0; i < 4; i++) {\n            dest.values[i] = this.values[i];\n        }\n\n        return dest;\n    }\n\n    roll(): number {\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n        return Math.atan2(2.0 * (x * y + w * z), w * w + x * x - y * y - z * z);\n    }\n\n    pitch(): number {\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n        return Math.atan2(2.0 * (y * z + w * x), w * w - x * x - y * y + z * z);\n    }\n\n    yaw(): number {\n        return Math.asin(2.0 * (this.x * this.z - this.w * this.y));\n    }\n\n    equals(vector: quat, threshold = epsilon): boolean {\n        for (let i = 0; i < 4; i++) {\n            if (Math.abs(this.values[i] - vector.at(i)) > threshold)\n                return false;\n        }\n\n        return true;\n    }\n\n    setIdentity(): quat {\n        this.x = 0;\n        this.y = 0;\n        this.z = 0;\n        this.w = 1;\n\n        return this;\n    }\n\n    calculateW(): quat {\n        const x = this.x,\n            y = this.y,\n            z = this.z;\n\n        this.w = -(Math.sqrt(Math.abs(1.0 - x * x - y * y - z * z)));\n\n        return this;\n    }\n\n    static dot(q1: quat, q2: quat): number {\n        return q1.x * q2.x + q1.y * q2.y + q1.z * q2.z + q1.w * q2.w;\n    }\n\n    inverse(): quat {\n        const dot = quat.dot(this, this);\n\n        if (!dot) {\n            this.xyzw = [0, 0, 0, 0];\n\n            return this;\n        }\n\n        const invDot = dot ? 1.0 / dot : 0;\n\n        this.x *= -invDot;\n        this.y *= -invDot;\n        this.z *= -invDot;\n        this.w *= invDot;\n\n        return this;\n    }\n\n    conjugate(): quat {\n        this.values[0] *= -1;\n        this.values[1] *= -1;\n        this.values[2] *= -1;\n\n        return this;\n    }\n\n    length(): number {\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n        return Math.sqrt(x * x + y * y + z * z + w * w);\n    }\n\n    normalize(dest: quat = null): quat {\n        if (!dest) dest = this;\n\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n            let length = Math.sqrt(x * x + y * y + z * z + w * w);\n\n        if (!length) {\n            dest.x = 0;\n            dest.y = 0;\n            dest.z = 0;\n            dest.w = 0;\n\n            return dest;\n        }\n\n        length = 1 / length;\n\n        dest.x = x * length;\n        dest.y = y * length;\n        dest.z = z * length;\n        dest.w = w * length;\n\n        return dest;\n    }\n\n    add(other: quat): quat {\n        for (let i = 0; i < 4; i++) {\n            this.values[i] += other.at(i);\n        }\n\n        return this;\n    }\n\n    multiply(other: quat): quat {\n        const q1x = this.values[0],\n            q1y = this.values[1],\n            q1z = this.values[2],\n            q1w = this.values[3];\n\n        const q2x = other.x,\n            q2y = other.y,\n            q2z = other.z,\n            q2w = other.w;\n\n        this.x = q1x * q2w + q1w * q2x + q1y * q2z - q1z * q2y;\n        this.y = q1y * q2w + q1w * q2y + q1z * q2x - q1x * q2z;\n        this.z = q1z * q2w + q1w * q2z + q1x * q2y - q1y * q2x;\n        this.w = q1w * q2w - q1x * q2x - q1y * q2y - q1z * q2z;\n\n        return this;\n    }\n\n    multiplyVec3(vector: vec3, dest: vec3 = null): vec3 {\n        if (!dest) dest = new vec3();\n\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        const qx = this.x,\n            qy = this.y,\n            qz = this.z,\n            qw = this.w;\n\n        const ix = qw * x + qy * z - qz * y,\n            iy = qw * y + qz * x - qx * z,\n            iz = qw * z + qx * y - qy * x,\n            iw = -qx * x - qy * y - qz * z;\n\n        dest.x = ix * qw + iw * -qx + iy * -qz - iz * -qy;\n        dest.y = iy * qw + iw * -qy + iz * -qx - ix * -qz;\n        dest.z = iz * qw + iw * -qz + ix * -qy - iy * -qx;\n\n        return dest;\n    }\n\n    toMat3(dest: mat3 = null): mat3 {\n        if (!dest) dest = new mat3();\n\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n        const x2 = x + x,\n            y2 = y + y,\n            z2 = z + z;\n\n        const xx = x * x2,\n            xy = x * y2,\n            xz = x * z2,\n            yy = y * y2,\n            yz = y * z2,\n            zz = z * z2,\n            wx = w * x2,\n            wy = w * y2,\n            wz = w * z2;\n\n        dest.init([\n            1 - (yy + zz),\n            xy + wz,\n            xz - wy,\n\n            xy - wz,\n            1 - (xx + zz),\n            yz + wx,\n\n            xz + wy,\n            yz - wx,\n            1 - (xx + yy)\n        ]);\n\n        return dest;\n    }\n\n    toMat4(dest: mat4 = null): mat4 {\n        if (!dest) dest = new mat4();\n\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w,\n\n            x2 = x + x,\n            y2 = y + y,\n            z2 = z + z,\n\n            xx = x * x2,\n            xy = x * y2,\n            xz = x * z2,\n            yy = y * y2,\n            yz = y * z2,\n            zz = z * z2,\n            wx = w * x2,\n            wy = w * y2,\n            wz = w * z2;\n\n        dest.init([\n            1 - (yy + zz),\n            xy + wz,\n            xz - wy,\n            0,\n\n            xy - wz,\n            1 - (xx + zz),\n            yz + wx,\n            0,\n\n            xz + wy,\n            yz - wx,\n            1 - (xx + yy),\n            0,\n\n            0,\n            0,\n            0,\n            1\n        ]);\n\n        return dest;\n    }\n\n    static sum(q1: quat, q2: quat, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        dest.x = q1.x + q2.x;\n        dest.y = q1.y + q2.y;\n        dest.z = q1.z + q2.z;\n        dest.w = q1.w + q2.w;\n\n        return dest;\n    }\n\n    static product(q1: quat, q2: quat, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        const q1x = q1.x,\n            q1y = q1.y,\n            q1z = q1.z,\n            q1w = q1.w,\n\n            q2x = q2.x,\n            q2y = q2.y,\n            q2z = q2.z,\n            q2w = q2.w;\n\n        dest.x = q1x * q2w + q1w * q2x + q1y * q2z - q1z * q2y;\n        dest.y = q1y * q2w + q1w * q2y + q1z * q2x - q1x * q2z;\n        dest.z = q1z * q2w + q1w * q2z + q1x * q2y - q1y * q2x;\n        dest.w = q1w * q2w - q1x * q2x - q1y * q2y - q1z * q2z;\n\n        return dest;\n    }\n\n    static cross(q1: quat, q2: quat, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        const q1x = q1.x,\n            q1y = q1.y,\n            q1z = q1.z,\n            q1w = q1.w,\n\n            q2x = q2.x,\n            q2y = q2.y,\n            q2z = q2.z,\n            q2w = q2.w;\n\n        dest.x = q1w * q2z + q1z * q2w + q1x * q2y - q1y * q2x;\n        dest.y = q1w * q2w - q1x * q2x - q1y * q2y - q1z * q2z;\n        dest.z = q1w * q2x + q1x * q2w + q1y * q2z - q1z * q2y;\n        dest.w = q1w * q2y + q1y * q2w + q1z * q2x - q1x * q2z;\n\n        return dest;\n    }\n\n    static shortMix(q1: quat, q2: quat, time: number, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        if (time <= 0.0) {\n            dest.xyzw = q1.xyzw;\n\n            return dest;\n        } else if (time >= 1.0) {\n            dest.xyzw = q2.xyzw;\n\n            return dest;\n        }\n\n        let cos = quat.dot(q1, q2),\n            q2a = q2.copy();\n\n        if (cos < 0.0) {\n            q2a.inverse();\n            cos = -cos;\n        }\n\n        let k0: number,\n            k1: number;\n\n        if (cos > 0.9999) {\n            k0 = 1 - time;\n            k1 = 0 + time;\n        }\n        else {\n            const sin: number = Math.sqrt(1 - cos * cos);\n            const angle: number = Math.atan2(sin, cos);\n\n            const oneOverSin: number = 1 / sin;\n\n            k0 = Math.sin((1 - time) * angle) * oneOverSin;\n            k1 = Math.sin((0 + time) * angle) * oneOverSin;\n        }\n\n        dest.x = k0 * q1.x + k1 * q2a.x;\n        dest.y = k0 * q1.y + k1 * q2a.y;\n        dest.z = k0 * q1.z + k1 * q2a.z;\n        dest.w = k0 * q1.w + k1 * q2a.w;\n\n        return dest;\n    }\n\n    static mix(q1: quat, q2: quat, time: number, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        const cosHalfTheta = q1.x * q2.x + q1.y * q2.y + q1.z * q2.z + q1.w * q2.w;\n\n        if (Math.abs(cosHalfTheta) >= 1.0) {\n            dest.xyzw = q1.xyzw;\n\n            return dest;\n        }\n\n        const halfTheta = Math.acos(cosHalfTheta),\n            sinHalfTheta = Math.sqrt(1.0 - cosHalfTheta * cosHalfTheta);\n\n        if (Math.abs(sinHalfTheta) < 0.001) {\n            dest.x = q1.x * 0.5 + q2.x * 0.5;\n            dest.y = q1.y * 0.5 + q2.y * 0.5;\n            dest.z = q1.z * 0.5 + q2.z * 0.5;\n            dest.w = q1.w * 0.5 + q2.w * 0.5;\n\n            return dest;\n        }\n\n        const ratioA = Math.sin((1 - time) * halfTheta) / sinHalfTheta,\n            ratioB = Math.sin(time * halfTheta) / sinHalfTheta;\n\n        dest.x = q1.x * ratioA + q2.x * ratioB;\n        dest.y = q1.y * ratioA + q2.y * ratioB;\n        dest.z = q1.z * ratioA + q2.z * ratioB;\n        dest.w = q1.w * ratioA + q2.w * ratioB;\n\n        return dest;\n    }\n\n    static fromAxis(axis: vec3, angle: number, dest: quat = null): quat {\n        if (!dest) dest = new quat();\n\n        angle *= 0.5;\n        const sin = Math.sin(angle);\n\n        dest.x = axis.x * sin;\n        dest.y = axis.y * sin;\n        dest.z = axis.z * sin;\n        dest.w = Math.cos(angle);\n\n        return dest;\n    }\n\n    static identity = new quat().setIdentity();\n\n}\n\n\n\n","import vec2 from './vec2';\nimport vec3 from './vec3';\nimport mat4 from './mat4';\nimport quat from './quat';\n\nimport { epsilon } from './constants';\n\nexport default class mat3 {\n\n    private values = new Float32Array(9);\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.init(values);\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    init(values: number[]): mat3 {\n        for (let i = 0; i < 9; i++) {\n            this.values[i] = values[i];\n        }\n\n        return this;\n    }\n\n    reset(): void {\n        for (let i = 0; i < 9; i++) {\n            this.values[i] = 0;\n        }\n    }\n\n    copy(dest: mat3 = null): mat3 {\n        if (!dest) dest = new mat3();\n\n        for (let i = 0; i < 9; i++) {\n            dest.values[i] = this.values[i];\n        }\n\n        return dest;\n    }\n\n    all(): number[] {\n        const data: number[] = [];\n        for (let i = 0; i < 9; i++) {\n            data[i] = this.values[i];\n        }\n\n        return data;\n    }\n\n    row(index: number): number[] {\n        return [\n            this.values[index * 3 + 0],\n            this.values[index * 3 + 1],\n            this.values[index * 3 + 2]\n        ];\n    }\n\n    col(index: number): number[] {\n        return [\n            this.values[index],\n            this.values[index + 3],\n            this.values[index + 6]\n        ];\n    }\n\n    equals(matrix: mat3, threshold = epsilon): boolean {\n        for (let i = 0; i < 9; i++) {\n            if (Math.abs(this.values[i] - matrix.at(i)) > threshold)\n                return false;\n        }\n\n        return true;\n    }\n\n    determinant(): number {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2],\n            a10 = this.values[3], a11 = this.values[4], a12 = this.values[5],\n            a20 = this.values[6], a21 = this.values[7], a22 = this.values[8];\n\n        const det01 = a22 * a11 - a12 * a21,\n            det11 = -a22 * a10 + a12 * a20,\n            det21 = a21 * a10 - a11 * a20;\n\n        return a00 * det01 + a01 * det11 + a02 * det21;\n    }\n\n    setIdentity(): mat3 {\n        this.values[0] = 1;\n        this.values[1] = 0;\n        this.values[2] = 0;\n        this.values[3] = 0;\n        this.values[4] = 1;\n        this.values[5] = 0;\n        this.values[6] = 0;\n        this.values[7] = 0;\n        this.values[8] = 1;\n\n        return this;\n    }\n\n    transpose(): mat3 {\n        const temp01 = this.values[1],\n            temp02 = this.values[2],\n            temp12 = this.values[5];\n\n        this.values[1] = this.values[3];\n        this.values[2] = this.values[6];\n        this.values[3] = temp01;\n        this.values[5] = this.values[7];\n        this.values[6] = temp02;\n        this.values[7] = temp12;\n\n        return this;\n    }\n\n    inverse(): mat3 {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2],\n            a10 = this.values[3], a11 = this.values[4], a12 = this.values[5],\n            a20 = this.values[6], a21 = this.values[7], a22 = this.values[8];\n\n        const det01 = a22 * a11 - a12 * a21,\n            det11 = -a22 * a10 + a12 * a20,\n            det21 = a21 * a10 - a11 * a20;\n\n        let det = a00 * det01 + a01 * det11 + a02 * det21;\n\n        if (!det)\n            return null;\n\n        det = 1.0 / det;\n\n        this.values[0] = det01 * det;\n        this.values[1] = (-a22 * a01 + a02 * a21) * det;\n        this.values[2] = (a12 * a01 - a02 * a11) * det;\n        this.values[3] = det11 * det;\n        this.values[4] = (a22 * a00 - a02 * a20) * det;\n        this.values[5] = (-a12 * a00 + a02 * a10) * det;\n        this.values[6] = det21 * det;\n        this.values[7] = (-a21 * a00 + a01 * a20) * det;\n        this.values[8] = (a11 * a00 - a01 * a10) * det;\n\n        return this;\n    }\n\n    multiply(matrix: mat3): mat3 {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2],\n            a10 = this.values[3], a11 = this.values[4], a12 = this.values[5],\n            a20 = this.values[6], a21 = this.values[7], a22 = this.values[8];\n\n        const b00 = matrix.at(0), b01 = matrix.at(1), b02 = matrix.at(2),\n            b10 = matrix.at(3), b11 = matrix.at(4), b12 = matrix.at(5),\n            b20 = matrix.at(6), b21 = matrix.at(7), b22 = matrix.at(8);\n\n        this.values[0] = b00 * a00 + b01 * a10 + b02 * a20;\n        this.values[1] = b00 * a01 + b01 * a11 + b02 * a21;\n        this.values[2] = b00 * a02 + b01 * a12 + b02 * a22;\n\n        this.values[3] = b10 * a00 + b11 * a10 + b12 * a20;\n        this.values[4] = b10 * a01 + b11 * a11 + b12 * a21;\n        this.values[5] = b10 * a02 + b11 * a12 + b12 * a22;\n\n        this.values[6] = b20 * a00 + b21 * a10 + b22 * a20;\n        this.values[7] = b20 * a01 + b21 * a11 + b22 * a21;\n        this.values[8] = b20 * a02 + b21 * a12 + b22 * a22;\n\n        return this;\n    }\n\n    multiplyVec2(vector: vec2, result: vec2 = null): vec2 {\n        const x = vector.x,\n            y = vector.y;\n\n        if (result) {\n            result.xy = [\n                x * this.values[0] + y * this.values[3] + this.values[6],\n                x * this.values[1] + y * this.values[4] + this.values[7]\n            ];\n\n            return result;\n        }\n        else {\n            return new vec2([\n                x * this.values[0] + y * this.values[3] + this.values[6],\n                x * this.values[1] + y * this.values[4] + this.values[7]\n            ]);\n        }\n    }\n\n    multiplyVec3(vector: vec3, result: vec3 = null): vec3 {\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        if (result) {\n            result.xyz = [\n                x * this.values[0] + y * this.values[3] + z * this.values[6],\n                x * this.values[1] + y * this.values[4] + z * this.values[7],\n                x * this.values[2] + y * this.values[5] + z * this.values[8]\n            ];\n\n            return result;\n        }\n        else {\n            return new vec3([\n                x * this.values[0] + y * this.values[3] + z * this.values[6],\n                x * this.values[1] + y * this.values[4] + z * this.values[7],\n                x * this.values[2] + y * this.values[5] + z * this.values[8]\n            ]);\n        }\n    }\n\n    toMat4(result: mat4 = null): mat4 {\n        if (result) {\n            result.init([\n                this.values[0],\n                this.values[1],\n                this.values[2],\n                0,\n\n                this.values[3],\n                this.values[4],\n                this.values[5],\n                0,\n\n                this.values[6],\n                this.values[7],\n                this.values[8],\n                0,\n\n                0,\n                0,\n                0,\n                1\n            ]);\n\n            return result;\n        }\n        else {\n            return new mat4([\n                this.values[0],\n                this.values[1],\n                this.values[2],\n                0,\n\n                this.values[3],\n                this.values[4],\n                this.values[5],\n                0,\n\n                this.values[6],\n                this.values[7],\n                this.values[8],\n                0,\n\n                0,\n                0,\n                0,\n                1\n            ]);\n        }\n    }\n\n    toQuat(): quat {\n        const m00 = this.values[0], m01 = this.values[1], m02 = this.values[2],\n            m10 = this.values[3], m11 = this.values[4], m12 = this.values[5],\n            m20 = this.values[6], m21 = this.values[7], m22 = this.values[8];\n\n        let fourXSquaredMinus1 = m00 - m11 - m22;\n        let fourYSquaredMinus1 = m11 - m00 - m22;\n        let fourZSquaredMinus1 = m22 - m00 - m11;\n        let fourWSquaredMinus1 = m00 + m11 + m22;\n\n        let biggestIndex = 0;\n\n        let fourBiggestSquaredMinus1 = fourWSquaredMinus1;\n\n        if (fourXSquaredMinus1 > fourBiggestSquaredMinus1) {\n            fourBiggestSquaredMinus1 = fourXSquaredMinus1;\n            biggestIndex = 1;\n        }\n\n        if (fourYSquaredMinus1 > fourBiggestSquaredMinus1) {\n            fourBiggestSquaredMinus1 = fourYSquaredMinus1;\n            biggestIndex = 2;\n        }\n\n        if (fourZSquaredMinus1 > fourBiggestSquaredMinus1) {\n            fourBiggestSquaredMinus1 = fourZSquaredMinus1;\n            biggestIndex = 3;\n        }\n\n        const biggestVal = Math.sqrt(fourBiggestSquaredMinus1 + 1) * 0.5;\n        const mult = 0.25 / biggestVal;\n\n        const result = new quat();\n\n        switch (biggestIndex) {\n            case 0:\n\n                result.w = biggestVal;\n                result.x = (m12 - m21) * mult;\n                result.y = (m20 - m02) * mult;\n                result.z = (m01 - m10) * mult;\n\n                break;\n\n            case 1:\n\n                result.w = (m12 - m21) * mult;\n                result.x = biggestVal;\n                result.y = (m01 + m10) * mult;\n                result.z = (m20 + m02) * mult;\n\n                break;\n\n            case 2:\n\n                result.w = (m20 - m02) * mult;\n                result.x = (m01 + m10) * mult;\n                result.y = biggestVal;\n                result.z = (m12 + m21) * mult;\n\n                break;\n\n            case 3:\n\n                result.w = (m01 - m10) * mult;\n                result.x = (m20 + m02) * mult;\n                result.y = (m12 + m21) * mult;\n                result.z = biggestVal;\n\n                break;\n        }\n\n        return result;\n    }\n\n    rotate(angle: number, axis: vec3): mat3 {\n        let x = axis.x,\n            y = axis.y,\n            z = axis.z;\n\n        let length = Math.sqrt(x * x + y * y + z * z);\n\n        if (!length)\n            return null;\n\n        if (length !== 1) {\n            length = 1 / length;\n            x *= length;\n            y *= length;\n            z *= length;\n        }\n\n        const s = Math.sin(angle);\n        const c = Math.cos(angle);\n\n        const t = 1.0 - c;\n\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2],\n            a10 = this.values[4], a11 = this.values[5], a12 = this.values[6],\n            a20 = this.values[8], a21 = this.values[9], a22 = this.values[10];\n\n        const b00 = x * x * t + c, b01 = y * x * t + z * s, b02 = z * x * t - y * s,\n            b10 = x * y * t - z * s, b11 = y * y * t + c, b12 = z * y * t + x * s,\n            b20 = x * z * t + y * s, b21 = y * z * t - x * s, b22 = z * z * t + c;\n\n        this.values[0] = a00 * b00 + a10 * b01 + a20 * b02;\n        this.values[1] = a01 * b00 + a11 * b01 + a21 * b02;\n        this.values[2] = a02 * b00 + a12 * b01 + a22 * b02;\n\n        this.values[3] = a00 * b10 + a10 * b11 + a20 * b12;\n        this.values[4] = a01 * b10 + a11 * b11 + a21 * b12;\n        this.values[5] = a02 * b10 + a12 * b11 + a22 * b12;\n\n        this.values[6] = a00 * b20 + a10 * b21 + a20 * b22;\n        this.values[7] = a01 * b20 + a11 * b21 + a21 * b22;\n        this.values[8] = a02 * b20 + a12 * b21 + a22 * b22;\n\n        return this;\n    }\n\n    static product(m1: mat3, m2: mat3, result: mat3 = null): mat3 {\n        const a00 = m1.at(0), a01 = m1.at(1), a02 = m1.at(2),\n            a10 = m1.at(3), a11 = m1.at(4), a12 = m1.at(5),\n            a20 = m1.at(6), a21 = m1.at(7), a22 = m1.at(8);\n\n        const b00 = m2.at(0), b01 = m2.at(1), b02 = m2.at(2),\n            b10 = m2.at(3), b11 = m2.at(4), b12 = m2.at(5),\n            b20 = m2.at(6), b21 = m2.at(7), b22 = m2.at(8);\n\n        if (result) {\n            result.init([\n                b00 * a00 + b01 * a10 + b02 * a20,\n                b00 * a01 + b01 * a11 + b02 * a21,\n                b00 * a02 + b01 * a12 + b02 * a22,\n\n                b10 * a00 + b11 * a10 + b12 * a20,\n                b10 * a01 + b11 * a11 + b12 * a21,\n                b10 * a02 + b11 * a12 + b12 * a22,\n\n                b20 * a00 + b21 * a10 + b22 * a20,\n                b20 * a01 + b21 * a11 + b22 * a21,\n                b20 * a02 + b21 * a12 + b22 * a22\n            ]);\n\n            return result;\n        }\n        else {\n            return new mat3([\n                b00 * a00 + b01 * a10 + b02 * a20,\n                b00 * a01 + b01 * a11 + b02 * a21,\n                b00 * a02 + b01 * a12 + b02 * a22,\n\n                b10 * a00 + b11 * a10 + b12 * a20,\n                b10 * a01 + b11 * a11 + b12 * a21,\n                b10 * a02 + b11 * a12 + b12 * a22,\n\n                b20 * a00 + b21 * a10 + b22 * a20,\n                b20 * a01 + b21 * a11 + b22 * a21,\n                b20 * a02 + b21 * a12 + b22 * a22\n            ]);\n        }\n    }\n\n    static identity = new mat3().setIdentity();\n\n}\n\n\n\n","import vec3 from './vec3';\nimport vec4 from './vec4';\nimport mat3 from './mat3';\n\nimport { epsilon } from './constants';\n\nexport default class mat4 {\n\n    private values = new Float32Array(16);\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.init(values);\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    init(values: number[]): mat4 {\n        for (let i = 0; i < 16; i++) {\n            this.values[i] = values[i];\n        }\n\n        return this;\n    }\n\n    reset(): void {\n        for (let i = 0; i < 16; i++) {\n            this.values[i] = 0;\n        }\n    }\n\n    copy(dest: mat4 = null): mat4 {\n        if (!dest) dest = new mat4();\n\n        for (let i = 0; i < 16; i++) {\n            dest.values[i] = this.values[i];\n        }\n\n        return dest;\n    }\n\n    all(): number[] {\n        const data: number[] = [];\n        for (let i = 0; i < 16; i++) {\n            data[i] = this.values[i];\n        }\n\n        return data;\n    }\n\n    row(index: number): number[] {\n        return [\n            this.values[index * 4 + 0],\n            this.values[index * 4 + 1],\n            this.values[index * 4 + 2],\n            this.values[index * 4 + 3]\n        ];\n    }\n\n    col(index: number): number[] {\n        return [\n            this.values[index],\n            this.values[index + 4],\n            this.values[index + 8],\n            this.values[index + 12]\n        ];\n    }\n\n    equals(matrix: mat4, threshold = epsilon): boolean {\n        for (let i = 0; i < 16; i++) {\n            if (Math.abs(this.values[i] - matrix.at(i)) > threshold)\n                return false;\n        }\n\n        return true;\n    }\n\n    determinant(): number {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2], a03 = this.values[3],\n            a10 = this.values[4], a11 = this.values[5], a12 = this.values[6], a13 = this.values[7],\n            a20 = this.values[8], a21 = this.values[9], a22 = this.values[10], a23 = this.values[11],\n            a30 = this.values[12], a31 = this.values[13], a32 = this.values[14], a33 = this.values[15];\n\n        const det00 = a00 * a11 - a01 * a10,\n            det01 = a00 * a12 - a02 * a10,\n            det02 = a00 * a13 - a03 * a10,\n            det03 = a01 * a12 - a02 * a11,\n            det04 = a01 * a13 - a03 * a11,\n            det05 = a02 * a13 - a03 * a12,\n            det06 = a20 * a31 - a21 * a30,\n            det07 = a20 * a32 - a22 * a30,\n            det08 = a20 * a33 - a23 * a30,\n            det09 = a21 * a32 - a22 * a31,\n            det10 = a21 * a33 - a23 * a31,\n            det11 = a22 * a33 - a23 * a32;\n\n        return (det00 * det11 - det01 * det10 + det02 * det09 + det03 * det08 - det04 * det07 + det05 * det06);\n    }\n\n    setIdentity(): mat4 {\n        this.values[0] = 1;\n        this.values[1] = 0;\n        this.values[2] = 0;\n        this.values[3] = 0;\n        this.values[4] = 0;\n        this.values[5] = 1;\n        this.values[6] = 0;\n        this.values[7] = 0;\n        this.values[8] = 0;\n        this.values[9] = 0;\n        this.values[10] = 1;\n        this.values[11] = 0;\n        this.values[12] = 0;\n        this.values[13] = 0;\n        this.values[14] = 0;\n        this.values[15] = 1;\n\n        return this;\n    }\n\n    transpose(): mat4 {\n        const temp01 = this.values[1], temp02 = this.values[2],\n            temp03 = this.values[3], temp12 = this.values[6],\n            temp13 = this.values[7], temp23 = this.values[11];\n\n        this.values[1] = this.values[4];\n        this.values[2] = this.values[8];\n        this.values[3] = this.values[12];\n        this.values[4] = temp01;\n        this.values[6] = this.values[9];\n        this.values[7] = this.values[13];\n        this.values[8] = temp02;\n        this.values[9] = temp12;\n        this.values[11] = this.values[14];\n        this.values[12] = temp03;\n        this.values[13] = temp13;\n        this.values[14] = temp23;\n\n        return this;\n    }\n\n    inverse(): mat4 {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2], a03 = this.values[3],\n            a10 = this.values[4], a11 = this.values[5], a12 = this.values[6], a13 = this.values[7],\n            a20 = this.values[8], a21 = this.values[9], a22 = this.values[10], a23 = this.values[11],\n            a30 = this.values[12], a31 = this.values[13], a32 = this.values[14], a33 = this.values[15];\n\n        const det00 = a00 * a11 - a01 * a10,\n            det01 = a00 * a12 - a02 * a10,\n            det02 = a00 * a13 - a03 * a10,\n            det03 = a01 * a12 - a02 * a11,\n            det04 = a01 * a13 - a03 * a11,\n            det05 = a02 * a13 - a03 * a12,\n            det06 = a20 * a31 - a21 * a30,\n            det07 = a20 * a32 - a22 * a30,\n            det08 = a20 * a33 - a23 * a30,\n            det09 = a21 * a32 - a22 * a31,\n            det10 = a21 * a33 - a23 * a31,\n            det11 = a22 * a33 - a23 * a32;\n\n        let det = (det00 * det11 - det01 * det10 + det02 * det09 + det03 * det08 - det04 * det07 + det05 * det06);\n\n        if (!det)\n            return null;\n\n        det = 1.0 / det;\n\n        this.values[0] = (a11 * det11 - a12 * det10 + a13 * det09) * det;\n        this.values[1] = (-a01 * det11 + a02 * det10 - a03 * det09) * det;\n        this.values[2] = (a31 * det05 - a32 * det04 + a33 * det03) * det;\n        this.values[3] = (-a21 * det05 + a22 * det04 - a23 * det03) * det;\n        this.values[4] = (-a10 * det11 + a12 * det08 - a13 * det07) * det;\n        this.values[5] = (a00 * det11 - a02 * det08 + a03 * det07) * det;\n        this.values[6] = (-a30 * det05 + a32 * det02 - a33 * det01) * det;\n        this.values[7] = (a20 * det05 - a22 * det02 + a23 * det01) * det;\n        this.values[8] = (a10 * det10 - a11 * det08 + a13 * det06) * det;\n        this.values[9] = (-a00 * det10 + a01 * det08 - a03 * det06) * det;\n        this.values[10] = (a30 * det04 - a31 * det02 + a33 * det00) * det;\n        this.values[11] = (-a20 * det04 + a21 * det02 - a23 * det00) * det;\n        this.values[12] = (-a10 * det09 + a11 * det07 - a12 * det06) * det;\n        this.values[13] = (a00 * det09 - a01 * det07 + a02 * det06) * det;\n        this.values[14] = (-a30 * det03 + a31 * det01 - a32 * det00) * det;\n        this.values[15] = (a20 * det03 - a21 * det01 + a22 * det00) * det;\n\n        return this;\n    }\n\n    multiply(matrix: mat4): mat4 {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2], a03 = this.values[3];\n        const a10 = this.values[4], a11 = this.values[5], a12 = this.values[6], a13 = this.values[7];\n        const a20 = this.values[8], a21 = this.values[9], a22 = this.values[10], a23 = this.values[11];\n        const a30 = this.values[12], a31 = this.values[13], a32 = this.values[14], a33 = this.values[15];\n\n        let b0 = matrix.at(0),\n            b1 = matrix.at(1),\n            b2 = matrix.at(2),\n            b3 = matrix.at(3);\n\n        this.values[0] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n        this.values[1] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n        this.values[2] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n        this.values[3] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n\n        b0 = matrix.at(4);\n        b1 = matrix.at(5);\n        b2 = matrix.at(6);\n        b3 = matrix.at(7);\n\n        this.values[4] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n        this.values[5] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n        this.values[6] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n        this.values[7] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n\n        b0 = matrix.at(8);\n        b1 = matrix.at(9);\n        b2 = matrix.at(10);\n        b3 = matrix.at(11);\n\n        this.values[8] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n        this.values[9] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n        this.values[10] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n        this.values[11] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n\n        b0 = matrix.at(12);\n        b1 = matrix.at(13);\n        b2 = matrix.at(14);\n        b3 = matrix.at(15);\n\n        this.values[12] = b0 * a00 + b1 * a10 + b2 * a20 + b3 * a30;\n        this.values[13] = b0 * a01 + b1 * a11 + b2 * a21 + b3 * a31;\n        this.values[14] = b0 * a02 + b1 * a12 + b2 * a22 + b3 * a32;\n        this.values[15] = b0 * a03 + b1 * a13 + b2 * a23 + b3 * a33;\n\n        return this;\n    }\n\n    multiplyVec3(vector: vec3): vec3 {\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        return new vec3([\n            this.values[0] * x + this.values[4] * y + this.values[8] * z + this.values[12],\n            this.values[1] * x + this.values[5] * y + this.values[9] * z + this.values[13],\n            this.values[2] * x + this.values[6] * y + this.values[10] * z + this.values[14]\n        ]);\n    }\n\n    multiplyVec4(vector: vec4, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z,\n            w = vector.w;\n\n        dest.x = this.values[0] * x + this.values[4] * y + this.values[8] * z + this.values[12] * w;\n        dest.y = this.values[1] * x + this.values[5] * y + this.values[9] * z + this.values[13] * w;\n        dest.z = this.values[2] * x + this.values[6] * y + this.values[10] * z + this.values[14] * w;\n        dest.w = this.values[3] * x + this.values[7] * y + this.values[11] * z + this.values[15] * w;\n\n        return dest;\n    }\n\n    toMat3(): mat3 {\n        return new mat3([\n            this.values[0],\n            this.values[1],\n            this.values[2],\n            this.values[4],\n            this.values[5],\n            this.values[6],\n            this.values[8],\n            this.values[9],\n            this.values[10]\n        ]);\n    }\n\n    toInverseMat3(): mat3 {\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2],\n            a10 = this.values[4], a11 = this.values[5], a12 = this.values[6],\n            a20 = this.values[8], a21 = this.values[9], a22 = this.values[10];\n\n        const det01 = a22 * a11 - a12 * a21,\n            det11 = -a22 * a10 + a12 * a20,\n            det21 = a21 * a10 - a11 * a20;\n\n        let det = a00 * det01 + a01 * det11 + a02 * det21;\n\n        if (!det)\n            return null;\n\n        det = 1.0 / det;\n\n        return new mat3([\n            det01 * det,\n            (-a22 * a01 + a02 * a21) * det,\n            (a12 * a01 - a02 * a11) * det,\n            det11 * det,\n            (a22 * a00 - a02 * a20) * det,\n            (-a12 * a00 + a02 * a10) * det,\n            det21 * det,\n            (-a21 * a00 + a01 * a20) * det,\n            (a11 * a00 - a01 * a10) * det\n        ]);\n    }\n\n    translate(vector: vec3): mat4 {\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        this.values[12] += this.values[0] * x + this.values[4] * y + this.values[8] * z;\n        this.values[13] += this.values[1] * x + this.values[5] * y + this.values[9] * z;\n        this.values[14] += this.values[2] * x + this.values[6] * y + this.values[10] * z;\n        this.values[15] += this.values[3] * x + this.values[7] * y + this.values[11] * z;\n\n        return this;\n    }\n\n    scale(vector: vec3): mat4 {\n        const x = vector.x,\n            y = vector.y,\n            z = vector.z;\n\n        this.values[0] *= x;\n        this.values[1] *= x;\n        this.values[2] *= x;\n        this.values[3] *= x;\n\n        this.values[4] *= y;\n        this.values[5] *= y;\n        this.values[6] *= y;\n        this.values[7] *= y;\n\n        this.values[8] *= z;\n        this.values[9] *= z;\n        this.values[10] *= z;\n        this.values[11] *= z;\n\n        return this;\n    }\n\n    rotate(angle: number, axis: vec3): mat4 {\n        let x = axis.x,\n            y = axis.y,\n            z = axis.z;\n\n        let length = Math.sqrt(x * x + y * y + z * z);\n\n        if (!length)\n            return null;\n\n        if (length !== 1) {\n            length = 1 / length;\n            x *= length;\n            y *= length;\n            z *= length;\n        }\n\n        const s = Math.sin(angle);\n        const c = Math.cos(angle);\n\n        const t = 1.0 - c;\n\n        const a00 = this.values[0], a01 = this.values[1], a02 = this.values[2], a03 = this.values[3],\n            a10 = this.values[4], a11 = this.values[5], a12 = this.values[6], a13 = this.values[7],\n            a20 = this.values[8], a21 = this.values[9], a22 = this.values[10], a23 = this.values[11];\n\n        const b00 = x * x * t + c, b01 = y * x * t + z * s, b02 = z * x * t - y * s,\n            b10 = x * y * t - z * s, b11 = y * y * t + c, b12 = z * y * t + x * s,\n            b20 = x * z * t + y * s, b21 = y * z * t - x * s, b22 = z * z * t + c;\n\n        this.values[0] = a00 * b00 + a10 * b01 + a20 * b02;\n        this.values[1] = a01 * b00 + a11 * b01 + a21 * b02;\n        this.values[2] = a02 * b00 + a12 * b01 + a22 * b02;\n        this.values[3] = a03 * b00 + a13 * b01 + a23 * b02;\n\n        this.values[4] = a00 * b10 + a10 * b11 + a20 * b12;\n        this.values[5] = a01 * b10 + a11 * b11 + a21 * b12;\n        this.values[6] = a02 * b10 + a12 * b11 + a22 * b12;\n        this.values[7] = a03 * b10 + a13 * b11 + a23 * b12;\n\n        this.values[8] = a00 * b20 + a10 * b21 + a20 * b22;\n        this.values[9] = a01 * b20 + a11 * b21 + a21 * b22;\n        this.values[10] = a02 * b20 + a12 * b21 + a22 * b22;\n        this.values[11] = a03 * b20 + a13 * b21 + a23 * b22;\n\n        return this;\n    }\n\n    static frustum(left: number, right: number, bottom: number, top: number, near: number, far: number): mat4 {\n        const rl = (right - left),\n            tb = (top - bottom),\n            fn = (far - near);\n\n        return new mat4([\n            (near * 2) / rl,\n            0,\n            0,\n            0,\n\n            0,\n            (near * 2) / tb,\n            0,\n            0,\n\n            (right + left) / rl,\n            (top + bottom) / tb,\n            -(far + near) / fn,\n            -1,\n\n            0,\n            0,\n            -(far * near * 2) / fn,\n            0\n        ]);\n    }\n\n    static perspective(fov: number, aspect: number, near: number, far: number): mat4 {\n        const top = near * Math.tan(fov * Math.PI / 360.0),\n            right = top * aspect;\n\n        return mat4.frustum(-right, right, -top, top, near, far);\n    }\n\n    static orthographic(left: number, right: number, bottom: number, top: number, near: number, far: number): mat4 {\n        const rl = (right - left),\n            tb = (top - bottom),\n            fn = (far - near);\n\n        return new mat4([\n            2 / rl,\n            0,\n            0,\n            0,\n\n            0,\n            2 / tb,\n            0,\n            0,\n\n            0,\n            0,\n            -2 / fn,\n            0,\n\n            -(left + right) / rl,\n            -(top + bottom) / tb,\n            -(far + near) / fn,\n            1\n        ]);\n    }\n\n    static lookAt(position: vec3, target: vec3, up: vec3 = vec3.up): mat4 {\n        if (position.equals(target)) {\n            return this.identity;\n        }\n\n        const z = vec3.difference(position, target).normalize();\n\n        const x = vec3.cross(up, z).normalize();\n        const y = vec3.cross(z, x).normalize();\n\n        return new mat4([\n            x.x,\n            y.x,\n            z.x,\n            0,\n\n            x.y,\n            y.y,\n            z.y,\n            0,\n\n            x.z,\n            y.z,\n            z.z,\n            0,\n\n            -vec3.dot(x, position),\n            -vec3.dot(y, position),\n            -vec3.dot(z, position),\n            1\n        ]);\n    }\n\n    static product(m1: mat4, m2: mat4, result: mat4 = null): mat4 {\n        const a00 = m1.at(0), a01 = m1.at(1), a02 = m1.at(2), a03 = m1.at(3),\n            a10 = m1.at(4), a11 = m1.at(5), a12 = m1.at(6), a13 = m1.at(7),\n            a20 = m1.at(8), a21 = m1.at(9), a22 = m1.at(10), a23 = m1.at(11),\n            a30 = m1.at(12), a31 = m1.at(13), a32 = m1.at(14), a33 = m1.at(15);\n\n        const b00 = m2.at(0), b01 = m2.at(1), b02 = m2.at(2), b03 = m2.at(3),\n            b10 = m2.at(4), b11 = m2.at(5), b12 = m2.at(6), b13 = m2.at(7),\n            b20 = m2.at(8), b21 = m2.at(9), b22 = m2.at(10), b23 = m2.at(11),\n            b30 = m2.at(12), b31 = m2.at(13), b32 = m2.at(14), b33 = m2.at(15);\n\n        if (result) {\n            result.init([\n                b00 * a00 + b01 * a10 + b02 * a20 + b03 * a30,\n                b00 * a01 + b01 * a11 + b02 * a21 + b03 * a31,\n                b00 * a02 + b01 * a12 + b02 * a22 + b03 * a32,\n                b00 * a03 + b01 * a13 + b02 * a23 + b03 * a33,\n\n                b10 * a00 + b11 * a10 + b12 * a20 + b13 * a30,\n                b10 * a01 + b11 * a11 + b12 * a21 + b13 * a31,\n                b10 * a02 + b11 * a12 + b12 * a22 + b13 * a32,\n                b10 * a03 + b11 * a13 + b12 * a23 + b13 * a33,\n\n                b20 * a00 + b21 * a10 + b22 * a20 + b23 * a30,\n                b20 * a01 + b21 * a11 + b22 * a21 + b23 * a31,\n                b20 * a02 + b21 * a12 + b22 * a22 + b23 * a32,\n                b20 * a03 + b21 * a13 + b22 * a23 + b23 * a33,\n\n                b30 * a00 + b31 * a10 + b32 * a20 + b33 * a30,\n                b30 * a01 + b31 * a11 + b32 * a21 + b33 * a31,\n                b30 * a02 + b31 * a12 + b32 * a22 + b33 * a32,\n                b30 * a03 + b31 * a13 + b32 * a23 + b33 * a33\n            ]);\n\n            return result;\n        }\n        else {\n            return new mat4([\n                b00 * a00 + b01 * a10 + b02 * a20 + b03 * a30,\n                b00 * a01 + b01 * a11 + b02 * a21 + b03 * a31,\n                b00 * a02 + b01 * a12 + b02 * a22 + b03 * a32,\n                b00 * a03 + b01 * a13 + b02 * a23 + b03 * a33,\n\n                b10 * a00 + b11 * a10 + b12 * a20 + b13 * a30,\n                b10 * a01 + b11 * a11 + b12 * a21 + b13 * a31,\n                b10 * a02 + b11 * a12 + b12 * a22 + b13 * a32,\n                b10 * a03 + b11 * a13 + b12 * a23 + b13 * a33,\n\n                b20 * a00 + b21 * a10 + b22 * a20 + b23 * a30,\n                b20 * a01 + b21 * a11 + b22 * a21 + b23 * a31,\n                b20 * a02 + b21 * a12 + b22 * a22 + b23 * a32,\n                b20 * a03 + b21 * a13 + b22 * a23 + b23 * a33,\n\n                b30 * a00 + b31 * a10 + b32 * a20 + b33 * a30,\n                b30 * a01 + b31 * a11 + b32 * a21 + b33 * a31,\n                b30 * a02 + b31 * a12 + b32 * a22 + b33 * a32,\n                b30 * a03 + b31 * a13 + b32 * a23 + b33 * a33\n            ]);\n        }\n    }\n\n    static identity = new mat4().setIdentity();\n\n}\n\n\n\n","import mat4 from './mat4';\n\nimport { epsilon } from './constants';\n\nexport default class vec4 {\n\n    private values = new Float32Array(4);\n\n    get x(): number {\n        return this.values[0];\n    }\n\n    get y(): number {\n        return this.values[1];\n    }\n\n    get z(): number {\n        return this.values[2];\n    }\n\n    get w(): number {\n        return this.values[3];\n    }\n\n    get xy(): number[] {\n        return [\n            this.values[0],\n            this.values[1]\n        ];\n    }\n\n    get xyz(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2]\n        ];\n    }\n\n    get xyzw(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2],\n            this.values[3]\n        ];\n    }\n\n    set x(value: number) {\n        this.values[0] = value;\n    }\n\n    set y(value: number) {\n        this.values[1] = value;\n    }\n\n    set z(value: number) {\n        this.values[2] = value;\n    }\n\n    set w(value: number) {\n        this.values[3] = value;\n    }\n\n    set xy(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n    }\n\n    set xyz(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n    }\n\n    set xyzw(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n        this.values[3] = values[3];\n    }\n\n    get r(): number {\n        return this.values[0];\n    }\n\n    get g(): number {\n        return this.values[1];\n    }\n\n    get b(): number {\n        return this.values[2];\n    }\n\n    get a(): number {\n        return this.values[3];\n    }\n\n    get rg(): number[] {\n        return [\n            this.values[0],\n            this.values[1]\n        ];\n    }\n\n    get rgb(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2]\n        ];\n    }\n\n    get rgba(): number[] {\n        return [\n            this.values[0],\n            this.values[1],\n            this.values[2],\n            this.values[3]\n        ];\n    }\n\n    set r(value: number) {\n        this.values[0] = value;\n    }\n\n    set g(value: number) {\n        this.values[1] = value;\n    }\n\n    set b(value: number) {\n        this.values[2] = value;\n    }\n\n    set a(value: number) {\n        this.values[3] = value;\n    }\n\n    set rg(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n    }\n\n    set rgb(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n    }\n\n    set rgba(values: number[]) {\n        this.values[0] = values[0];\n        this.values[1] = values[1];\n        this.values[2] = values[2];\n        this.values[3] = values[3];\n    }\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.xyzw = values;\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    reset(): void {\n        this.x = 0;\n        this.y = 0;\n        this.z = 0;\n        this.w = 0;\n    }\n\n    copy(dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = this.x;\n        dest.y = this.y;\n        dest.z = this.z;\n        dest.w = this.w;\n\n        return dest;\n    }\n\n    negate(dest: vec4 = null): vec4 {\n        if (!dest) dest = this;\n\n        dest.x = -this.x;\n        dest.y = -this.y;\n        dest.z = -this.z;\n        dest.w = -this.w;\n\n        return dest;\n    }\n\n    equals(vector: vec4, threshold = epsilon): boolean {\n        if (Math.abs(this.x - vector.x) > threshold)\n            return false;\n\n        if (Math.abs(this.y - vector.y) > threshold)\n            return false;\n\n        if (Math.abs(this.z - vector.z) > threshold)\n            return false;\n\n        if (Math.abs(this.w - vector.w) > threshold)\n            return false;\n\n        return true;\n    }\n\n    length(): number {\n        return Math.sqrt(this.squaredLength());\n    }\n\n    squaredLength(): number {\n        const x = this.x,\n            y = this.y,\n            z = this.z,\n            w = this.w;\n\n        return (x * x + y * y + z * z + w * w);\n    }\n\n    add(vector: vec4): vec4 {\n        this.x += vector.x;\n        this.y += vector.y;\n        this.z += vector.z;\n        this.w += vector.w;\n\n        return this;\n    }\n\n    subtract(vector: vec4): vec4 {\n        this.x -= vector.x;\n        this.y -= vector.y;\n        this.z -= vector.z;\n        this.w -= vector.w;\n\n        return this;\n    }\n\n    multiply(vector: vec4): vec4 {\n        this.x *= vector.x;\n        this.y *= vector.y;\n        this.z *= vector.z;\n        this.w *= vector.w;\n\n        return this;\n    }\n\n    divide(vector: vec4): vec4 {\n        this.x /= vector.x;\n        this.y /= vector.y;\n        this.z /= vector.z;\n        this.w /= vector.w;\n\n        return this;\n    }\n\n    scale(value: number, dest: vec4 = null): vec4 {\n        if (!dest) dest = this;\n\n        dest.x *= value;\n        dest.y *= value;\n        dest.z *= value;\n        dest.w *= value;\n\n        return dest;\n    }\n\n    normalize(dest: vec4 = null): vec4 {\n        if (!dest) dest = this;\n\n        let length = this.length();\n\n        if (length === 1) {\n            return this;\n        }\n\n        if (length === 0) {\n            dest.x *= 0;\n            dest.y *= 0;\n            dest.z *= 0;\n            dest.w *= 0;\n\n            return dest;\n        }\n\n        length = 1.0 / length;\n\n        dest.x *= length;\n        dest.y *= length;\n        dest.z *= length;\n        dest.w *= length;\n\n        return dest;\n    }\n\n    multiplyMat4(matrix: mat4, dest: vec4 = null): vec4 {\n        if (!dest) dest = this;\n\n        return matrix.multiplyVec4(this, dest);\n    }\n\n    static mix(vector: vec4, vector2: vec4, time: number, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = vector.x + time * (vector2.x - vector.x);\n        dest.y = vector.y + time * (vector2.y - vector.y);\n        dest.z = vector.z + time * (vector2.z - vector.z);\n        dest.w = vector.w + time * (vector2.w - vector.w);\n\n        return dest;\n    }\n\n    static sum(vector: vec4, vector2: vec4, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = vector.x + vector2.x,\n            dest.y = vector.y + vector2.y,\n            dest.z = vector.z + vector2.z,\n            dest.w = vector.w + vector2.w\n\n        return dest;\n    }\n\n    static difference(vector: vec4, vector2: vec4, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = vector.x - vector2.x,\n            dest.y = vector.y - vector2.y,\n            dest.z = vector.z - vector2.z,\n            dest.w = vector.w - vector2.w\n\n        return dest;\n    }\n\n    static product(vector: vec4, vector2: vec4, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = vector.x * vector2.x,\n            dest.y = vector.y * vector2.y,\n            dest.z = vector.z * vector2.z,\n            dest.w = vector.w * vector2.w\n\n        return dest;\n    }\n\n    static quotient(vector: vec4, vector2: vec4, dest: vec4 = null): vec4 {\n        if (!dest) dest = new vec4();\n\n        dest.x = vector.x / vector2.x,\n            dest.y = vector.y / vector2.y,\n            dest.z = vector.z / vector2.z,\n            dest.w = vector.w / vector2.w\n\n        return dest;\n    }\n\n    static zero = new vec4([0, 0, 0, 1]);\n}\n\n\n\n","/*\n * Copyright (c) 2012, 2018 Matthias Ferch\n *\n * Project homepage: https://github.com/matthiasferch/tsm\n *\n * This software is provided 'as-is', without any express or implied\n * warranty. In no event will the authors be held liable for any damages\n * arising from the use of this software.\n *\n * Permission is granted to anyone to use this software for any purpose,\n * including commercial applications, and to alter it and redistribute it\n * freely, subject to the following restrictions:\n *\n *    1. The origin of this software must not be misrepresented; you must not\n *    claim that you wrote the original software. If you use this software\n *    in a product, an acknowledgment in the product documentation would be\n *    appreciated but is not required.\n *\n *    2. Altered source versions must be plainly marked as such, and must not\n *    be misrepresented as being the original software.\n *\n *    3. This notice may not be removed or altered from any source\n *    distribution.\n */\n\nimport vec2 from \"./vec2\";\nimport vec3 from \"./vec3\";\nimport vec4 from \"./vec4\";\nimport mat2 from \"./mat2\";\nimport mat3 from \"./mat3\";\nimport mat4 from \"./mat4\";\nimport quat from \"./quat\";\n\nexport default {\n    vec2, vec3, vec4, \n    mat2, mat3, mat4, \n    quat\n};\n\n\n","import vec2 from './vec2';\n\nimport { epsilon } from './constants';\n\nexport default class mat2 {\n\n    private values = new Float32Array(4);\n\n    constructor(values: number[] = null) {\n        if (values) {\n            this.init(values);\n        }\n    }\n\n    at(index: number): number {\n        return this.values[index];\n    }\n\n    init(values: number[]): mat2 {\n        for (let i = 0; i < 4; i++) {\n            this.values[i] = values[i];\n        }\n\n        return this;\n    }\n\n    reset(): void {\n        for (let i = 0; i < 4; i++) {\n            this.values[i] = 0;\n        }\n    }\n\n    copy(dest: mat2 = null): mat2 {\n        if (!dest) dest = new mat2();\n\n        for (let i = 0; i < 4; i++) {\n            dest.values[i] = this.values[i];\n        }\n\n        return dest;\n    }\n\n    all(): number[] {\n        const data: number[] = [];\n        for (let i = 0; i < 4; i++) {\n            data[i] = this.values[i];\n        }\n\n        return data;\n    }\n\n    row(index: number): number[] {\n        return [\n            this.values[index * 2 + 0],\n            this.values[index * 2 + 1]\n        ];\n    }\n\n    col(index: number): number[] {\n        return [\n            this.values[index],\n            this.values[index + 2]\n        ];\n    }\n\n    equals(matrix: mat2, threshold = epsilon): boolean {\n        for (let i = 0; i < 4; i++) {\n            if (Math.abs(this.values[i] - matrix.at(i)) > threshold)\n                return false;\n        }\n\n        return true;\n    }\n\n    determinant(): number {\n        return this.values[0] * this.values[3] - this.values[2] * this.values[1];\n    }\n\n    setIdentity(): mat2 {\n        this.values[0] = 1;\n        this.values[1] = 0;\n        this.values[2] = 0;\n        this.values[3] = 1;\n\n        return this;\n    }\n\n    transpose(): mat2 {\n        const temp = this.values[1];\n\n        this.values[1] = this.values[2];\n        this.values[2] = temp;\n\n        return this;\n    }\n\n    inverse(): mat2 {\n        let det = this.determinant();\n\n        if (!det) return null;\n\n        det = 1.0 / det;\n\n        const a11 = this.values[0]\n\n        this.values[0] = det * (this.values[3]);\n        this.values[1] = det * (-this.values[1]);\n        this.values[2] = det * (-this.values[2]);\n        this.values[3] = det * a11;\n\n        return this;\n    }\n\n    multiply(matrix: mat2): mat2 {\n        const a11 = this.values[0],\n            a12 = this.values[1],\n            a21 = this.values[2],\n            a22 = this.values[3];\n\n        this.values[0] = a11 * matrix.at(0) + a12 * matrix.at(2);\n        this.values[1] = a11 * matrix.at(1) + a12 * matrix.at(3);\n        this.values[2] = a21 * matrix.at(0) + a22 * matrix.at(2);\n        this.values[3] = a21 * matrix.at(1) + a22 * matrix.at(3);\n\n        return this;\n    }\n\n    rotate(angle: number): mat2 {\n        const a11 = this.values[0],\n            a12 = this.values[1],\n            a21 = this.values[2],\n            a22 = this.values[3];\n\n        const sin = Math.sin(angle),\n            cos = Math.cos(angle);\n\n        this.values[0] = a11 * cos + a12 * sin;\n        this.values[1] = a11 * -sin + a12 * cos;\n        this.values[2] = a21 * cos + a22 * sin;\n        this.values[3] = a21 * -sin + a22 * cos;\n\n        return this;\n    }\n\n    multiplyVec2(vector: vec2, result: vec2 = null): vec2 {\n        const x = vector.x,\n            y = vector.y;\n\n        if (result) {\n            result.xy = [\n                x * this.values[0] + y * this.values[1],\n                x * this.values[2] + y * this.values[3]\n            ];\n\n            return result;\n        }\n        else {\n            return new vec2([\n                x * this.values[0] + y * this.values[1],\n                x * this.values[2] + y * this.values[3]\n            ]);\n        }\n    }\n\n    scale(vector: vec2): mat2 {\n        const a11 = this.values[0],\n            a12 = this.values[1],\n            a21 = this.values[2],\n            a22 = this.values[3];\n\n        const x = vector.x,\n            y = vector.y;\n\n        this.values[0] = a11 * x;\n        this.values[1] = a12 * y;\n        this.values[2] = a21 * x;\n        this.values[3] = a22 * y;\n\n        return this;\n    }\n\n    static product(m1: mat2, m2: mat2, result: mat2 = null): mat2 {\n        const a11 = m1.at(0),\n            a12 = m1.at(1),\n            a21 = m1.at(2),\n            a22 = m1.at(3);\n\n        if (result) {\n            result.init([\n                a11 * m2.at(0) + a12 * m2.at(2),\n                a11 * m2.at(1) + a12 * m2.at(3),\n                a21 * m2.at(0) + a22 * m2.at(2),\n                a21 * m2.at(1) + a22 * m2.at(3)\n            ]);\n\n            return result;\n        }\n        else {\n            return new mat2([\n                a11 * m2.at(0) + a12 * m2.at(2),\n                a11 * m2.at(1) + a12 * m2.at(3),\n                a21 * m2.at(0) + a22 * m2.at(2),\n                a21 * m2.at(1) + a22 * m2.at(3)\n            ]);\n        }\n    }\n\n    static identity = new mat2().setIdentity();\n\n}\n\n\n\n"],"sourceRoot":""} \ No newline at end of file +"use strict"; +/* + * Copyright (c) 2012, 2018 Matthias Ferch + * + * Project homepage: https://github.com/matthiasferch/tsm + * + * This software is provided 'as-is', without any express or implied + * warranty. In no event will the authors be held liable for any damages + * arising from the use of this software. + * + * Permission is granted to anyone to use this software for any purpose, + * including commercial applications, and to alter it and redistribute it + * freely, subject to the following restrictions: + * + * 1. The origin of this software must not be misrepresented; you must not + * claim that you wrote the original software. If you use this software + * in a product, an acknowledgment in the product documentation would be + * appreciated but is not required. + * + * 2. Altered source versions must be plainly marked as such, and must not + * be misrepresented as being the original software. + * + * 3. This notice may not be removed or altered from any source + * distribution. + */ +Object.defineProperty(exports, "__esModule", { value: true }); +var mat2_1 = require("./mat2"); +var mat3_1 = require("./mat3"); +var mat4_1 = require("./mat4"); +var quat_1 = require("./quat"); +var vec2_1 = require("./vec2"); +var vec3_1 = require("./vec3"); +var vec4_1 = require("./vec4"); +exports.default = { + vec2: vec2_1.default, vec3: vec3_1.default, vec4: vec4_1.default, + mat2: mat2_1.default, mat3: mat3_1.default, mat4: mat4_1.default, + quat: quat_1.default, +}; +//# sourceMappingURL=tsm.js.map \ No newline at end of file diff --git a/package.json b/package.json index fccd09c..990088e 100644 --- a/package.json +++ b/package.json @@ -1,26 +1,23 @@ { - "name": "tsm", + "name": "@tlaukkan/tsm", "version": "0.8.0", - "description": "A TypeScript vector and matrix math library", + "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", - "module": "src/tsm.js", + "main": "src/tsm.js", + "types": "src/tsm.d.ts", "scripts": { "test": "mocha -r ts-node/register test/**/*.spec.ts", "lint": "tslint src/*.ts -t verbose", - "build": "webpack", - "watch": "webpack --watch" + "build": "tsc" }, "devDependencies": { "@types/chai": "^4.1.4", "@types/mocha": "^5.2.5", "chai": "^4.1.2", "mocha": "^5.2.0", - "ts-loader": "^5.1.0", "ts-node": "^7.0.1", "tslint": "^5.11.0", - "typescript": "^3.0.3", - "webpack": "^4.18.0", - "webpack-cli": "^3.1.0" + "typescript": "^3.0.3" }, "dependencies": {} } diff --git a/webpack.config.js b/webpack.config.js deleted file mode 100644 index 22e1f97..0000000 --- a/webpack.config.js +++ /dev/null @@ -1,23 +0,0 @@ -const path = require('path'); - -module.exports = { - entry: './src/tsm.ts', - devtool: 'inline-source-map', - module: { - rules: [ - { - test: /\.ts$/, - use: 'ts-loader', - exclude: /node_modules/ - } - ] - }, - resolve: { - extensions: ['.ts'] - }, - output: { - library: 'tsm', - filename: 'tsm.js', - path: path.resolve(__dirname, 'dist') - } -}; \ No newline at end of file From 451b9b7c426be2aa6111667a9be645aed92cd830 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:19:31 +0300 Subject: [PATCH 02/10] 0.8.1 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 990088e..7fa75cb 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@tlaukkan/tsm", - "version": "0.8.0", + "version": "0.8.1", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", "main": "src/tsm.js", From 26ec29a60371ac114b0b3a6e9a7a62c751d3ed79 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:22:53 +0300 Subject: [PATCH 03/10] Adding typescript definitions. --- dist/tsm.js | 39 --------------------------------------- tsconfig.json | 3 ++- 2 files changed, 2 insertions(+), 40 deletions(-) delete mode 100644 dist/tsm.js diff --git a/dist/tsm.js b/dist/tsm.js deleted file mode 100644 index e3258dc..0000000 --- a/dist/tsm.js +++ /dev/null @@ -1,39 +0,0 @@ -"use strict"; -/* - * Copyright (c) 2012, 2018 Matthias Ferch - * - * Project homepage: https://github.com/matthiasferch/tsm - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event will the authors be held liable for any damages - * arising from the use of this software. - * - * Permission is granted to anyone to use this software for any purpose, - * including commercial applications, and to alter it and redistribute it - * freely, subject to the following restrictions: - * - * 1. The origin of this software must not be misrepresented; you must not - * claim that you wrote the original software. If you use this software - * in a product, an acknowledgment in the product documentation would be - * appreciated but is not required. - * - * 2. Altered source versions must be plainly marked as such, and must not - * be misrepresented as being the original software. - * - * 3. This notice may not be removed or altered from any source - * distribution. - */ -Object.defineProperty(exports, "__esModule", { value: true }); -var mat2_1 = require("./mat2"); -var mat3_1 = require("./mat3"); -var mat4_1 = require("./mat4"); -var quat_1 = require("./quat"); -var vec2_1 = require("./vec2"); -var vec3_1 = require("./vec3"); -var vec4_1 = require("./vec4"); -exports.default = { - vec2: vec2_1.default, vec3: vec3_1.default, vec4: vec4_1.default, - mat2: mat2_1.default, mat3: mat3_1.default, mat4: mat4_1.default, - quat: quat_1.default, -}; -//# sourceMappingURL=tsm.js.map \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index 052fe96..6a8bd4a 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -6,9 +6,10 @@ "./test/**/*.spec.ts" ], "compilerOptions": { + "declaration": true, "outDir": "./dist/", "module": "commonjs", "target": "es5", - "sourceMap": true, + "sourceMap": true } } \ No newline at end of file From 2be9f38f7a2d44dd1883208de2f96549d9f22cce Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:23:24 +0300 Subject: [PATCH 04/10] Adding typescript definitions. --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 8073570..e4d484a 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,7 @@ tsm: A Typescript vector and matrix math library ================================================= -This is node packaged version of the library. +This is new packaging of the library for node + TypeScript. tsm is a a collection of vector, matrix and quaternion classes written in Typescript. From 53c101ebe23dafd2609a1dbc351ce42c2bebdfe0 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:23:37 +0300 Subject: [PATCH 05/10] 0.8.2 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 7fa75cb..b0eeef6 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@tlaukkan/tsm", - "version": "0.8.1", + "version": "0.8.2", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", "main": "src/tsm.js", From bb9c8fbc217bef6c339ead93f34b27df5a19a460 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:25:41 +0300 Subject: [PATCH 06/10] Adding typescript definitions. --- package.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index b0eeef6..9a2bb68 100644 --- a/package.json +++ b/package.json @@ -8,7 +8,8 @@ "scripts": { "test": "mocha -r ts-node/register test/**/*.spec.ts", "lint": "tslint src/*.ts -t verbose", - "build": "tsc" + "build": "tsc", + "prepublishOnly": "npm run build" }, "devDependencies": { "@types/chai": "^4.1.4", From 06983cd78ca3fca7036e5bf538da80c0986550b8 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:25:45 +0300 Subject: [PATCH 07/10] 0.8.3 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 9a2bb68..0804a54 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@tlaukkan/tsm", - "version": "0.8.2", + "version": "0.8.3", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", "main": "src/tsm.js", From db83fd2f282920c63a67453004c397224bb70d1b Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:32:43 +0300 Subject: [PATCH 08/10] Adding typescript definitions. --- package.json | 4 ++-- src/index.ts | 7 +++++++ 2 files changed, 9 insertions(+), 2 deletions(-) create mode 100644 src/index.ts diff --git a/package.json b/package.json index 0804a54..877f79e 100644 --- a/package.json +++ b/package.json @@ -3,8 +3,8 @@ "version": "0.8.3", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", - "main": "src/tsm.js", - "types": "src/tsm.d.ts", + "main": "src/index.js", + "types": "src/index.d.ts", "scripts": { "test": "mocha -r ts-node/register test/**/*.spec.ts", "lint": "tslint src/*.ts -t verbose", diff --git a/src/index.ts b/src/index.ts new file mode 100644 index 0000000..b2b68ba --- /dev/null +++ b/src/index.ts @@ -0,0 +1,7 @@ +export { default as mat2 } from './mat2' +export { default as mat3 } from './mat3' +export { default as mat4 } from './mat4' +export { default as quat } from './quat' +export { default as vec2 } from './vec2' +export { default as vec3 } from './vec3' +export { default as vec4 } from './vec4' From c9ea9e51da15f59c452fa2aceed53a4d4921f761 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:32:58 +0300 Subject: [PATCH 09/10] 0.8.4 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 877f79e..74fc5cc 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@tlaukkan/tsm", - "version": "0.8.3", + "version": "0.8.4", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", "main": "src/index.js", From 11a38a00183008a3ecf3bae95f28d6fe35ba1031 Mon Sep 17 00:00:00 2001 From: "Tommi S.E. Laukkanen" Date: Sun, 7 Oct 2018 21:35:23 +0300 Subject: [PATCH 10/10] Adding typescript definitions. --- package.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index 74fc5cc..1966671 100644 --- a/package.json +++ b/package.json @@ -3,8 +3,8 @@ "version": "0.8.4", "description": "A node version of the TypeScript vector and matrix math library.", "author": "Matthias Ferch", - "main": "src/index.js", - "types": "src/index.d.ts", + "main": "dist/index.js", + "types": "dist/index.d.ts", "scripts": { "test": "mocha -r ts-node/register test/**/*.spec.ts", "lint": "tslint src/*.ts -t verbose",