diff --git a/dist/index.d.ts b/dist/index.d.ts index 99d1c7d..82c976e 100644 --- a/dist/index.d.ts +++ b/dist/index.d.ts @@ -372,4 +372,11 @@ declare module 'mz-math' { export const naturalNumbersSum1ToN: (n: number) => number; export const naturalNumbersSumMToN: (m: number, n: number) => number; + + export const factorialIterative: (n: number, start?: number) => number; + export const factorialRecursive: (n: number, start?: number) => number; + export const factorialMemoized: (n: number, start?: number) => number; + export const factorial: (n: number, start?: number) => number; + + export const permutationsWithRepetition: (n: number, r: number) => number; } \ No newline at end of file diff --git a/dist/mz-math.esm.js b/dist/mz-math.esm.js index 44fc778..7f874fc 100644 --- a/dist/mz-math.esm.js +++ b/dist/mz-math.esm.js @@ -5,10 +5,10 @@ https://github.com/mzusin/mz-math Licensed GPLv3 for open source use, or Commercial License for commercial use - https://github.com/mzusin/index/blob/main/LICENSE.md Copyright (c) 2023-present, Miriam Zusin */ -var b=Math.pow;var s=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=b(10,r);return Math.round(t*e)/e};var y=(t,r)=>(t%r+r)%r,j=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,br=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),T=t=>!isNaN(parseFloat(t))&&isFinite(t),hr=(t,r,e,n=1/0)=>{let[o,i]=t,[c,u]=r;return[s(o+c*Math.cos(e),n),s(i+u*Math.sin(e),n)]};var L=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return s(e,r)},dr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return s(n,e)},K=(t,r,e=1/0)=>{let n=P(t);return[s(Math.cos(r)*n,e),s(Math.sin(r)*n,e)]},vr=(t,r=1/0)=>{let e=t*(180/Math.PI);return s(e,r)},gr=(t,r=1/0)=>{let e=t*(Math.PI/180);return s(e,r)},qt=(t,r,e=1/0)=>{let n=B(t),o=B(r),i=S(n,o),c=Math.acos(i);return s(c,e)},Sr=(t,r,e=1/0)=>{let n=d(t,r),o=Math.atan2(n[1],n[0]);return s(o,e)},Rr=(t,r,e=1/0)=>qt(t,r,e),wr=(t,r,e)=>{let n=k(r,e),o=k(r,t),i=k(e,t),c=o+i;return Math.abs(c-n)<=.001},J=(t,r,e=0)=>(t=t%360,r=r%360,t=t),k=(t,r,e=1/0)=>{let n=Math.abs(y(t,360)-y(r,360));return s(n<=180?n:360-n,e)},At=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=At(r,e,n);return J(r,e,n)?y(n+t*o/100,360):y(n-t*o/100,360)};var N=(t,r,e=1/0)=>{let n=[];for(let o=0;oN(t,r,e),$r=(t,r,e=1/0)=>N(t,r,e),d=(t,r,e=1/0)=>{let n=[];for(let o=0;od(t,r,e),Er=(t,r,e=1/0)=>d(t,r,e),C=(t,r,e=1/0)=>{let n=[];for(let o=0;oC(t,r,e),F=(t,r,e=1/0)=>C(t,r,e),D=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oD(t,r,e),Nr=(t,r,e=1/0)=>D(t,r,e),z=(t,r=1/0)=>{let e=0;for(let n=0;nz(t,r),Cr=(t,r=1/0)=>z(t,r),Nt=(t,r,e=1/0)=>{let n=L(t);return[s(Math.cos(n)*r,e),s(Math.sin(n)*r,e)]},Dr=(t,r,e=1/0)=>{let n=d(t,r);return z(n,e)},Xr=(t,r,e=1/0)=>{let n=d(t,r);return z(n,e)},Yr=(t,r,e=1/0)=>{let n=d(t,r);return z(n,e)},B=(t,r=1/0)=>{let e=z(t),n=[];for(let o=0;oB(t,r),g=(t,r=1/0)=>B(t,r),S=(t,r,e=1/0)=>{let n=0;for(let o=0;oS(t,r,e),Gr=(t,r,e=1/0)=>S(t,r,e),Or=(t,r,e=1/0)=>[s(t[1]*r[2]-t[2]*r[1],e),s(t[2]*r[0]-t[0]*r[2],e),s(t[0]*r[1]-t[1]*r[0],e)],jr=(t=0)=>[t,t],kr=(t=0)=>[t,t,t],Fr=(t=0)=>[t,t,t,t],rt=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=Nt(e,t),K(e,r)},et=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=w(r,t);return[-s(n[1],e),s(n[0],e)]};var ot=(t,r,e=1/0)=>{let n=[];for(let o=0;oot(t,r,e),Ur=(t,r,e=1/0)=>ot(t,r,e),it=(t,r,e=1/0)=>{let n=[];for(let o=0;oit(t,r,e),Jr=(t,r,e=1/0)=>it(t,r,e),ct=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(C(o,r,e));return n},Pr=(t,r,e=1/0)=>ct(t,r,e),te=(t,r,e=1/0)=>ct(t,r,e),Q=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(D(o,r,e));return n},Ct=(t,r,e=1/0)=>Q(t,r,e),re=(t,r,e=1/0)=>Q(t,r,e),X=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oX(t),ne=t=>X(t),st=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nst(t,r),ie=(t,r=0)=>st(t,r),ce=(t=0)=>[[t,t],[t,t]],se=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],ue=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],xe=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],ae=()=>[[1,0,0],[0,1,0],[0,0,1]],fe=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],pe=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;eI(t),xt=t=>I(t),Me=(t,r)=>{if(t.length<=0)return[];let e=I(t);for(let n=0;n{if(t.length<=0)return[];let e=I(t);for(let n=0;n{let e=I(t);return e.push(r),e},Ve=(t,r)=>{let e=ut(t);return e.push(r),e},le=(t,r)=>{let e=xt(t);return e.push(r),e},ye=(t,r)=>{let e=I(t);return e.unshift(r),e},Ie=(t,r)=>{let e=ut(t);return e.unshift(r),e},de=(t,r)=>{let e=xt(t);return e.unshift(r),e},ve=t=>{if(t.length<=0)return[];let r=I(t);return r.pop(),r},ge=t=>{if(t.length<=0)return[];let r=I(t);return r.shift(),r},mt=t=>{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=Dt(t,r,e);return Y(o)},Y=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return pt(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},He=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return Y(t)},Mt=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},Te=t=>bt(t),bt=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return Mt(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return Y(t)===0},ht=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=pt(t);if(e===0)return null;let n=Mt(t);return n===null?null:Ct(n,e,r)},Vt=(t,r=1/0)=>Z(t,r),Z=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=Y(t),o=bt(t);return o===null?null:Q(o,n,r)};var Ae=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},Ne=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${c})`},Ce=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${c}, 0, 1)`},De=t=>`matrix3d( +var h=Math.pow;var s=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=h(10,r);return Math.round(t*e)/e};var y=(t,r)=>(t%r+r)%r,j=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,Mr=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),H=t=>!isNaN(parseFloat(t))&&isFinite(t),Vr=(t,r,e,n=1/0)=>{let[o,i]=t,[c,u]=r;return[s(o+c*Math.cos(e),n),s(i+u*Math.sin(e),n)]};var E=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return s(e,r)},gr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return s(n,e)},K=(t,r,e=1/0)=>{let n=P(t);return[s(Math.cos(r)*n,e),s(Math.sin(r)*n,e)]},vr=(t,r=1/0)=>{let e=t*(180/Math.PI);return s(e,r)},Sr=(t,r=1/0)=>{let e=t*(Math.PI/180);return s(e,r)},$t=(t,r,e=1/0)=>{let n=T(t),o=T(r),i=S(n,o),c=Math.acos(i);return s(c,e)},wr=(t,r,e=1/0)=>{let n=I(t,r),o=Math.atan2(n[1],n[0]);return s(o,e)},Rr=(t,r,e=1/0)=>$t(t,r,e),zr=(t,r,e)=>{let n=F(r,e),o=F(r,t),i=F(e,t),c=o+i;return Math.abs(c-n)<=.001},J=(t,r,e=0)=>(t=t%360,r=r%360,t=t),F=(t,r,e=1/0)=>{let n=Math.abs(y(t,360)-y(r,360));return s(n<=180?n:360-n,e)},qt=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=qt(r,e,n);return J(r,e,n)?y(n+t*o/100,360):y(n-t*o/100,360)};var A=(t,r,e=1/0)=>{let n=[];for(let o=0;oA(t,r,e),Nr=(t,r,e=1/0)=>A(t,r,e),I=(t,r,e=1/0)=>{let n=[];for(let o=0;oI(t,r,e),$r=(t,r,e=1/0)=>I(t,r,e),C=(t,r,e=1/0)=>{let n=[];for(let o=0;oC(t,r,e),k=(t,r,e=1/0)=>C(t,r,e),D=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oD(t,r,e),Cr=(t,r,e=1/0)=>D(t,r,e),z=(t,r=1/0)=>{let e=0;for(let n=0;nz(t,r),Dr=(t,r=1/0)=>z(t,r),At=(t,r,e=1/0)=>{let n=E(t);return[s(Math.cos(n)*r,e),s(Math.sin(n)*r,e)]},Xr=(t,r,e=1/0)=>{let n=I(t,r);return z(n,e)},Yr=(t,r,e=1/0)=>{let n=I(t,r);return z(n,e)},Gr=(t,r,e=1/0)=>{let n=I(t,r);return z(n,e)},T=(t,r=1/0)=>{let e=z(t),n=[];for(let o=0;oT(t,r),v=(t,r=1/0)=>T(t,r),S=(t,r,e=1/0)=>{let n=0;for(let o=0;oS(t,r,e),Or=(t,r,e=1/0)=>S(t,r,e),jr=(t,r,e=1/0)=>[s(t[1]*r[2]-t[2]*r[1],e),s(t[2]*r[0]-t[0]*r[2],e),s(t[0]*r[1]-t[1]*r[0],e)],Fr=(t=0)=>[t,t],kr=(t=0)=>[t,t,t],Qr=(t=0)=>[t,t,t,t],rt=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=At(e,t),K(e,r)},et=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=R(r,t);return[-s(n[1],e),s(n[0],e)]};var ot=(t,r,e=1/0)=>{let n=[];for(let o=0;oot(t,r,e),Kr=(t,r,e=1/0)=>ot(t,r,e),it=(t,r,e=1/0)=>{let n=[];for(let o=0;oit(t,r,e),Pr=(t,r,e=1/0)=>it(t,r,e),ct=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(C(o,r,e));return n},te=(t,r,e=1/0)=>ct(t,r,e),re=(t,r,e=1/0)=>ct(t,r,e),Q=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(D(o,r,e));return n},Ct=(t,r,e=1/0)=>Q(t,r,e),ee=(t,r,e=1/0)=>Q(t,r,e),X=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oX(t),oe=t=>X(t),st=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nst(t,r),ce=(t,r=0)=>st(t,r),se=(t=0)=>[[t,t],[t,t]],ue=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],xe=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],me=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],fe=()=>[[1,0,0],[0,1,0],[0,0,1]],pe=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],be=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;ed(t),xt=t=>d(t),he=(t,r)=>{if(t.length<=0)return[];let e=d(t);for(let n=0;n{if(t.length<=0)return[];let e=d(t);for(let n=0;n{let e=d(t);return e.push(r),e},le=(t,r)=>{let e=ut(t);return e.push(r),e},ye=(t,r)=>{let e=xt(t);return e.push(r),e},de=(t,r)=>{let e=d(t);return e.unshift(r),e},Ie=(t,r)=>{let e=ut(t);return e.unshift(r),e},ge=(t,r)=>{let e=xt(t);return e.unshift(r),e},ve=t=>{if(t.length<=0)return[];let r=d(t);return r.pop(),r},Se=t=>{if(t.length<=0)return[];let r=d(t);return r.shift(),r},mt=t=>{if(t.length<=0)return[];let r=d(t);for(let e=0;e{if(t.length<=0)return[];let r=d(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=Dt(t,r,e);return Y(o)},Y=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return pt(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},He=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return Y(t)},bt=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},Te=t=>ht(t),ht=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return bt(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return Y(t)===0},Mt=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=pt(t);if(e===0)return null;let n=bt(t);return n===null?null:Ct(n,e,r)},Vt=(t,r=1/0)=>Z(t,r),Z=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=Y(t),o=ht(t);return o===null?null:Q(o,n,r)};var Ae=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},Ce=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${c})`},De=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${c}, 0, 1)`},Xe=t=>`matrix3d( ${t[0][0]}, ${t[0][1]}, ${t[0][2]}, ${t[0][3]}, ${t[1][0]}, ${t[1][1]}, ${t[1][2]}, ${t[1][3]}, ${t[2][0]}, ${t[2][1]}, ${t[2][2]}, ${t[2][3]}, ${t[3][0]}, ${t[3][1]}, ${t[3][2]}, ${t[3][3]} - )`,Xe=(t,r=1/0)=>[[1,0],[0,1],[s(t[0],r),s(t[1],r)]],Ye=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[s(t[0],r),s(t[1],r),s(t[2],r)]],G=(t,r=1/0)=>[[1,0,s(t[0],r)],[0,1,s(t[1],r)],[0,0,1]],Ge=(t,r=1/0)=>[[1,0,0,s(t[0],r)],[0,1,0,s(t[1],r)],[0,0,1,s(t[2],r)],[0,0,0,1]],Xt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},lt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},Yt=(t,r,e=!0,n=1/0)=>{let o=G(r,n),i=lt(t,e,n),c=G(F(r,-1),n),u=E(o,i);return E(u,c)},Oe=(t,r,e,n=!0,o=1/0)=>{let i=Yt(t,r,n,o);return h(i,e)},je=(t,r,e=!0,n=1/0)=>{let o=$(r);return h(Xt(t,e,n),o)},ke=(t,r,e=!0,n=1/0)=>{let o=g(r);return h(lt(t,e,n),o)},Gt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},Fe=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},Qe=(t,r,e=!0,n=1/0)=>{let o=g(r);return h(Gt(t,e,n),o)},Ot=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},Ze=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},_e=(t,r,e=!0,n=1/0)=>{let o=g(r);return h(Ot(t,e,n),o)},jt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},We=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},Ue=(t,r,e=!0,n=1/0)=>{let o=g(r);return h(jt(t,e,n),o)},kt=(t,r,e=1/0)=>{let n=G(r,e),o=Qt(t),i=G(F(r,-1),e),c=E(n,o);return E(c,i)},Ke=(t,r,e,n=1/0)=>{let o=kt(t,r,n);return h(o,e)},Ft=t=>[[t[0],0],[0,t[1]]],Je=(t,r)=>h(Ft(t),r),Qt=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],Zt=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],Pe=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],tn=(t,r)=>h(Zt(t),r),rn=t=>[[t,0],[0,1]],en=t=>[[t,0,0],[0,1,0],[0,0,1]],nn=t=>[[t,0,0],[0,1,0],[0,0,1]],on=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],cn=t=>[[1,0,0],[0,t,0],[0,0,1]],sn=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],un=t=>[[1,0,0],[0,1,0],[0,0,t]],xn=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],mn=t=>[[1,0],[0,t]],an=t=>[[1,0,0],[0,t,0],[0,0,1]],fn=()=>[[-1,0],[0,-1]],pn=()=>[[-1,0,0],[0,-1,0],[0,0,1]],Mn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],bn=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],hn=()=>[[0,-1],[-1,0]],Vn=()=>[[1,0],[0,-1]],ln=()=>[[1,0,0],[0,-1,0],[0,0,1]],yn=()=>[[-1,0],[0,1]],In=()=>[[-1,0,0],[0,1,0],[0,0,1]],dn=()=>[[-1,0,0],[0,1,0],[0,0,1]],vn=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],gn=()=>[[1,0,0],[0,-1,0],[0,0,1]],Sn=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],Rn=()=>[[1,0,0],[0,1,0],[0,0,-1]],wn=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],zn=t=>[[1,t],[0,1]],Hn=t=>[[1,0],[t,1]];var V=(t,r,e=1/0)=>s(Math.random()*(r-t)+t,e),_t=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),Ln=()=>Math.random()<.5,$n=t=>{let r=_t(0,t.length-1);return t[r]};var qn=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var Cn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],c=o[1];n+=i*c*Math.pow(t,c-1)}return s(n,e)},yt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},It=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},dt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},vt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},Dn=(t,r=1/0)=>s(Math.cos(t),r),Xn=(t,r=1/0)=>s(-Math.sin(t),r),Yn=(t,r=1/0)=>s(1/b(Math.cos(t),2),r),Gn=(t,r=1/0)=>s(-1/b(Math.sin(t),2),r),On=(t,r=1/0)=>s(1/Math.sqrt(1-b(t,2)),r),jn=(t,r=1/0)=>s(-1/Math.sqrt(1-b(t,2)),r),kn=(t,r=1/0)=>s(1/(1+b(t,2)),r),Fn=(t,r=1/0)=>s(-1/(1+b(t,2)),r);var q=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:s(i/e,r)},Kn=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=ht(n);if(o===null)return null;let i=[t[2],r[2]];return h(o,i,e)},Jn=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=Vt(o);if(i===null)return null;let c=[t[3],r[3],e[3]];return h(i,c,n)},Pn=(t,r=1/0)=>{if(t.length<=0)return null;let e=mt(t),n=Z(e);if(n===null)return null;let o=at(t);return h(n,o,r)},to=(t,r)=>{let[e,n]=w(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let c=n/e,u=i-c*o,x="";return c===0?x=`y = ${u}`:(x=`y = ${c===1?"":c}x`,u!==0&&(x+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:c,xIntercept:void 0,yIntercept:u,formula:x}};var _=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=q([n,o,i],r);return T(f)?[f]:[]}let c=o-i,u=n*n-4*e*c;if(u<0)return[];if(u===0)return[s(-n/(2*e),r)];let x=2*e,m=Math.sqrt(u);return[s((-n+m)/x,r),s((-n-m)/x,r)]};var Wt=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},fo=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},Ut=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},po=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},Kt=(t,r,e,n,o=1/0)=>{let i=yt(t,r,e,n);return $(i,o)},Mo=(t,r,e,n,o=1/0)=>{let i=It(t,r,e,n);return g(i,o)},Jt=(t,r,e,n,o,i=1/0)=>{let c=dt(t,r,e,n,o);return $(c,i)},bo=(t,r,e,n,o,i=1/0)=>{let c=vt(t,r,e,n,o);return g(c,i)},ho=(t,r,e,n,o=1/0)=>{let i=Kt(t,r,e,n,o);return[-i[1],i[0]]},Vo=(t,r,e,n,o,i=1/0)=>{let c=Jt(t,r,e,n,o,i);return[-c[1],c[0]]},Pt=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=q([o,i,0],n),x=2*t[1]-4*r[1]+2*e[1],m=-2*t[1]+2*r[1],p=q([x,m,0],n),a=[];return T(u)&&a.push(u),T(p)&&a.push(p),a},tr=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],c=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],x=[i,c,u,0],m=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],a=[m,f,p,0],M=_(x,o).filter(l=>l>=0&&l<=1),v=_(a,o).filter(l=>l>=0&&l<=1);return[...M,...v].length===2?[...M,...v]:null},lo=(t,r,e,n=1/0)=>{let o=Pt(t,r,e),i=1/0,c=1/0,u=-1/0,x=-1/0;for(let m of o){let f=Wt(m,t,r,e),p=f[0],a=f[1];i=Math.min(i,p),u=Math.max(u,p),c=Math.min(c,a),x=Math.max(x,a)}return i=s(Math.min(i,t[0],e[0]),n),u=s(Math.max(u,t[0],e[0]),n),c=s(Math.min(c,t[1],e[1]),n),x=s(Math.max(x,t[1],e[1]),n),{x:i,y:c,w:Math.abs(u-i),h:Math.abs(x-c),x2:u,y2:x}},yo=(t,r,e,n,o=1/0)=>{let i=tr(t,r,e,n)||[],c=1/0,u=1/0,x=-1/0,m=-1/0;for(let f of i){let p=Ut(f,t,r,e,n),a=p[0],M=p[1];c=Math.min(c,a!=null?a:1/0),x=Math.max(x,a!=null?a:-1/0),u=Math.min(u,M!=null?M:1/0),m=Math.max(m,M!=null?M:-1/0)}return c=s(Math.min(c,t[0],n[0]),o),x=s(Math.max(x,t[0],n[0]),o),u=s(Math.min(u,t[1],n[1]),o),m=s(Math.max(m,t[1],n[1]),o),{x:c,y:u,w:Math.abs(x-c),h:Math.abs(m-u),x2:x,y2:m}};var rr=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),Ro=(t,r,e)=>{let n=w(t,r),o=L(n);return o=j(o,0,Math.PI*2,0,Math.PI),rr(r,o,e)},er=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),wo=(t,r,e)=>{let n=w(t,r),o=L(n);return o=j(o,0,Math.PI*2,0,Math.PI),er(r,o,e[0],e[1])},zo=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},Ho=(t,r,e,n,o,i,c)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-c)];var Eo=()=>{let t=St();return cr(t)},qo=()=>{let t=St();return sr(t)},St=()=>{let t=V(1,360),r=V(0,100),e=V(0,100);return[t,r,e]},Ao=t=>{let r=V(0,100),e=V(0,100);return[t,r,e]},No=t=>{let r=V(1,360),e=V(0,100);return[r,t,e]},Co=t=>{let r=V(1,360),e=V(0,100);return[r,e,t]},Do=()=>[0,0,V(0,100)],Xo=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let c=V(t,r),u=V(e,n),x=V(o,i);return[c,u,x]},nr=t=>(t*=60,t<0&&(t+=360),t),or=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,c=0;return o===t&&(c=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),ir=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?Rt(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),Yo=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),c=Math.max(e,n,o),u=Rt(e,n,o,i,c),x=ir(e,n,o,i,c,u),m=or(e,n,o,i,c);return m>360||x>100||u>100?[0,0,100]:m<0||x<0||u<0?[0,0,0]:[s(m,r),s(x,r),s(u,r)]},W=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),cr=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let M=o*255;return[M,M,M]}let i=o<.5?o*(1+n):o+n-o*n,c=2*o-i,u=e+.333,x=e,m=e-.333,f=W(i,c,u),p=W(i,c,x),a=W(i,c,m);return f*=255,p*=255,a*=255,f>255||p>255||a>255?[255,255,255]:f<0||p<0||a<0?[0,0,0]:[s(f,r),s(p,r),s(a,r)]},sr=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,c;if(e===0)o=i=c=n;else{let x=(p,a,M)=>(M<0&&(M+=1),M>1&&(M-=1),M<.16666666666666666?p+(a-p)*6*M:M<.5?a:M<.6666666666666666?p+(a-p)*(.6666666666666666-M)*6:p),m=n<.5?n*(1+e):n+e-n*e,f=2*n-m;o=x(f,m,r+1/3),i=x(f,m,r),c=x(f,m,r-1/3)}let u=x=>{let m=Math.round(x*255).toString(16);return m.length===1?"0"+m:m};return`#${u(o)}${u(i)}${u(c)}`},Go=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},Oo=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,x,m,f)=>x+x+m+m+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),c=parseInt(n[3],16);return[o,i,c]},gt=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,c=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,c=c>.008856?Math.pow(c,1/3):7.787*c+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[s(116*c-16,r),s(500*(i-c),r),s(200*(c-u),r)]},jo=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,c=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,c=c>.0031308?1.055*Math.pow(c,1/2.4)-.055:12.92*c,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[s(Math.max(0,Math.min(1,i))*255,r),s(Math.max(0,Math.min(1,c))*255,r),s(Math.max(0,Math.min(1,u))*255,r)]},ko=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=y(e,360)),[e,t[1],t[2]]},Fo=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=y(e,100)),[t[0],t[1],e]},Qo=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},Zo=(t,r,e=1/0)=>{let n=gt(t,e),o=gt(r,e),i=n[0]-o[0],c=n[1]-o[1],u=n[2]-o[2],x=Math.sqrt(n[1]*n[1]+n[2]*n[2]),m=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=x-m,p=c*c+u*u-f*f;p=p<0?0:Math.sqrt(p);let a=1+.045*x,M=1+.015*x,v=i/1,H=f/a,l=p/M,A=v*v+H*H+l*l;return A<0?0:Math.sqrt(A)};var Wo=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),Uo=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var ti=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,ri=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},wt=t=>{let r=[];for(let e=0;e{let e=[];e.push(...wt(t)),e.push(...wt(r));for(let n of e){let o=nt(n[0],n[1]),i=zt(t,o),c=zt(r,o);if(!(i.max>=c.min&&c.max>=i.min))return!1}return!0},zt=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=tt(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var oi=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,c=!1,u,x=()=>{e=void 0,o=void 0,i=void 0,c=!1,n!==void 0&&window.cancelAnimationFrame(n)},m=()=>{x(),v()},f=()=>{c=!1},p=()=>{c=!0},a=R=>{e===void 0&&(e=R),o=R-e,c&&i!==R&&typeof t.callback=="function"&&t.callback(U()),o<=r?(i=R,n=window.requestAnimationFrame(a)):x()},M=(R,Et)=>{m(),typeof t.resizeCallback=="function"&&t.resizeCallback(R,Et)},v=()=>{e=void 0,o=void 0,i=void 0,c=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(M),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(a)},H=()=>o,l=()=>c,A=()=>e,Lt=()=>{if(!(r===1/0||o===void 0))return o*100/r},$t=()=>u,U=()=>({start:v,stop:x,pause:f,resume:p,restart:m,isAnimating:l,getElapsedTime:H,getStartTime:A,getPercent:Lt,getResizeObserver:$t});return U()};var si=(t,r=1/0)=>s(2*Math.PI*t,r),ui=(t,r,e=1/0)=>s(2*Math.PI*Math.sqrt((b(t,2)+b(r,2))/2),e),xi=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),mi=(t,r=1/0)=>s(t*2/Math.sqrt(2),r);var pi=t=>t*(t+1)/2,Mi=(t,r,e)=>t/2*(2*r+(t-1)*e);var O=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return s(e/t.length,r)},Vi=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return s(e,r)},li=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?s((e[n]+e[n-1])/2,r):s(e[n],r)},yi=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},Ii=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=O(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+b(i-e,2),0);return s(n/t.length,r)},ur=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=O(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+b(i,2),0);return s(n/t.length-b(e,2),r)},Ht=(t,r=1/0)=>{var n;let e=(n=ur(t))!=null?n:0;return s(Math.sqrt(e),r)};var xr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:s((t-r)/o,n)},Tt=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=Tt(t,e,n,r);return{min:s(e,r),max:s(n,r),data:o}},wi=(t,r,e,n=1/0)=>Tt(t,r,e,n),mr=(t,r,e,n=1/0)=>e===0?0:s((t-r)/e,n),Bt=(t,r,e,n=1/0)=>[...t].map(o=>mr(o,r,e,n)),zi=(t,r=1/0)=>{var i;let e=(i=O(t))!=null?i:0,n=Ht(t),o=Bt(t,e,n,r);return{mean:s(e,r),stdDev:s(n,r),data:o}},Hi=(t,r,e,n=1/0)=>Bt(t,r,e,n);var Bi=t=>t/2*(t+1),Li=(t,r)=>(r-t+1)*(t+r)/2;export{oi as animate,Mi as arithmeticSequenceSum,ri as circleCollide,rr as circleMovement,Ro as circleMovementAfterMouse,j as convertRange,ei as convexPolygonsCollide,gr as degreesToRadians,br as doRangesOverlap,jn as dxArcCos,Fn as dxArcCot,On as dxArcSin,kn as dxArcTan,Xn as dxCos,Gn as dxCot,Cn as dxPolynomial,Dn as dxSin,Yn as dxTan,dt as dxV2CubicBezierCurve,yt as dxV2QuadraticBezierCurve,vt as dxV3CubicBezierCurve,It as dxV3QuadraticBezierCurve,er as ellipseMovement,wo as ellipseMovementAfterMouse,At as getAnglesDistance,k as getAnglesSub,O as getArithmeticMean,Vi as getArithmeticMeanFromFrequency,si as getCircleCircumference,Zo as getColorsDelta,ui as getEllipseCircumference,to as getLinearEquationBy2Points,li as getMedian,yi as getMode,V as getRandom,Ln as getRandomBoolean,Do as getRandomGrayscaleHSLColor,St as getRandomHSLColor,Ao as getRandomHSLColorWithHue,Co as getRandomHSLColorWithLightness,No as getRandomHSLColorWithSaturation,Xo as getRandomHSLColorWithinRanges,qo as getRandomHexColor,_t as getRandomInt,$n as getRandomItemFromArray,Eo as getRandomRGBColor,ko as getShiftedHue,Fo as getShiftedLightness,Qo as getShiftedSaturation,mi as getSquareInCircleSide,Ht as getStandardDeviation,L as getV2Angle,Sr as getV2AngleBetween,dr as getV2AngleInEllipse,Rr as getV3AngleBetween,qt as getVNAngleBetween,ur as getVariance,Ii as getVariance1,Wo as guid,Oo as hexToRgb,sr as hslToHex,cr as hslToRgb,me as identity2,ae as identity3,fe as identity4,pe as identityN,wr as isAngleBetween,xi as isAngleInCircleArc,J as isClockwise,T as isNumber,Be as isSingularMatrix,jo as labToRgb,q as linearEquation,Kn as linearEquationSystem2,Jn as linearEquationSystem3,Pn as linearEquationSystemN,Ho as lissajousCurve,Mt as m2Adjugate,Ve as m2AppendRow,ut as m2DeepCopy,pt as m2Determinant,Ct as m2DivideScalar,ht as m2Inverse,Pr as m2MulScalar,Ie as m2PrependRow,fn as m2ReflectionOrigin,pn as m2ReflectionOriginH,Vn as m2ReflectionX,ln as m2ReflectionXH,yn as m2ReflectionY,In as m2ReflectionYH,hn as m2ReflectionYmX,oe as m2Reset,Oe as m2RotateAroundPointH,Xt as m2Rotation,Yt as m2RotationAroundPointH,lt as m2RotationH,Ft as m2Scale,Ke as m2ScaleAtPointH,kt as m2ScaleAtPointHMatrix,Qt as m2ScaleH,rn as m2ScaleX,en as m2ScaleXH,mn as m2ScaleY,an as m2ScaleYH,Hn as m2ShearingX,zn as m2ShearingY,Kr as m2Sub,Wr as m2Sum,Ae as m2ToCSS,Xe as m2Translation,G as m2TranslationH,ee as m2Transpose,Ne as m2hToCSS,Ce as m2hToCSS3d,ce as m2x2,Te as m3Adjugate,le as m3AppendRow,xt as m3DeepCopy,He as m3Determinant,re as m3DivideScalar,Vt as m3Inverse,te as m3MulScalar,de as m3PrependRow,Mn as m3ReflectionOrigin,bn as m3ReflectionOriginH,Rn as m3ReflectionXY,wn as m3ReflectionXYH,gn as m3ReflectionXZ,Sn as m3ReflectionXZH,dn as m3ReflectionYZ,vn as m3ReflectionYZH,ie as m3Reset,Gt as m3RotationX,Fe as m3RotationXH,Ot as m3RotationY,Ze as m3RotationYH,jt as m3RotationZ,We as m3RotationZH,Zt as m3Scale,Pe as m3ScaleH,nn as m3ScaleX,on as m3ScaleXH,cn as m3ScaleY,sn as m3ScaleYH,un as m3ScaleZ,xn as m3ScaleZH,Jr as m3Sub,Ur as m3Sum,Ye as m3Translation,Ge as m3TranslationH,ne as m3Transpose,De as m3hToCSS3d,se as m3x3,ue as m4x4,bt as mAdjugate,Me as mAppendCol,he as mAppendRow,I as mDeepCopy,Se as mDelFirstColumn,ge as mDelFirstRow,mt as mDelLastColumn,ve as mDelLastRow,Y as mDeterminant,Q as mDivideScalar,ze as mEqual,we as mGetColumn,Re as mGetFirstColumn,at as mGetLastColumn,Z as mInverse,ft as mMinor,E as mMul,ct as mMulScalar,h as mMulVector,xe as mNxM,be as mPrependCol,ye as mPrependRow,st as mReset,it as mSub,ot as mSum,X as mTranspose,Tt as mlNormalizeArray,Ri as mlNormalizeTestData,wi as mlNormalizeUnseenData,xr as mlNormalizeValue,Bt as mlStandardizeArray,zi as mlStandardizeTestData,Hi as mlStandardizeUnseenData,mr as mlStandardizeValue,y as mod,pi as naturalNumbersSequenceSum,Bi as naturalNumbersSum1ToN,Li as naturalNumbersSumMToN,Uo as newId,zr as percentToAngle,hr as polarToCartesian,vr as radiansToDegrees,ti as rectCollide,Go as rgbToHex,Yo as rgbToHsl,gt as rgbToLab,s as setDecimalPlaces,K as setV2Angle,zo as sineWaveMovement,qn as stringToNumber,jr as v2,yo as v2CubicBezierBBox,Ut as v2CubicBezierCurve,tr as v2CubicBezierCurveExtrema,Vo as v2CubicBezierCurveNormal,Jt as v2CubicBezierCurveTangent,Xr as v2Distance,Ar as v2DivideScalar,tt as v2DotProduct,Qr as v2FromPolarCoords,nt as v2GetNormal,P as v2Length,qr as v2MulScalar,$ as v2Normalize,lo as v2QuadraticBezierBBox,Wt as v2QuadraticBezierCurve,Pt as v2QuadraticBezierCurveExtrema,ho as v2QuadraticBezierCurveNormal,Kt as v2QuadraticBezierCurveTangent,je as v2Rotate,ke as v2RotateH,Je as v2Scale,Nt as v2SetLength,w as v2Sub,Lr as v2Sum,kr as v3,Or as v3CrossProduct,po as v3CubicBezierCurve,bo as v3CubicBezierCurveTangent,Yr as v3Distance,Nr as v3DivideScalar,Gr as v3DotProduct,Cr as v3Length,F as v3MulScalar,g as v3Normalize,fo as v3QuadraticBezierCurve,Mo as v3QuadraticBezierCurveTangent,Qe as v3RotateX,_e as v3RotateY,Ue as v3RotateZ,tn as v3Scale,Er as v3Sub,$r as v3Sum,Fr as v4,Dr as vDistance,D as vDivideScalar,S as vDotProduct,et as vEqual,z as vLength,C as vMulScalar,rt as vN,B as vNormalize,d as vSub,N as vSum}; + )`,Ye=(t,r=1/0)=>[[1,0],[0,1],[s(t[0],r),s(t[1],r)]],Ge=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[s(t[0],r),s(t[1],r),s(t[2],r)]],G=(t,r=1/0)=>[[1,0,s(t[0],r)],[0,1,s(t[1],r)],[0,0,1]],Oe=(t,r=1/0)=>[[1,0,0,s(t[0],r)],[0,1,0,s(t[1],r)],[0,0,1,s(t[2],r)],[0,0,0,1]],Xt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},lt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},Yt=(t,r,e=!0,n=1/0)=>{let o=G(r,n),i=lt(t,e,n),c=G(k(r,-1),n),u=N(o,i);return N(u,c)},je=(t,r,e,n=!0,o=1/0)=>{let i=Yt(t,r,n,o);return M(i,e)},Fe=(t,r,e=!0,n=1/0)=>{let o=L(r);return M(Xt(t,e,n),o)},ke=(t,r,e=!0,n=1/0)=>{let o=v(r);return M(lt(t,e,n),o)},Gt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},Qe=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},Ze=(t,r,e=!0,n=1/0)=>{let o=v(r);return M(Gt(t,e,n),o)},Ot=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},We=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},_e=(t,r,e=!0,n=1/0)=>{let o=v(r);return M(Ot(t,e,n),o)},jt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},Ue=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},Ke=(t,r,e=!0,n=1/0)=>{let o=v(r);return M(jt(t,e,n),o)},Ft=(t,r,e=1/0)=>{let n=G(r,e),o=Qt(t),i=G(k(r,-1),e),c=N(n,o);return N(c,i)},Je=(t,r,e,n=1/0)=>{let o=Ft(t,r,n);return M(o,e)},kt=t=>[[t[0],0],[0,t[1]]],Pe=(t,r)=>M(kt(t),r),Qt=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],Zt=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],tn=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],rn=(t,r)=>M(Zt(t),r),en=t=>[[t,0],[0,1]],nn=t=>[[t,0,0],[0,1,0],[0,0,1]],on=t=>[[t,0,0],[0,1,0],[0,0,1]],cn=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],sn=t=>[[1,0,0],[0,t,0],[0,0,1]],un=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],xn=t=>[[1,0,0],[0,1,0],[0,0,t]],mn=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],an=t=>[[1,0],[0,t]],fn=t=>[[1,0,0],[0,t,0],[0,0,1]],pn=()=>[[-1,0],[0,-1]],bn=()=>[[-1,0,0],[0,-1,0],[0,0,1]],hn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],Mn=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],Vn=()=>[[0,-1],[-1,0]],ln=()=>[[1,0],[0,-1]],yn=()=>[[1,0,0],[0,-1,0],[0,0,1]],dn=()=>[[-1,0],[0,1]],In=()=>[[-1,0,0],[0,1,0],[0,0,1]],gn=()=>[[-1,0,0],[0,1,0],[0,0,1]],vn=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],Sn=()=>[[1,0,0],[0,-1,0],[0,0,1]],wn=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],Rn=()=>[[1,0,0],[0,1,0],[0,0,-1]],zn=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],Bn=t=>[[1,t],[0,1]],Hn=t=>[[1,0],[t,1]];var V=(t,r,e=1/0)=>s(Math.random()*(r-t)+t,e),Wt=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),Ln=()=>Math.random()<.5,Nn=t=>{let r=Wt(0,t.length-1);return t[r]};var qn=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var Dn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],c=o[1];n+=i*c*Math.pow(t,c-1)}return s(n,e)},yt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},dt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},It=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},gt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},Xn=(t,r=1/0)=>s(Math.cos(t),r),Yn=(t,r=1/0)=>s(-Math.sin(t),r),Gn=(t,r=1/0)=>s(1/h(Math.cos(t),2),r),On=(t,r=1/0)=>s(-1/h(Math.sin(t),2),r),jn=(t,r=1/0)=>s(1/Math.sqrt(1-h(t,2)),r),Fn=(t,r=1/0)=>s(-1/Math.sqrt(1-h(t,2)),r),kn=(t,r=1/0)=>s(1/(1+h(t,2)),r),Qn=(t,r=1/0)=>s(-1/(1+h(t,2)),r);var $=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:s(i/e,r)},Jn=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=Mt(n);if(o===null)return null;let i=[t[2],r[2]];return M(o,i,e)},Pn=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=Vt(o);if(i===null)return null;let c=[t[3],r[3],e[3]];return M(i,c,n)},to=(t,r=1/0)=>{if(t.length<=0)return null;let e=mt(t),n=Z(e);if(n===null)return null;let o=at(t);return M(n,o,r)},ro=(t,r)=>{let[e,n]=R(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let c=n/e,u=i-c*o,x="";return c===0?x=`y = ${u}`:(x=`y = ${c===1?"":c}x`,u!==0&&(x+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:c,xIntercept:void 0,yIntercept:u,formula:x}};var W=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=$([n,o,i],r);return H(f)?[f]:[]}let c=o-i,u=n*n-4*e*c;if(u<0)return[];if(u===0)return[s(-n/(2*e),r)];let x=2*e,m=Math.sqrt(u);return[s((-n+m)/x,r),s((-n-m)/x,r)]};var _t=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},po=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},Ut=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},bo=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},Kt=(t,r,e,n,o=1/0)=>{let i=yt(t,r,e,n);return L(i,o)},ho=(t,r,e,n,o=1/0)=>{let i=dt(t,r,e,n);return v(i,o)},Jt=(t,r,e,n,o,i=1/0)=>{let c=It(t,r,e,n,o);return L(c,i)},Mo=(t,r,e,n,o,i=1/0)=>{let c=gt(t,r,e,n,o);return v(c,i)},Vo=(t,r,e,n,o=1/0)=>{let i=Kt(t,r,e,n,o);return[-i[1],i[0]]},lo=(t,r,e,n,o,i=1/0)=>{let c=Jt(t,r,e,n,o,i);return[-c[1],c[0]]},Pt=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=$([o,i,0],n),x=2*t[1]-4*r[1]+2*e[1],m=-2*t[1]+2*r[1],p=$([x,m,0],n),a=[];return H(u)&&a.push(u),H(p)&&a.push(p),a},tr=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],c=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],x=[i,c,u,0],m=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],a=[m,f,p,0],b=W(x,o).filter(l=>l>=0&&l<=1),g=W(a,o).filter(l=>l>=0&&l<=1);return[...b,...g].length===2?[...b,...g]:null},yo=(t,r,e,n=1/0)=>{let o=Pt(t,r,e),i=1/0,c=1/0,u=-1/0,x=-1/0;for(let m of o){let f=_t(m,t,r,e),p=f[0],a=f[1];i=Math.min(i,p),u=Math.max(u,p),c=Math.min(c,a),x=Math.max(x,a)}return i=s(Math.min(i,t[0],e[0]),n),u=s(Math.max(u,t[0],e[0]),n),c=s(Math.min(c,t[1],e[1]),n),x=s(Math.max(x,t[1],e[1]),n),{x:i,y:c,w:Math.abs(u-i),h:Math.abs(x-c),x2:u,y2:x}},Io=(t,r,e,n,o=1/0)=>{let i=tr(t,r,e,n)||[],c=1/0,u=1/0,x=-1/0,m=-1/0;for(let f of i){let p=Ut(f,t,r,e,n),a=p[0],b=p[1];c=Math.min(c,a!=null?a:1/0),x=Math.max(x,a!=null?a:-1/0),u=Math.min(u,b!=null?b:1/0),m=Math.max(m,b!=null?b:-1/0)}return c=s(Math.min(c,t[0],n[0]),o),x=s(Math.max(x,t[0],n[0]),o),u=s(Math.min(u,t[1],n[1]),o),m=s(Math.max(m,t[1],n[1]),o),{x:c,y:u,w:Math.abs(x-c),h:Math.abs(m-u),x2:x,y2:m}};var rr=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),Ro=(t,r,e)=>{let n=R(t,r),o=E(n);return o=j(o,0,Math.PI*2,0,Math.PI),rr(r,o,e)},er=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),zo=(t,r,e)=>{let n=R(t,r),o=E(n);return o=j(o,0,Math.PI*2,0,Math.PI),er(r,o,e[0],e[1])},Bo=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},Ho=(t,r,e,n,o,i,c)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-c)];var $o=()=>{let t=St();return cr(t)},qo=()=>{let t=St();return sr(t)},St=()=>{let t=V(1,360),r=V(0,100),e=V(0,100);return[t,r,e]},Ao=t=>{let r=V(0,100),e=V(0,100);return[t,r,e]},Co=t=>{let r=V(1,360),e=V(0,100);return[r,t,e]},Do=t=>{let r=V(1,360),e=V(0,100);return[r,e,t]},Xo=()=>[0,0,V(0,100)],Yo=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let c=V(t,r),u=V(e,n),x=V(o,i);return[c,u,x]},nr=t=>(t*=60,t<0&&(t+=360),t),or=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,c=0;return o===t&&(c=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),ir=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?wt(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),Go=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),c=Math.max(e,n,o),u=wt(e,n,o,i,c),x=ir(e,n,o,i,c,u),m=or(e,n,o,i,c);return m>360||x>100||u>100?[0,0,100]:m<0||x<0||u<0?[0,0,0]:[s(m,r),s(x,r),s(u,r)]},_=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),cr=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let b=o*255;return[b,b,b]}let i=o<.5?o*(1+n):o+n-o*n,c=2*o-i,u=e+.333,x=e,m=e-.333,f=_(i,c,u),p=_(i,c,x),a=_(i,c,m);return f*=255,p*=255,a*=255,f>255||p>255||a>255?[255,255,255]:f<0||p<0||a<0?[0,0,0]:[s(f,r),s(p,r),s(a,r)]},sr=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,c;if(e===0)o=i=c=n;else{let x=(p,a,b)=>(b<0&&(b+=1),b>1&&(b-=1),b<.16666666666666666?p+(a-p)*6*b:b<.5?a:b<.6666666666666666?p+(a-p)*(.6666666666666666-b)*6:p),m=n<.5?n*(1+e):n+e-n*e,f=2*n-m;o=x(f,m,r+1/3),i=x(f,m,r),c=x(f,m,r-1/3)}let u=x=>{let m=Math.round(x*255).toString(16);return m.length===1?"0"+m:m};return`#${u(o)}${u(i)}${u(c)}`},Oo=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},jo=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,x,m,f)=>x+x+m+m+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),c=parseInt(n[3],16);return[o,i,c]},vt=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,c=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,c=c>.008856?Math.pow(c,1/3):7.787*c+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[s(116*c-16,r),s(500*(i-c),r),s(200*(c-u),r)]},Fo=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,c=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,c=c>.0031308?1.055*Math.pow(c,1/2.4)-.055:12.92*c,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[s(Math.max(0,Math.min(1,i))*255,r),s(Math.max(0,Math.min(1,c))*255,r),s(Math.max(0,Math.min(1,u))*255,r)]},ko=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=y(e,360)),[e,t[1],t[2]]},Qo=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=y(e,100)),[t[0],t[1],e]},Zo=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},Wo=(t,r,e=1/0)=>{let n=vt(t,e),o=vt(r,e),i=n[0]-o[0],c=n[1]-o[1],u=n[2]-o[2],x=Math.sqrt(n[1]*n[1]+n[2]*n[2]),m=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=x-m,p=c*c+u*u-f*f;p=p<0?0:Math.sqrt(p);let a=1+.045*x,b=1+.015*x,g=i/1,B=f/a,l=p/b,q=g*g+B*B+l*l;return q<0?0:Math.sqrt(q)};var Uo=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),Ko=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var ri=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,ei=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},Rt=t=>{let r=[];for(let e=0;e{let e=[];e.push(...Rt(t)),e.push(...Rt(r));for(let n of e){let o=nt(n[0],n[1]),i=zt(t,o),c=zt(r,o);if(!(i.max>=c.min&&c.max>=i.min))return!1}return!0},zt=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=tt(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var ii=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,c=!1,u,x=()=>{e=void 0,o=void 0,i=void 0,c=!1,n!==void 0&&window.cancelAnimationFrame(n)},m=()=>{x(),g()},f=()=>{c=!1},p=()=>{c=!0},a=w=>{e===void 0&&(e=w),o=w-e,c&&i!==w&&typeof t.callback=="function"&&t.callback(U()),o<=r?(i=w,n=window.requestAnimationFrame(a)):x()},b=(w,Nt)=>{m(),typeof t.resizeCallback=="function"&&t.resizeCallback(w,Nt)},g=()=>{e=void 0,o=void 0,i=void 0,c=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(b),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(a)},B=()=>o,l=()=>c,q=()=>e,Et=()=>{if(!(r===1/0||o===void 0))return o*100/r},Lt=()=>u,U=()=>({start:g,stop:x,pause:f,resume:p,restart:m,isAnimating:l,getElapsedTime:B,getStartTime:q,getPercent:Et,getResizeObserver:Lt});return U()};var ui=(t,r=1/0)=>s(2*Math.PI*t,r),xi=(t,r,e=1/0)=>s(2*Math.PI*Math.sqrt((h(t,2)+h(r,2))/2),e),mi=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),ai=(t,r=1/0)=>s(t*2/Math.sqrt(2),r);var bi=t=>t*(t+1)/2,hi=(t,r,e)=>t/2*(2*r+(t-1)*e);var O=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return s(e/t.length,r)},li=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return s(e,r)},yi=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?s((e[n]+e[n-1])/2,r):s(e[n],r)},di=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},Ii=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=O(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+h(i-e,2),0);return s(n/t.length,r)},ur=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=O(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+h(i,2),0);return s(n/t.length-h(e,2),r)},Bt=(t,r=1/0)=>{var n;let e=(n=ur(t))!=null?n:0;return s(Math.sqrt(e),r)};var xr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:s((t-r)/o,n)},Ht=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=Ht(t,e,n,r);return{min:s(e,r),max:s(n,r),data:o}},zi=(t,r,e,n=1/0)=>Ht(t,r,e,n),mr=(t,r,e,n=1/0)=>e===0?0:s((t-r)/e,n),Tt=(t,r,e,n=1/0)=>[...t].map(o=>mr(o,r,e,n)),Bi=(t,r=1/0)=>{var i;let e=(i=O(t))!=null?i:0,n=Bt(t),o=Tt(t,e,n,r);return{mean:s(e,r),stdDev:s(n,r),data:o}},Hi=(t,r,e,n=1/0)=>Tt(t,r,e,n);var Ei=t=>t/2*(t+1),Li=(t,r)=>(r-t+1)*(t+r)/2;var $i=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=1;for(let n=r;n<=t;n++)e*=n;return e},ar=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}return t===r?r:t*ar(t-1,r)},qi=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=new Map,n=(o,i)=>{var u;if(o{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===t)return t===0?1:t;r===0&&(r=1);let e=[];e[0]=1;for(let n=1;n<=t;n++)e[n]=e[n-1]*n;return e[t]/e[r-1]};var Di=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return h(t,r)},Xi=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return h(t,r)};export{ii as animate,hi as arithmeticSequenceSum,ei as circleCollide,rr as circleMovement,Ro as circleMovementAfterMouse,j as convertRange,ni as convexPolygonsCollide,Sr as degreesToRadians,Mr as doRangesOverlap,Fn as dxArcCos,Qn as dxArcCot,jn as dxArcSin,kn as dxArcTan,Yn as dxCos,On as dxCot,Dn as dxPolynomial,Xn as dxSin,Gn as dxTan,It as dxV2CubicBezierCurve,yt as dxV2QuadraticBezierCurve,gt as dxV3CubicBezierCurve,dt as dxV3QuadraticBezierCurve,er as ellipseMovement,zo as ellipseMovementAfterMouse,Ai as factorial,$i as factorialIterative,qi as factorialMemoized,ar as factorialRecursive,qt as getAnglesDistance,F as getAnglesSub,O as getArithmeticMean,li as getArithmeticMeanFromFrequency,ui as getCircleCircumference,Wo as getColorsDelta,xi as getEllipseCircumference,ro as getLinearEquationBy2Points,yi as getMedian,di as getMode,V as getRandom,Ln as getRandomBoolean,Xo as getRandomGrayscaleHSLColor,St as getRandomHSLColor,Ao as getRandomHSLColorWithHue,Do as getRandomHSLColorWithLightness,Co as getRandomHSLColorWithSaturation,Yo as getRandomHSLColorWithinRanges,qo as getRandomHexColor,Wt as getRandomInt,Nn as getRandomItemFromArray,$o as getRandomRGBColor,ko as getShiftedHue,Qo as getShiftedLightness,Zo as getShiftedSaturation,ai as getSquareInCircleSide,Bt as getStandardDeviation,E as getV2Angle,wr as getV2AngleBetween,gr as getV2AngleInEllipse,Rr as getV3AngleBetween,$t as getVNAngleBetween,ur as getVariance,Ii as getVariance1,Uo as guid,jo as hexToRgb,sr as hslToHex,cr as hslToRgb,ae as identity2,fe as identity3,pe as identity4,be as identityN,zr as isAngleBetween,mi as isAngleInCircleArc,J as isClockwise,H as isNumber,Ee as isSingularMatrix,Fo as labToRgb,$ as linearEquation,Jn as linearEquationSystem2,Pn as linearEquationSystem3,to as linearEquationSystemN,Ho as lissajousCurve,bt as m2Adjugate,le as m2AppendRow,ut as m2DeepCopy,pt as m2Determinant,Ct as m2DivideScalar,Mt as m2Inverse,te as m2MulScalar,Ie as m2PrependRow,pn as m2ReflectionOrigin,bn as m2ReflectionOriginH,ln as m2ReflectionX,yn as m2ReflectionXH,dn as m2ReflectionY,In as m2ReflectionYH,Vn as m2ReflectionYmX,ie as m2Reset,je as m2RotateAroundPointH,Xt as m2Rotation,Yt as m2RotationAroundPointH,lt as m2RotationH,kt as m2Scale,Je as m2ScaleAtPointH,Ft as m2ScaleAtPointHMatrix,Qt as m2ScaleH,en as m2ScaleX,nn as m2ScaleXH,an as m2ScaleY,fn as m2ScaleYH,Hn as m2ShearingX,Bn as m2ShearingY,Jr as m2Sub,Ur as m2Sum,Ae as m2ToCSS,Ye as m2Translation,G as m2TranslationH,ne as m2Transpose,Ce as m2hToCSS,De as m2hToCSS3d,se as m2x2,Te as m3Adjugate,ye as m3AppendRow,xt as m3DeepCopy,He as m3Determinant,ee as m3DivideScalar,Vt as m3Inverse,re as m3MulScalar,ge as m3PrependRow,hn as m3ReflectionOrigin,Mn as m3ReflectionOriginH,Rn as m3ReflectionXY,zn as m3ReflectionXYH,Sn as m3ReflectionXZ,wn as m3ReflectionXZH,gn as m3ReflectionYZ,vn as m3ReflectionYZH,ce as m3Reset,Gt as m3RotationX,Qe as m3RotationXH,Ot as m3RotationY,We as m3RotationYH,jt as m3RotationZ,Ue as m3RotationZH,Zt as m3Scale,tn as m3ScaleH,on as m3ScaleX,cn as m3ScaleXH,sn as m3ScaleY,un as m3ScaleYH,xn as m3ScaleZ,mn as m3ScaleZH,Pr as m3Sub,Kr as m3Sum,Ge as m3Translation,Oe as m3TranslationH,oe as m3Transpose,Xe as m3hToCSS3d,ue as m3x3,xe as m4x4,ht as mAdjugate,he as mAppendCol,Ve as mAppendRow,d as mDeepCopy,we as mDelFirstColumn,Se as mDelFirstRow,mt as mDelLastColumn,ve as mDelLastRow,Y as mDeterminant,Q as mDivideScalar,Be as mEqual,ze as mGetColumn,Re as mGetFirstColumn,at as mGetLastColumn,Z as mInverse,ft as mMinor,N as mMul,ct as mMulScalar,M as mMulVector,me as mNxM,Me as mPrependCol,de as mPrependRow,st as mReset,it as mSub,ot as mSum,X as mTranspose,Ht as mlNormalizeArray,Ri as mlNormalizeTestData,zi as mlNormalizeUnseenData,xr as mlNormalizeValue,Tt as mlStandardizeArray,Bi as mlStandardizeTestData,Hi as mlStandardizeUnseenData,mr as mlStandardizeValue,y as mod,bi as naturalNumbersSequenceSum,Ei as naturalNumbersSum1ToN,Li as naturalNumbersSumMToN,Ko as newId,Br as percentToAngle,Di as permutationsWithRepetition,Xi as permutationsWithoutRepetition,Vr as polarToCartesian,vr as radiansToDegrees,ri as rectCollide,Oo as rgbToHex,Go as rgbToHsl,vt as rgbToLab,s as setDecimalPlaces,K as setV2Angle,Bo as sineWaveMovement,qn as stringToNumber,Fr as v2,Io as v2CubicBezierBBox,Ut as v2CubicBezierCurve,tr as v2CubicBezierCurveExtrema,lo as v2CubicBezierCurveNormal,Jt as v2CubicBezierCurveTangent,Yr as v2Distance,Ar as v2DivideScalar,tt as v2DotProduct,Zr as v2FromPolarCoords,nt as v2GetNormal,P as v2Length,qr as v2MulScalar,L as v2Normalize,yo as v2QuadraticBezierBBox,_t as v2QuadraticBezierCurve,Pt as v2QuadraticBezierCurveExtrema,Vo as v2QuadraticBezierCurveNormal,Kt as v2QuadraticBezierCurveTangent,Fe as v2Rotate,ke as v2RotateH,Pe as v2Scale,At as v2SetLength,R as v2Sub,Lr as v2Sum,kr as v3,jr as v3CrossProduct,bo as v3CubicBezierCurve,Mo as v3CubicBezierCurveTangent,Gr as v3Distance,Cr as v3DivideScalar,Or as v3DotProduct,Dr as v3Length,k as v3MulScalar,v as v3Normalize,po as v3QuadraticBezierCurve,ho as v3QuadraticBezierCurveTangent,Ze as v3RotateX,_e as v3RotateY,Ke as v3RotateZ,rn as v3Scale,$r as v3Sub,Nr as v3Sum,Qr as v4,Xr as vDistance,D as vDivideScalar,S as vDotProduct,et as vEqual,z as vLength,C as vMulScalar,rt as vN,T as vNormalize,I as vSub,A as vSum}; //# sourceMappingURL=mz-math.esm.js.map diff --git a/dist/mz-math.esm.js.map b/dist/mz-math.esm.js.map index c1d04eb..4583fca 100644 --- a/dist/mz-math.esm.js.map +++ b/dist/mz-math.esm.js.map @@ -1,7 +1,7 @@ { "version": 3, - "sources": ["../src/main/format.ts", "../src/main/other.ts", "../src/main/angle.ts", "../src/main/linear-algebra/vector.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts"], - "sourcesContent": ["export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};"], - "mappings": "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", - "names": ["setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "stringToNumber", "value", "defaultNumber", "_a", "res", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "x", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "guid", "c", "newId", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "naturalNumbersSequenceSum", "n", "arithmeticSequenceSum", "a", "d", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "naturalNumbersSum1ToN", "n", "naturalNumbersSumMToN", "m"] + "sources": ["../src/main/format.ts", "../src/main/other.ts", "../src/main/angle.ts", "../src/main/linear-algebra/vector.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts", "../src/main/combinatorics/factorial.ts", "../src/main/combinatorics/combinatorics.ts"], + "sourcesContent": ["export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};", "/**\n * The simplest and straightforward method\n * but can become inefficient for extremely large numbers\n * due to growing computational time.\n */\nexport const factorialIterative = (n: number, start = 0): number => {\n\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n let result = 1;\n for (let i = start; i <= n; i++) {\n result *= i;\n }\n return result;\n};\n\n/**\n * A recursive approach is a classic method for calculating factorials\n * but can lead to stack overflow errors\n * for very large inputs because of deep recursion.\n * However, it's a direct translation\n * of the mathematical definition of factorial.\n */\nexport const factorialRecursive = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n // Base case: when n reaches start, return start instead of further reducing\n if (n === start) return start;\n\n // Recursive call\n return n * factorialRecursive(n - 1, start);\n};\n\n/**\n * Memoization (Top-Down Dynamic Programming).\n */\nexport const factorialMemoized = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n const memo = new Map();\n\n const traverse = (num: number, end: number): number => {\n if (num < end) return 1; // Adjust the base case to return 1 if we're below 'end'\n // if (num === 0) return 1;\n\n if (memo.has(num)) return memo.get(num) ?? 1;\n\n if (num === end) {\n memo.set(num, num);\n return num;\n }\n\n const result = num * traverse(num - 1, end);\n\n memo.set(num, result);\n\n return result;\n };\n\n return traverse(n, start);\n};\n\n/**\n * Tabulation (Bottom-Up Dynamic Programming).\n */\nexport const factorial = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === n) {\n return n === 0 ? 1 : n; // If start == n and n == 0, return 1 (0!), otherwise return n\n }\n\n if (start === 0) {\n start = 1;\n }\n\n const table = []; // new Array(n + 1);\n table[0] = 1;\n for (let i = 1; i <= n; i++) {\n table[i] = table[i - 1] * i;\n }\n return table[n] / table[start - 1];\n};", "/**\n * Order doesn't matter.\n */\n/*\nexport const combinations = (n: number) => {\n\n};\n*/\n\n/**\n * Order does matter.\n * A Permutation is an ordered Combination.\n */\n/*\nexport const permutations = (n: number, isRepetitionAllowed: boolean) => {\n if(isRepetitionAllowed) {\n // n!\n }\n};*/\n\n/**\n * Permutations with repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - repetition is allowed\n *\n * Formula:\n * --------\n * n^r\n *\n * Intuition:\n * ----------\n * In other words, there are n possibilities for the first choice,\n * THEN there are n possibilities for the second choice, and so on,\n * multiplying each time.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n/**\n * Permutations without repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - no repetitions\n *\n * Formula:\n * --------\n * P(n,r) = n! / (n \u2212 r)!\n *\n * Intuition:\n * ----------\n * In this case, we have to reduce the number of available choices each time.\n * After choosing, say, number \"14\" we can't choose it again.\n * So, our first choice has 16 possibilities, and our next choice has 15 possibilities,\n * then 14, 13, 12, 11, ... etc.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithoutRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n"], + "mappings": "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", + "names": ["setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "stringToNumber", "value", "defaultNumber", "_a", "res", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "x", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "guid", "c", "newId", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "naturalNumbersSequenceSum", "n", "arithmeticSequenceSum", "a", "d", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "naturalNumbersSum1ToN", "n", "naturalNumbersSumMToN", "m", "factorialIterative", "n", "start", "result", "i", "factorialRecursive", "factorialMemoized", "memo", "traverse", "num", "end", "_a", "factorial", "table", "permutationsWithRepetition", "n", "__pow", "permutationsWithoutRepetition"] } diff --git a/dist/mz-math.min.js b/dist/mz-math.min.js index ca596bc..baa25b7 100644 --- a/dist/mz-math.min.js +++ b/dist/mz-math.min.js @@ -5,10 +5,10 @@ https://github.com/mzusin/mz-math Licensed GPLv3 for open source use, or Commercial License for commercial use - https://github.com/mzusin/index/blob/main/LICENSE.md Copyright (c) 2023-present, Miriam Zusin */ -(()=>{var Pt=Object.defineProperty;var Kt=Object.getOwnPropertySymbols;var Er=Object.prototype.hasOwnProperty,Ar=Object.prototype.propertyIsEnumerable;var V=Math.pow,Jt=(t,r,e)=>r in t?Pt(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,b=(t,r)=>{for(var e in r||(r={}))Er.call(r,e)&&Jt(t,e,r[e]);if(Kt)for(var e of Kt(r))Ar.call(r,e)&&Jt(t,e,r[e]);return t};var h=(t,r)=>{for(var e in r)Pt(t,e,{get:r[e],enumerable:!0})};var st={};h(st,{v2:()=>ne,v2Distance:()=>Pr,v2DivideScalar:()=>Wr,v2DotProduct:()=>et,v2FromPolarCoords:()=>se,v2GetNormal:()=>it,v2Length:()=>rt,v2MulScalar:()=>_r,v2Normalize:()=>q,v2SetLength:()=>er,v2Sub:()=>z,v2Sum:()=>Fr,v3:()=>oe,v3CrossProduct:()=>ee,v3Distance:()=>te,v3DivideScalar:()=>Ur,v3DotProduct:()=>re,v3Length:()=>Kr,v3MulScalar:()=>Z,v3Normalize:()=>S,v3Sub:()=>Zr,v3Sum:()=>Qr,v4:()=>ie,vDistance:()=>Jr,vDivideScalar:()=>X,vDotProduct:()=>R,vEqual:()=>ot,vLength:()=>T,vMulScalar:()=>D,vN:()=>nt,vNormalize:()=>L,vSub:()=>g,vSum:()=>C});var U={};h(U,{setDecimalPlaces:()=>c});var c=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=V(10,r);return Math.round(t*e)/e};var tt={};h(tt,{degreesToRadians:()=>Yr,getAnglesDistance:()=>rr,getAnglesSub:()=>Q,getV2Angle:()=>$,getV2AngleBetween:()=>Gr,getV2AngleInEllipse:()=>Dr,getV3AngleBetween:()=>Or,getVNAngleBetween:()=>tr,isAngleBetween:()=>jr,isClockwise:()=>P,percentToAngle:()=>kr,radiansToDegrees:()=>Xr,setV2Angle:()=>J});var K={};h(K,{convertRange:()=>F,doRangesOverlap:()=>Nr,isNumber:()=>B,mod:()=>d,polarToCartesian:()=>Cr});var d=(t,r)=>(t%r+r)%r,F=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,Nr=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),B=t=>!isNaN(parseFloat(t))&&isFinite(t),Cr=(t,r,e,n=1/0)=>{let[o,i]=t,[s,u]=r;return[c(o+s*Math.cos(e),n),c(i+u*Math.sin(e),n)]};var $=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return c(e,r)},Dr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return c(n,e)},J=(t,r,e=1/0)=>{let n=rt(t);return[c(Math.cos(r)*n,e),c(Math.sin(r)*n,e)]},Xr=(t,r=1/0)=>{let e=t*(180/Math.PI);return c(e,r)},Yr=(t,r=1/0)=>{let e=t*(Math.PI/180);return c(e,r)},tr=(t,r,e=1/0)=>{let n=L(t),o=L(r),i=R(n,o),s=Math.acos(i);return c(s,e)},Gr=(t,r,e=1/0)=>{let n=g(t,r),o=Math.atan2(n[1],n[0]);return c(o,e)},Or=(t,r,e=1/0)=>tr(t,r,e),jr=(t,r,e)=>{let n=Q(r,e),o=Q(r,t),i=Q(e,t),s=o+i;return Math.abs(s-n)<=.001},P=(t,r,e=0)=>(t=t%360,r=r%360,t=t),Q=(t,r,e=1/0)=>{let n=Math.abs(d(t,360)-d(r,360));return c(n<=180?n:360-n,e)},rr=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=rr(r,e,n);return P(r,e,n)?d(n+t*o/100,360):d(n-t*o/100,360)};var C=(t,r,e=1/0)=>{let n=[];for(let o=0;oC(t,r,e),Qr=(t,r,e=1/0)=>C(t,r,e),g=(t,r,e=1/0)=>{let n=[];for(let o=0;og(t,r,e),Zr=(t,r,e=1/0)=>g(t,r,e),D=(t,r,e=1/0)=>{let n=[];for(let o=0;oD(t,r,e),Z=(t,r,e=1/0)=>D(t,r,e),X=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oX(t,r,e),Ur=(t,r,e=1/0)=>X(t,r,e),T=(t,r=1/0)=>{let e=0;for(let n=0;nT(t,r),Kr=(t,r=1/0)=>T(t,r),er=(t,r,e=1/0)=>{let n=$(t);return[c(Math.cos(n)*r,e),c(Math.sin(n)*r,e)]},Jr=(t,r,e=1/0)=>{let n=g(t,r);return T(n,e)},Pr=(t,r,e=1/0)=>{let n=g(t,r);return T(n,e)},te=(t,r,e=1/0)=>{let n=g(t,r);return T(n,e)},L=(t,r=1/0)=>{let e=T(t),n=[];for(let o=0;oL(t,r),S=(t,r=1/0)=>L(t,r),R=(t,r,e=1/0)=>{let n=0;for(let o=0;oR(t,r,e),re=(t,r,e=1/0)=>R(t,r,e),ee=(t,r,e=1/0)=>[c(t[1]*r[2]-t[2]*r[1],e),c(t[2]*r[0]-t[0]*r[2],e),c(t[0]*r[1]-t[1]*r[0],e)],ne=(t=0)=>[t,t],oe=(t=0)=>[t,t,t],ie=(t=0)=>[t,t,t,t],nt=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=er(e,t),J(e,r)},ot=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=z(r,t);return[-c(n[1],e),c(n[0],e)]};var It={};h(It,{identity2:()=>ve,identity3:()=>ge,identity4:()=>Se,identityN:()=>we,isSingularMatrix:()=>je,m2Adjugate:()=>Vt,m2AppendRow:()=>He,m2DeepCopy:()=>at,m2Determinant:()=>ht,m2DivideScalar:()=>nr,m2Inverse:()=>yt,m2MulScalar:()=>ae,m2PrependRow:()=>$e,m2Reset:()=>he,m2Sub:()=>me,m2Sum:()=>ce,m2Transpose:()=>Me,m2x2:()=>le,m3Adjugate:()=>Oe,m3AppendRow:()=>Be,m3DeepCopy:()=>ft,m3Determinant:()=>Ge,m3DivideScalar:()=>pe,m3Inverse:()=>dt,m3MulScalar:()=>fe,m3PrependRow:()=>qe,m3Reset:()=>Ve,m3Sub:()=>xe,m3Sum:()=>ue,m3Transpose:()=>be,m3x3:()=>ye,m4x4:()=>de,mAdjugate:()=>lt,mAppendCol:()=>Re,mAppendRow:()=>Te,mDeepCopy:()=>I,mDelFirstColumn:()=>Ne,mDelFirstRow:()=>Ae,mDelLastColumn:()=>pt,mDelLastRow:()=>Ee,mDeterminant:()=>G,mDivideScalar:()=>_,mEqual:()=>Xe,mGetColumn:()=>De,mGetFirstColumn:()=>Ce,mGetLastColumn:()=>Mt,mInverse:()=>W,mMinor:()=>bt,mMul:()=>E,mMulScalar:()=>mt,mMulVector:()=>l,mNxM:()=>Ie,mPrependCol:()=>ze,mPrependRow:()=>Le,mReset:()=>xt,mSub:()=>ut,mSum:()=>ct,mTranspose:()=>Y});var ct=(t,r,e=1/0)=>{let n=[];for(let o=0;oct(t,r,e),ue=(t,r,e=1/0)=>ct(t,r,e),ut=(t,r,e=1/0)=>{let n=[];for(let o=0;out(t,r,e),xe=(t,r,e=1/0)=>ut(t,r,e),mt=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(D(o,r,e));return n},ae=(t,r,e=1/0)=>mt(t,r,e),fe=(t,r,e=1/0)=>mt(t,r,e),_=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(X(o,r,e));return n},nr=(t,r,e=1/0)=>_(t,r,e),pe=(t,r,e=1/0)=>_(t,r,e),Y=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oY(t),be=t=>Y(t),xt=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nxt(t,r),Ve=(t,r=0)=>xt(t,r),le=(t=0)=>[[t,t],[t,t]],ye=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],de=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],Ie=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],ge=()=>[[1,0,0],[0,1,0],[0,0,1]],Se=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],we=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;eI(t),ft=t=>I(t),Re=(t,r)=>{if(t.length<=0)return[];let e=I(t);for(let n=0;n{if(t.length<=0)return[];let e=I(t);for(let n=0;n{let e=I(t);return e.push(r),e},He=(t,r)=>{let e=at(t);return e.push(r),e},Be=(t,r)=>{let e=ft(t);return e.push(r),e},Le=(t,r)=>{let e=I(t);return e.unshift(r),e},$e=(t,r)=>{let e=at(t);return e.unshift(r),e},qe=(t,r)=>{let e=ft(t);return e.unshift(r),e},Ee=t=>{if(t.length<=0)return[];let r=I(t);return r.pop(),r},Ae=t=>{if(t.length<=0)return[];let r=I(t);return r.shift(),r},pt=t=>{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=Ye(t,r,e);return G(o)},G=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return ht(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},Ge=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return G(t)},Vt=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},Oe=t=>lt(t),lt=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return Vt(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return G(t)===0},yt=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=ht(t);if(e===0)return null;let n=Vt(t);return n===null?null:nr(n,e,r)},dt=(t,r=1/0)=>W(t,r),W=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=G(t),o=lt(t);return o===null?null:_(o,n,r)};var gt={};h(gt,{m2ReflectionOrigin:()=>In,m2ReflectionOriginH:()=>vn,m2ReflectionX:()=>Rn,m2ReflectionXH:()=>zn,m2ReflectionY:()=>Tn,m2ReflectionYH:()=>Hn,m2ReflectionYmX:()=>wn,m2RotateAroundPointH:()=>Ke,m2Rotation:()=>or,m2RotationAroundPointH:()=>ir,m2RotationH:()=>vt,m2Scale:()=>xr,m2ScaleAtPointH:()=>cn,m2ScaleAtPointHMatrix:()=>mr,m2ScaleH:()=>ar,m2ScaleX:()=>an,m2ScaleXH:()=>fn,m2ScaleY:()=>yn,m2ScaleYH:()=>dn,m2ShearingX:()=>Cn,m2ShearingY:()=>Nn,m2ToCSS:()=>ke,m2Translation:()=>_e,m2TranslationH:()=>O,m2hToCSS:()=>Fe,m2hToCSS3d:()=>Qe,m3ReflectionOrigin:()=>gn,m3ReflectionOriginH:()=>Sn,m3ReflectionXY:()=>En,m3ReflectionXYH:()=>An,m3ReflectionXZ:()=>$n,m3ReflectionXZH:()=>qn,m3ReflectionYZ:()=>Bn,m3ReflectionYZH:()=>Ln,m3RotationX:()=>sr,m3RotationXH:()=>tn,m3RotationY:()=>cr,m3RotationYH:()=>en,m3RotationZ:()=>ur,m3RotationZH:()=>on,m3Scale:()=>fr,m3ScaleH:()=>mn,m3ScaleX:()=>pn,m3ScaleXH:()=>Mn,m3ScaleY:()=>bn,m3ScaleYH:()=>hn,m3ScaleZ:()=>Vn,m3ScaleZH:()=>ln,m3Translation:()=>We,m3TranslationH:()=>Ue,m3hToCSS3d:()=>Ze,v2Rotate:()=>Je,v2RotateH:()=>Pe,v2Scale:()=>un,v3RotateX:()=>rn,v3RotateY:()=>nn,v3RotateZ:()=>sn,v3Scale:()=>xn});var ke=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},Fe=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],s=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${s})`},Qe=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],s=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${s}, 0, 1)`},Ze=t=>`matrix3d( +(()=>{var rr=Object.defineProperty;var Pt=Object.getOwnPropertySymbols;var Cr=Object.prototype.hasOwnProperty,Dr=Object.prototype.propertyIsEnumerable;var V=Math.pow,tr=(t,r,e)=>r in t?rr(t,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):t[r]=e,h=(t,r)=>{for(var e in r||(r={}))Cr.call(r,e)&&tr(t,e,r[e]);if(Pt)for(var e of Pt(r))Dr.call(r,e)&&tr(t,e,r[e]);return t};var M=(t,r)=>{for(var e in r)rr(t,e,{get:r[e],enumerable:!0})};var st={};M(st,{v2:()=>se,v2Distance:()=>ee,v2DivideScalar:()=>Jr,v2DotProduct:()=>et,v2FromPolarCoords:()=>me,v2GetNormal:()=>it,v2Length:()=>rt,v2MulScalar:()=>Kr,v2Normalize:()=>N,v2SetLength:()=>or,v2Sub:()=>z,v2Sum:()=>Wr,v3:()=>ce,v3CrossProduct:()=>ie,v3Distance:()=>ne,v3DivideScalar:()=>Pr,v3DotProduct:()=>oe,v3Length:()=>te,v3MulScalar:()=>Z,v3Normalize:()=>w,v3Sub:()=>Ur,v3Sum:()=>_r,v4:()=>ue,vDistance:()=>re,vDivideScalar:()=>X,vDotProduct:()=>R,vEqual:()=>ot,vLength:()=>B,vMulScalar:()=>D,vN:()=>nt,vNormalize:()=>H,vSub:()=>v,vSum:()=>C});var U={};M(U,{setDecimalPlaces:()=>c});var c=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=V(10,r);return Math.round(t*e)/e};var tt={};M(tt,{degreesToRadians:()=>jr,getAnglesDistance:()=>nr,getAnglesSub:()=>Q,getV2Angle:()=>L,getV2AngleBetween:()=>Fr,getV2AngleInEllipse:()=>Gr,getV3AngleBetween:()=>kr,getVNAngleBetween:()=>er,isAngleBetween:()=>Qr,isClockwise:()=>P,percentToAngle:()=>Zr,radiansToDegrees:()=>Or,setV2Angle:()=>J});var K={};M(K,{convertRange:()=>k,doRangesOverlap:()=>Xr,isNumber:()=>E,mod:()=>d,polarToCartesian:()=>Yr});var d=(t,r)=>(t%r+r)%r,k=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,Xr=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),E=t=>!isNaN(parseFloat(t))&&isFinite(t),Yr=(t,r,e,n=1/0)=>{let[o,i]=t,[s,u]=r;return[c(o+s*Math.cos(e),n),c(i+u*Math.sin(e),n)]};var L=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return c(e,r)},Gr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return c(n,e)},J=(t,r,e=1/0)=>{let n=rt(t);return[c(Math.cos(r)*n,e),c(Math.sin(r)*n,e)]},Or=(t,r=1/0)=>{let e=t*(180/Math.PI);return c(e,r)},jr=(t,r=1/0)=>{let e=t*(Math.PI/180);return c(e,r)},er=(t,r,e=1/0)=>{let n=H(t),o=H(r),i=R(n,o),s=Math.acos(i);return c(s,e)},Fr=(t,r,e=1/0)=>{let n=v(t,r),o=Math.atan2(n[1],n[0]);return c(o,e)},kr=(t,r,e=1/0)=>er(t,r,e),Qr=(t,r,e)=>{let n=Q(r,e),o=Q(r,t),i=Q(e,t),s=o+i;return Math.abs(s-n)<=.001},P=(t,r,e=0)=>(t=t%360,r=r%360,t=t),Q=(t,r,e=1/0)=>{let n=Math.abs(d(t,360)-d(r,360));return c(n<=180?n:360-n,e)},nr=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=nr(r,e,n);return P(r,e,n)?d(n+t*o/100,360):d(n-t*o/100,360)};var C=(t,r,e=1/0)=>{let n=[];for(let o=0;oC(t,r,e),_r=(t,r,e=1/0)=>C(t,r,e),v=(t,r,e=1/0)=>{let n=[];for(let o=0;ov(t,r,e),Ur=(t,r,e=1/0)=>v(t,r,e),D=(t,r,e=1/0)=>{let n=[];for(let o=0;oD(t,r,e),Z=(t,r,e=1/0)=>D(t,r,e),X=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oX(t,r,e),Pr=(t,r,e=1/0)=>X(t,r,e),B=(t,r=1/0)=>{let e=0;for(let n=0;nB(t,r),te=(t,r=1/0)=>B(t,r),or=(t,r,e=1/0)=>{let n=L(t);return[c(Math.cos(n)*r,e),c(Math.sin(n)*r,e)]},re=(t,r,e=1/0)=>{let n=v(t,r);return B(n,e)},ee=(t,r,e=1/0)=>{let n=v(t,r);return B(n,e)},ne=(t,r,e=1/0)=>{let n=v(t,r);return B(n,e)},H=(t,r=1/0)=>{let e=B(t),n=[];for(let o=0;oH(t,r),w=(t,r=1/0)=>H(t,r),R=(t,r,e=1/0)=>{let n=0;for(let o=0;oR(t,r,e),oe=(t,r,e=1/0)=>R(t,r,e),ie=(t,r,e=1/0)=>[c(t[1]*r[2]-t[2]*r[1],e),c(t[2]*r[0]-t[0]*r[2],e),c(t[0]*r[1]-t[1]*r[0],e)],se=(t=0)=>[t,t],ce=(t=0)=>[t,t,t],ue=(t=0)=>[t,t,t,t],nt=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=or(e,t),J(e,r)},ot=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=z(r,t);return[-c(n[1],e),c(n[0],e)]};var It={};M(It,{identity2:()=>Se,identity3:()=>Re,identity4:()=>ze,identityN:()=>Be,isSingularMatrix:()=>Qe,m2Adjugate:()=>Vt,m2AppendRow:()=>Le,m2DeepCopy:()=>xt,m2Determinant:()=>Mt,m2DivideScalar:()=>ir,m2Inverse:()=>yt,m2MulScalar:()=>be,m2PrependRow:()=>qe,m2Reset:()=>ye,m2Sub:()=>fe,m2Sum:()=>ae,m2Transpose:()=>Ve,m2x2:()=>Ie,m3Adjugate:()=>ke,m3AppendRow:()=>Ne,m3DeepCopy:()=>ft,m3Determinant:()=>Fe,m3DivideScalar:()=>Me,m3Inverse:()=>dt,m3MulScalar:()=>he,m3PrependRow:()=>Ae,m3Reset:()=>de,m3Sub:()=>pe,m3Sum:()=>xe,m3Transpose:()=>le,m3x3:()=>ge,m4x4:()=>ve,mAdjugate:()=>lt,mAppendCol:()=>Te,mAppendRow:()=>He,mDeepCopy:()=>I,mDelFirstColumn:()=>Xe,mDelFirstRow:()=>De,mDelLastColumn:()=>pt,mDelLastRow:()=>Ce,mDeterminant:()=>G,mDivideScalar:()=>W,mEqual:()=>Oe,mGetColumn:()=>Ge,mGetFirstColumn:()=>Ye,mGetLastColumn:()=>bt,mInverse:()=>_,mMinor:()=>ht,mMul:()=>$,mMulScalar:()=>mt,mMulVector:()=>l,mNxM:()=>we,mPrependCol:()=>Ee,mPrependRow:()=>$e,mReset:()=>at,mSub:()=>ut,mSum:()=>ct,mTranspose:()=>Y});var ct=(t,r,e=1/0)=>{let n=[];for(let o=0;oct(t,r,e),xe=(t,r,e=1/0)=>ct(t,r,e),ut=(t,r,e=1/0)=>{let n=[];for(let o=0;out(t,r,e),pe=(t,r,e=1/0)=>ut(t,r,e),mt=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(D(o,r,e));return n},be=(t,r,e=1/0)=>mt(t,r,e),he=(t,r,e=1/0)=>mt(t,r,e),W=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(X(o,r,e));return n},ir=(t,r,e=1/0)=>W(t,r,e),Me=(t,r,e=1/0)=>W(t,r,e),Y=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oY(t),le=t=>Y(t),at=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nat(t,r),de=(t,r=0)=>at(t,r),Ie=(t=0)=>[[t,t],[t,t]],ge=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],ve=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],we=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],Re=()=>[[1,0,0],[0,1,0],[0,0,1]],ze=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],Be=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;eI(t),ft=t=>I(t),Te=(t,r)=>{if(t.length<=0)return[];let e=I(t);for(let n=0;n{if(t.length<=0)return[];let e=I(t);for(let n=0;n{let e=I(t);return e.push(r),e},Le=(t,r)=>{let e=xt(t);return e.push(r),e},Ne=(t,r)=>{let e=ft(t);return e.push(r),e},$e=(t,r)=>{let e=I(t);return e.unshift(r),e},qe=(t,r)=>{let e=xt(t);return e.unshift(r),e},Ae=(t,r)=>{let e=ft(t);return e.unshift(r),e},Ce=t=>{if(t.length<=0)return[];let r=I(t);return r.pop(),r},De=t=>{if(t.length<=0)return[];let r=I(t);return r.shift(),r},pt=t=>{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=I(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=je(t,r,e);return G(o)},G=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return Mt(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},Fe=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return G(t)},Vt=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},ke=t=>lt(t),lt=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return Vt(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return G(t)===0},yt=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=Mt(t);if(e===0)return null;let n=Vt(t);return n===null?null:ir(n,e,r)},dt=(t,r=1/0)=>_(t,r),_=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=G(t),o=lt(t);return o===null?null:W(o,n,r)};var vt={};M(vt,{m2ReflectionOrigin:()=>wn,m2ReflectionOriginH:()=>Sn,m2ReflectionX:()=>Tn,m2ReflectionXH:()=>En,m2ReflectionY:()=>Hn,m2ReflectionYH:()=>Ln,m2ReflectionYmX:()=>Bn,m2RotateAroundPointH:()=>tn,m2Rotation:()=>sr,m2RotationAroundPointH:()=>cr,m2RotationH:()=>gt,m2Scale:()=>fr,m2ScaleAtPointH:()=>an,m2ScaleAtPointHMatrix:()=>xr,m2ScaleH:()=>pr,m2ScaleX:()=>bn,m2ScaleXH:()=>hn,m2ScaleY:()=>gn,m2ScaleYH:()=>vn,m2ShearingX:()=>Yn,m2ShearingY:()=>Xn,m2ToCSS:()=>Ze,m2Translation:()=>Ke,m2TranslationH:()=>O,m2hToCSS:()=>We,m2hToCSS3d:()=>_e,m3ReflectionOrigin:()=>Rn,m3ReflectionOriginH:()=>zn,m3ReflectionXY:()=>Cn,m3ReflectionXYH:()=>Dn,m3ReflectionXZ:()=>qn,m3ReflectionXZH:()=>An,m3ReflectionYZ:()=>Nn,m3ReflectionYZH:()=>$n,m3RotationX:()=>ur,m3RotationXH:()=>nn,m3RotationY:()=>mr,m3RotationYH:()=>sn,m3RotationZ:()=>ar,m3RotationZH:()=>un,m3Scale:()=>br,m3ScaleH:()=>fn,m3ScaleX:()=>Mn,m3ScaleXH:()=>Vn,m3ScaleY:()=>ln,m3ScaleYH:()=>yn,m3ScaleZ:()=>dn,m3ScaleZH:()=>In,m3Translation:()=>Je,m3TranslationH:()=>Pe,m3hToCSS3d:()=>Ue,v2Rotate:()=>rn,v2RotateH:()=>en,v2Scale:()=>xn,v3RotateX:()=>on,v3RotateY:()=>cn,v3RotateZ:()=>mn,v3Scale:()=>pn});var Ze=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},We=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],s=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${s})`},_e=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],s=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${s}, 0, 1)`},Ue=t=>`matrix3d( ${t[0][0]}, ${t[0][1]}, ${t[0][2]}, ${t[0][3]}, ${t[1][0]}, ${t[1][1]}, ${t[1][2]}, ${t[1][3]}, ${t[2][0]}, ${t[2][1]}, ${t[2][2]}, ${t[2][3]}, ${t[3][0]}, ${t[3][1]}, ${t[3][2]}, ${t[3][3]} - )`,_e=(t,r=1/0)=>[[1,0],[0,1],[c(t[0],r),c(t[1],r)]],We=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[c(t[0],r),c(t[1],r),c(t[2],r)]],O=(t,r=1/0)=>[[1,0,c(t[0],r)],[0,1,c(t[1],r)],[0,0,1]],Ue=(t,r=1/0)=>[[1,0,0,c(t[0],r)],[0,1,0,c(t[1],r)],[0,0,1,c(t[2],r)],[0,0,0,1]],or=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},vt=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},ir=(t,r,e=!0,n=1/0)=>{let o=O(r,n),i=vt(t,e,n),s=O(Z(r,-1),n),u=E(o,i);return E(u,s)},Ke=(t,r,e,n=!0,o=1/0)=>{let i=ir(t,r,n,o);return l(i,e)},Je=(t,r,e=!0,n=1/0)=>{let o=q(r);return l(or(t,e,n),o)},Pe=(t,r,e=!0,n=1/0)=>{let o=S(r);return l(vt(t,e,n),o)},sr=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},tn=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},rn=(t,r,e=!0,n=1/0)=>{let o=S(r);return l(sr(t,e,n),o)},cr=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},en=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},nn=(t,r,e=!0,n=1/0)=>{let o=S(r);return l(cr(t,e,n),o)},ur=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},on=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},sn=(t,r,e=!0,n=1/0)=>{let o=S(r);return l(ur(t,e,n),o)},mr=(t,r,e=1/0)=>{let n=O(r,e),o=ar(t),i=O(Z(r,-1),e),s=E(n,o);return E(s,i)},cn=(t,r,e,n=1/0)=>{let o=mr(t,r,n);return l(o,e)},xr=t=>[[t[0],0],[0,t[1]]],un=(t,r)=>l(xr(t),r),ar=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],fr=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],mn=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],xn=(t,r)=>l(fr(t),r),an=t=>[[t,0],[0,1]],fn=t=>[[t,0,0],[0,1,0],[0,0,1]],pn=t=>[[t,0,0],[0,1,0],[0,0,1]],Mn=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],bn=t=>[[1,0,0],[0,t,0],[0,0,1]],hn=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],Vn=t=>[[1,0,0],[0,1,0],[0,0,t]],ln=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],yn=t=>[[1,0],[0,t]],dn=t=>[[1,0,0],[0,t,0],[0,0,1]],In=()=>[[-1,0],[0,-1]],vn=()=>[[-1,0,0],[0,-1,0],[0,0,1]],gn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],Sn=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],wn=()=>[[0,-1],[-1,0]],Rn=()=>[[1,0],[0,-1]],zn=()=>[[1,0,0],[0,-1,0],[0,0,1]],Tn=()=>[[-1,0],[0,1]],Hn=()=>[[-1,0,0],[0,1,0],[0,0,1]],Bn=()=>[[-1,0,0],[0,1,0],[0,0,1]],Ln=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],$n=()=>[[1,0,0],[0,-1,0],[0,0,1]],qn=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],En=()=>[[1,0,0],[0,1,0],[0,0,-1]],An=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],Nn=t=>[[1,t],[0,1]],Cn=t=>[[1,0],[t,1]];var St={};h(St,{getRandom:()=>y,getRandomBoolean:()=>Dn,getRandomInt:()=>pr,getRandomItemFromArray:()=>Xn});var y=(t,r,e=1/0)=>c(Math.random()*(r-t)+t,e),pr=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),Dn=()=>Math.random()<.5,Xn=t=>{let r=pr(0,t.length-1);return t[r]};var wt={};h(wt,{stringToNumber:()=>Yn});var Yn=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var qt={};h(qt,{v2CubicBezierBBox:()=>co,v2CubicBezierCurve:()=>br,v2CubicBezierCurveExtrema:()=>yr,v2CubicBezierCurveNormal:()=>io,v2CubicBezierCurveTangent:()=>Vr,v2QuadraticBezierBBox:()=>so,v2QuadraticBezierCurve:()=>Mr,v2QuadraticBezierCurveExtrema:()=>lr,v2QuadraticBezierCurveNormal:()=>oo,v2QuadraticBezierCurveTangent:()=>hr,v3CubicBezierCurve:()=>ro,v3CubicBezierCurveTangent:()=>no,v3QuadraticBezierCurve:()=>to,v3QuadraticBezierCurveTangent:()=>eo});var Bt={};h(Bt,{dxArcCos:()=>Zn,dxArcCot:()=>Wn,dxArcSin:()=>Qn,dxArcTan:()=>_n,dxCos:()=>jn,dxCot:()=>Fn,dxPolynomial:()=>Gn,dxSin:()=>On,dxTan:()=>kn,dxV2CubicBezierCurve:()=>Tt,dxV2QuadraticBezierCurve:()=>Rt,dxV3CubicBezierCurve:()=>Ht,dxV3QuadraticBezierCurve:()=>zt});var Gn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],s=o[1];n+=i*s*Math.pow(t,s-1)}return c(n,e)},Rt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),s=2-4*t,u=2*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o)]},zt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),s=2-4*t,u=2*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o),c(i*r[2]+s*e[2]+u*n[2],o)]},Tt=(t,r,e,n,o,i=1/0)=>{let s=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),m=6*t-9*t*t,x=3*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+x*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+x*o[1],i)]},Ht=(t,r,e,n,o,i=1/0)=>{let s=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),m=6*t-9*t*t,x=3*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+x*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+x*o[1],i),c(s*r[2]+u*e[2]+m*n[2]+x*o[2],i)]},On=(t,r=1/0)=>c(Math.cos(t),r),jn=(t,r=1/0)=>c(-Math.sin(t),r),kn=(t,r=1/0)=>c(1/V(Math.cos(t),2),r),Fn=(t,r=1/0)=>c(-1/V(Math.sin(t),2),r),Qn=(t,r=1/0)=>c(1/Math.sqrt(1-V(t,2)),r),Zn=(t,r=1/0)=>c(-1/Math.sqrt(1-V(t,2)),r),_n=(t,r=1/0)=>c(1/(1+V(t,2)),r),Wn=(t,r=1/0)=>c(-1/(1+V(t,2)),r);var Lt={};h(Lt,{getLinearEquationBy2Points:()=>Pn,linearEquation:()=>A,linearEquationSystem2:()=>Un,linearEquationSystem3:()=>Kn,linearEquationSystemN:()=>Jn});var A=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:c(i/e,r)},Un=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=yt(n);if(o===null)return null;let i=[t[2],r[2]];return l(o,i,e)},Kn=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=dt(o);if(i===null)return null;let s=[t[3],r[3],e[3]];return l(i,s,n)},Jn=(t,r=1/0)=>{if(t.length<=0)return null;let e=pt(t),n=W(e);if(n===null)return null;let o=Mt(t);return l(n,o,r)},Pn=(t,r)=>{let[e,n]=z(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let s=n/e,u=i-s*o,m="";return s===0?m=`y = ${u}`:(m=`y = ${s===1?"":s}x`,u!==0&&(m+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:s,xIntercept:void 0,yIntercept:u,formula:m}};var $t=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=A([n,o,i],r);return B(f)?[f]:[]}let s=o-i,u=n*n-4*e*s;if(u<0)return[];if(u===0)return[c(-n/(2*e),r)];let m=2*e,x=Math.sqrt(u);return[c((-n+x)/m,r),c((-n-x)/m,r)]};var Mr=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),s=(1-t)*2*t,u=t*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o)]},to=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),s=(1-t)*2*t,u=t*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o),c(i*r[2]+s*e[2]+u*n[2],o)]},br=(t,r,e,n,o,i=1/0)=>{let s=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,m=(1-t)*3*t*t,x=t*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+x*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+x*o[1],i)]},ro=(t,r,e,n,o,i=1/0)=>{let s=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,m=(1-t)*3*t*t,x=t*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+x*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+x*o[1],i),c(s*r[2]+u*e[2]+m*n[2]+x*o[2],i)]},hr=(t,r,e,n,o=1/0)=>{let i=Rt(t,r,e,n);return q(i,o)},eo=(t,r,e,n,o=1/0)=>{let i=zt(t,r,e,n);return S(i,o)},Vr=(t,r,e,n,o,i=1/0)=>{let s=Tt(t,r,e,n,o);return q(s,i)},no=(t,r,e,n,o,i=1/0)=>{let s=Ht(t,r,e,n,o);return S(s,i)},oo=(t,r,e,n,o=1/0)=>{let i=hr(t,r,e,n,o);return[-i[1],i[0]]},io=(t,r,e,n,o,i=1/0)=>{let s=Vr(t,r,e,n,o,i);return[-s[1],s[0]]},lr=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=A([o,i,0],n),m=2*t[1]-4*r[1]+2*e[1],x=-2*t[1]+2*r[1],p=A([m,x,0],n),a=[];return B(u)&&a.push(u),B(p)&&a.push(p),a},yr=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],s=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],m=[i,s,u,0],x=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],a=[x,f,p,0],M=$t(m,o).filter(v=>v>=0&&v<=1),w=$t(a,o).filter(v=>v>=0&&v<=1);return[...M,...w].length===2?[...M,...w]:null},so=(t,r,e,n=1/0)=>{let o=lr(t,r,e),i=1/0,s=1/0,u=-1/0,m=-1/0;for(let x of o){let f=Mr(x,t,r,e),p=f[0],a=f[1];i=Math.min(i,p),u=Math.max(u,p),s=Math.min(s,a),m=Math.max(m,a)}return i=c(Math.min(i,t[0],e[0]),n),u=c(Math.max(u,t[0],e[0]),n),s=c(Math.min(s,t[1],e[1]),n),m=c(Math.max(m,t[1],e[1]),n),{x:i,y:s,w:Math.abs(u-i),h:Math.abs(m-s),x2:u,y2:m}},co=(t,r,e,n,o=1/0)=>{let i=yr(t,r,e,n)||[],s=1/0,u=1/0,m=-1/0,x=-1/0;for(let f of i){let p=br(f,t,r,e,n),a=p[0],M=p[1];s=Math.min(s,a!=null?a:1/0),m=Math.max(m,a!=null?a:-1/0),u=Math.min(u,M!=null?M:1/0),x=Math.max(x,M!=null?M:-1/0)}return s=c(Math.min(s,t[0],n[0]),o),m=c(Math.max(m,t[0],n[0]),o),u=c(Math.min(u,t[1],n[1]),o),x=c(Math.max(x,t[1],n[1]),o),{x:s,y:u,w:Math.abs(m-s),h:Math.abs(x-u),x2:m,y2:x}};var Et={};h(Et,{circleMovement:()=>dr,circleMovementAfterMouse:()=>uo,ellipseMovement:()=>Ir,ellipseMovementAfterMouse:()=>mo,lissajousCurve:()=>ao,sineWaveMovement:()=>xo});var dr=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),uo=(t,r,e)=>{let n=z(t,r),o=$(n);return o=F(o,0,Math.PI*2,0,Math.PI),dr(r,o,e)},Ir=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),mo=(t,r,e)=>{let n=z(t,r),o=$(n);return o=F(o,0,Math.PI*2,0,Math.PI),Ir(r,o,e[0],e[1])},xo=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},ao=(t,r,e,n,o,i,s)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-s)];var Dt={};h(Dt,{getColorsDelta:()=>Bo,getRandomGrayscaleHSLColor:()=>Vo,getRandomHSLColor:()=>Ct,getRandomHSLColorWithHue:()=>Mo,getRandomHSLColorWithLightness:()=>ho,getRandomHSLColorWithSaturation:()=>bo,getRandomHSLColorWithinRanges:()=>lo,getRandomHexColor:()=>po,getRandomRGBColor:()=>fo,getShiftedHue:()=>zo,getShiftedLightness:()=>To,getShiftedSaturation:()=>Ho,hexToRgb:()=>wo,hslToHex:()=>Sr,hslToRgb:()=>gr,labToRgb:()=>Ro,rgbToHex:()=>So,rgbToHsl:()=>go,rgbToLab:()=>Nt});var fo=()=>{let t=Ct();return gr(t)},po=()=>{let t=Ct();return Sr(t)},Ct=()=>{let t=y(1,360),r=y(0,100),e=y(0,100);return[t,r,e]},Mo=t=>{let r=y(0,100),e=y(0,100);return[t,r,e]},bo=t=>{let r=y(1,360),e=y(0,100);return[r,t,e]},ho=t=>{let r=y(1,360),e=y(0,100);return[r,e,t]},Vo=()=>[0,0,y(0,100)],lo=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let s=y(t,r),u=y(e,n),m=y(o,i);return[s,u,m]},yo=t=>(t*=60,t<0&&(t+=360),t),Io=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,s=0;return o===t&&(s=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),vo=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?vr(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),go=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),s=Math.max(e,n,o),u=vr(e,n,o,i,s),m=vo(e,n,o,i,s,u),x=Io(e,n,o,i,s);return x>360||m>100||u>100?[0,0,100]:x<0||m<0||u<0?[0,0,0]:[c(x,r),c(m,r),c(u,r)]},At=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),gr=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let M=o*255;return[M,M,M]}let i=o<.5?o*(1+n):o+n-o*n,s=2*o-i,u=e+.333,m=e,x=e-.333,f=At(i,s,u),p=At(i,s,m),a=At(i,s,x);return f*=255,p*=255,a*=255,f>255||p>255||a>255?[255,255,255]:f<0||p<0||a<0?[0,0,0]:[c(f,r),c(p,r),c(a,r)]},Sr=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,s;if(e===0)o=i=s=n;else{let m=(p,a,M)=>(M<0&&(M+=1),M>1&&(M-=1),M<.16666666666666666?p+(a-p)*6*M:M<.5?a:M<.6666666666666666?p+(a-p)*(.6666666666666666-M)*6:p),x=n<.5?n*(1+e):n+e-n*e,f=2*n-x;o=m(f,x,r+1/3),i=m(f,x,r),s=m(f,x,r-1/3)}let u=m=>{let x=Math.round(m*255).toString(16);return x.length===1?"0"+x:x};return`#${u(o)}${u(i)}${u(s)}`},So=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},wo=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,m,x,f)=>m+m+x+x+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),s=parseInt(n[3],16);return[o,i,s]},Nt=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,s=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,s=s>.008856?Math.pow(s,1/3):7.787*s+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[c(116*s-16,r),c(500*(i-s),r),c(200*(s-u),r)]},Ro=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,s=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,s=s>.0031308?1.055*Math.pow(s,1/2.4)-.055:12.92*s,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[c(Math.max(0,Math.min(1,i))*255,r),c(Math.max(0,Math.min(1,s))*255,r),c(Math.max(0,Math.min(1,u))*255,r)]},zo=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=d(e,360)),[e,t[1],t[2]]},To=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=d(e,100)),[t[0],t[1],e]},Ho=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},Bo=(t,r,e=1/0)=>{let n=Nt(t,e),o=Nt(r,e),i=n[0]-o[0],s=n[1]-o[1],u=n[2]-o[2],m=Math.sqrt(n[1]*n[1]+n[2]*n[2]),x=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=m-x,p=s*s+u*u-f*f;p=p<0?0:Math.sqrt(p);let a=1+.045*m,M=1+.015*m,w=i/1,N=f/a,v=p/M,k=w*w+N*N+v*v;return k<0?0:Math.sqrt(k)};var wr={};var Xt={};h(Xt,{guid:()=>Lo,newId:()=>$o});var Lo=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),$o=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var Yt={};h(Yt,{circleCollide:()=>Eo,convexPolygonsCollide:()=>Ao,rectCollide:()=>qo});var qo=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,Eo=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},Rr=t=>{let r=[];for(let e=0;e{let e=[];e.push(...Rr(t)),e.push(...Rr(r));for(let n of e){let o=it(n[0],n[1]),i=zr(t,o),s=zr(r,o);if(!(i.max>=s.min&&s.max>=i.min))return!1}return!0},zr=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=et(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var Gt={};h(Gt,{animate:()=>No});var No=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,s=!1,u,m=()=>{e=void 0,o=void 0,i=void 0,s=!1,n!==void 0&&window.cancelAnimationFrame(n)},x=()=>{m(),w()},f=()=>{s=!1},p=()=>{s=!0},a=H=>{e===void 0&&(e=H),o=H-e,s&&i!==H&&typeof t.callback=="function"&&t.callback(Ut()),o<=r?(i=H,n=window.requestAnimationFrame(a)):m()},M=(H,qr)=>{x(),typeof t.resizeCallback=="function"&&t.resizeCallback(H,qr)},w=()=>{e=void 0,o=void 0,i=void 0,s=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(M),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(a)},N=()=>o,v=()=>s,k=()=>e,Lr=()=>{if(!(r===1/0||o===void 0))return o*100/r},$r=()=>u,Ut=()=>({start:w,stop:m,pause:f,resume:p,restart:x,isAnimating:v,getElapsedTime:N,getStartTime:k,getPercent:Lr,getResizeObserver:$r});return Ut()};var Ot={};h(Ot,{getCircleCircumference:()=>Co,getEllipseCircumference:()=>Do,getSquareInCircleSide:()=>Yo,isAngleInCircleArc:()=>Xo});var Co=(t,r=1/0)=>c(2*Math.PI*t,r),Do=(t,r,e=1/0)=>c(2*Math.PI*Math.sqrt((V(t,2)+V(r,2))/2),e),Xo=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),Yo=(t,r=1/0)=>c(t*2/Math.sqrt(2),r);var jt={};h(jt,{arithmeticSequenceSum:()=>Oo,naturalNumbersSequenceSum:()=>Go});var Go=t=>t*(t+1)/2,Oo=(t,r,e)=>t/2*(2*r+(t-1)*e);var Ft={};h(Ft,{getArithmeticMean:()=>j,getArithmeticMeanFromFrequency:()=>jo,getMedian:()=>ko,getMode:()=>Fo,getStandardDeviation:()=>kt,getVariance:()=>Tr,getVariance1:()=>Qo});var j=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return c(e/t.length,r)},jo=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return c(e,r)},ko=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?c((e[n]+e[n-1])/2,r):c(e[n],r)},Fo=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},Qo=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=j(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+V(i-e,2),0);return c(n/t.length,r)},Tr=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=j(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+V(i,2),0);return c(n/t.length-V(e,2),r)},kt=(t,r=1/0)=>{var n;let e=(n=Tr(t))!=null?n:0;return c(Math.sqrt(e),r)};var _t={};h(_t,{mlNormalizeArray:()=>Qt,mlNormalizeTestData:()=>Zo,mlNormalizeUnseenData:()=>_o,mlNormalizeValue:()=>Hr,mlStandardizeArray:()=>Zt,mlStandardizeTestData:()=>Wo,mlStandardizeUnseenData:()=>Uo,mlStandardizeValue:()=>Br});var Hr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:c((t-r)/o,n)},Qt=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=Qt(t,e,n,r);return{min:c(e,r),max:c(n,r),data:o}},_o=(t,r,e,n=1/0)=>Qt(t,r,e,n),Br=(t,r,e,n=1/0)=>e===0?0:c((t-r)/e,n),Zt=(t,r,e,n=1/0)=>[...t].map(o=>Br(o,r,e,n)),Wo=(t,r=1/0)=>{var i;let e=(i=j(t))!=null?i:0,n=kt(t),o=Zt(t,e,n,r);return{mean:c(e,r),stdDev:c(n,r),data:o}},Uo=(t,r,e,n=1/0)=>Zt(t,r,e,n);var Wt={};h(Wt,{naturalNumbersSum1ToN:()=>Ko,naturalNumbersSumMToN:()=>Jo});var Ko=t=>t/2*(t+1),Jo=(t,r)=>(r-t+1)*(t+r)/2;var Po=b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b(b({},st),It),gt),U),tt),St),K),wt),qt),Lt),Et),Dt),wr),Xt),Bt),Yt),Gt),Ot),jt),Ft),_t),Wt);window.mzMath=window.mzMath||Po;})(); + )`,Ke=(t,r=1/0)=>[[1,0],[0,1],[c(t[0],r),c(t[1],r)]],Je=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[c(t[0],r),c(t[1],r),c(t[2],r)]],O=(t,r=1/0)=>[[1,0,c(t[0],r)],[0,1,c(t[1],r)],[0,0,1]],Pe=(t,r=1/0)=>[[1,0,0,c(t[0],r)],[0,1,0,c(t[1],r)],[0,0,1,c(t[2],r)],[0,0,0,1]],sr=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},gt=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},cr=(t,r,e=!0,n=1/0)=>{let o=O(r,n),i=gt(t,e,n),s=O(Z(r,-1),n),u=$(o,i);return $(u,s)},tn=(t,r,e,n=!0,o=1/0)=>{let i=cr(t,r,n,o);return l(i,e)},rn=(t,r,e=!0,n=1/0)=>{let o=N(r);return l(sr(t,e,n),o)},en=(t,r,e=!0,n=1/0)=>{let o=w(r);return l(gt(t,e,n),o)},ur=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},nn=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},on=(t,r,e=!0,n=1/0)=>{let o=w(r);return l(ur(t,e,n),o)},mr=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},sn=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},cn=(t,r,e=!0,n=1/0)=>{let o=w(r);return l(mr(t,e,n),o)},ar=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},un=(t,r=!0,e=1/0)=>{let n=c(Math.cos(t),e),o=c(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},mn=(t,r,e=!0,n=1/0)=>{let o=w(r);return l(ar(t,e,n),o)},xr=(t,r,e=1/0)=>{let n=O(r,e),o=pr(t),i=O(Z(r,-1),e),s=$(n,o);return $(s,i)},an=(t,r,e,n=1/0)=>{let o=xr(t,r,n);return l(o,e)},fr=t=>[[t[0],0],[0,t[1]]],xn=(t,r)=>l(fr(t),r),pr=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],br=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],fn=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],pn=(t,r)=>l(br(t),r),bn=t=>[[t,0],[0,1]],hn=t=>[[t,0,0],[0,1,0],[0,0,1]],Mn=t=>[[t,0,0],[0,1,0],[0,0,1]],Vn=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],ln=t=>[[1,0,0],[0,t,0],[0,0,1]],yn=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],dn=t=>[[1,0,0],[0,1,0],[0,0,t]],In=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],gn=t=>[[1,0],[0,t]],vn=t=>[[1,0,0],[0,t,0],[0,0,1]],wn=()=>[[-1,0],[0,-1]],Sn=()=>[[-1,0,0],[0,-1,0],[0,0,1]],Rn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],zn=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],Bn=()=>[[0,-1],[-1,0]],Tn=()=>[[1,0],[0,-1]],En=()=>[[1,0,0],[0,-1,0],[0,0,1]],Hn=()=>[[-1,0],[0,1]],Ln=()=>[[-1,0,0],[0,1,0],[0,0,1]],Nn=()=>[[-1,0,0],[0,1,0],[0,0,1]],$n=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],qn=()=>[[1,0,0],[0,-1,0],[0,0,1]],An=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],Cn=()=>[[1,0,0],[0,1,0],[0,0,-1]],Dn=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],Xn=t=>[[1,t],[0,1]],Yn=t=>[[1,0],[t,1]];var wt={};M(wt,{getRandom:()=>y,getRandomBoolean:()=>Gn,getRandomInt:()=>hr,getRandomItemFromArray:()=>On});var y=(t,r,e=1/0)=>c(Math.random()*(r-t)+t,e),hr=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),Gn=()=>Math.random()<.5,On=t=>{let r=hr(0,t.length-1);return t[r]};var St={};M(St,{stringToNumber:()=>jn});var jn=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var Nt={};M(Nt,{v2CubicBezierBBox:()=>ao,v2CubicBezierCurve:()=>Vr,v2CubicBezierCurveExtrema:()=>Ir,v2CubicBezierCurveNormal:()=>uo,v2CubicBezierCurveTangent:()=>yr,v2QuadraticBezierBBox:()=>mo,v2QuadraticBezierCurve:()=>Mr,v2QuadraticBezierCurveExtrema:()=>dr,v2QuadraticBezierCurveNormal:()=>co,v2QuadraticBezierCurveTangent:()=>lr,v3CubicBezierCurve:()=>oo,v3CubicBezierCurveTangent:()=>so,v3QuadraticBezierCurve:()=>no,v3QuadraticBezierCurveTangent:()=>io});var Et={};M(Et,{dxArcCos:()=>Un,dxArcCot:()=>Jn,dxArcSin:()=>_n,dxArcTan:()=>Kn,dxCos:()=>Qn,dxCot:()=>Wn,dxPolynomial:()=>Fn,dxSin:()=>kn,dxTan:()=>Zn,dxV2CubicBezierCurve:()=>Bt,dxV2QuadraticBezierCurve:()=>Rt,dxV3CubicBezierCurve:()=>Tt,dxV3QuadraticBezierCurve:()=>zt});var Fn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],s=o[1];n+=i*s*Math.pow(t,s-1)}return c(n,e)},Rt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),s=2-4*t,u=2*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o)]},zt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),s=2-4*t,u=2*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o),c(i*r[2]+s*e[2]+u*n[2],o)]},Bt=(t,r,e,n,o,i=1/0)=>{let s=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),m=6*t-9*t*t,a=3*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+a*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+a*o[1],i)]},Tt=(t,r,e,n,o,i=1/0)=>{let s=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),m=6*t-9*t*t,a=3*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+a*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+a*o[1],i),c(s*r[2]+u*e[2]+m*n[2]+a*o[2],i)]},kn=(t,r=1/0)=>c(Math.cos(t),r),Qn=(t,r=1/0)=>c(-Math.sin(t),r),Zn=(t,r=1/0)=>c(1/V(Math.cos(t),2),r),Wn=(t,r=1/0)=>c(-1/V(Math.sin(t),2),r),_n=(t,r=1/0)=>c(1/Math.sqrt(1-V(t,2)),r),Un=(t,r=1/0)=>c(-1/Math.sqrt(1-V(t,2)),r),Kn=(t,r=1/0)=>c(1/(1+V(t,2)),r),Jn=(t,r=1/0)=>c(-1/(1+V(t,2)),r);var Ht={};M(Ht,{getLinearEquationBy2Points:()=>eo,linearEquation:()=>q,linearEquationSystem2:()=>Pn,linearEquationSystem3:()=>to,linearEquationSystemN:()=>ro});var q=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:c(i/e,r)},Pn=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=yt(n);if(o===null)return null;let i=[t[2],r[2]];return l(o,i,e)},to=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=dt(o);if(i===null)return null;let s=[t[3],r[3],e[3]];return l(i,s,n)},ro=(t,r=1/0)=>{if(t.length<=0)return null;let e=pt(t),n=_(e);if(n===null)return null;let o=bt(t);return l(n,o,r)},eo=(t,r)=>{let[e,n]=z(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let s=n/e,u=i-s*o,m="";return s===0?m=`y = ${u}`:(m=`y = ${s===1?"":s}x`,u!==0&&(m+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:s,xIntercept:void 0,yIntercept:u,formula:m}};var Lt=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=q([n,o,i],r);return E(f)?[f]:[]}let s=o-i,u=n*n-4*e*s;if(u<0)return[];if(u===0)return[c(-n/(2*e),r)];let m=2*e,a=Math.sqrt(u);return[c((-n+a)/m,r),c((-n-a)/m,r)]};var Mr=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),s=(1-t)*2*t,u=t*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o)]},no=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),s=(1-t)*2*t,u=t*t;return[c(i*r[0]+s*e[0]+u*n[0],o),c(i*r[1]+s*e[1]+u*n[1],o),c(i*r[2]+s*e[2]+u*n[2],o)]},Vr=(t,r,e,n,o,i=1/0)=>{let s=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,m=(1-t)*3*t*t,a=t*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+a*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+a*o[1],i)]},oo=(t,r,e,n,o,i=1/0)=>{let s=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,m=(1-t)*3*t*t,a=t*t*t;return[c(s*r[0]+u*e[0]+m*n[0]+a*o[0],i),c(s*r[1]+u*e[1]+m*n[1]+a*o[1],i),c(s*r[2]+u*e[2]+m*n[2]+a*o[2],i)]},lr=(t,r,e,n,o=1/0)=>{let i=Rt(t,r,e,n);return N(i,o)},io=(t,r,e,n,o=1/0)=>{let i=zt(t,r,e,n);return w(i,o)},yr=(t,r,e,n,o,i=1/0)=>{let s=Bt(t,r,e,n,o);return N(s,i)},so=(t,r,e,n,o,i=1/0)=>{let s=Tt(t,r,e,n,o);return w(s,i)},co=(t,r,e,n,o=1/0)=>{let i=lr(t,r,e,n,o);return[-i[1],i[0]]},uo=(t,r,e,n,o,i=1/0)=>{let s=yr(t,r,e,n,o,i);return[-s[1],s[0]]},dr=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=q([o,i,0],n),m=2*t[1]-4*r[1]+2*e[1],a=-2*t[1]+2*r[1],p=q([m,a,0],n),x=[];return E(u)&&x.push(u),E(p)&&x.push(p),x},Ir=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],s=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],m=[i,s,u,0],a=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],x=[a,f,p,0],b=Lt(m,o).filter(g=>g>=0&&g<=1),S=Lt(x,o).filter(g=>g>=0&&g<=1);return[...b,...S].length===2?[...b,...S]:null},mo=(t,r,e,n=1/0)=>{let o=dr(t,r,e),i=1/0,s=1/0,u=-1/0,m=-1/0;for(let a of o){let f=Mr(a,t,r,e),p=f[0],x=f[1];i=Math.min(i,p),u=Math.max(u,p),s=Math.min(s,x),m=Math.max(m,x)}return i=c(Math.min(i,t[0],e[0]),n),u=c(Math.max(u,t[0],e[0]),n),s=c(Math.min(s,t[1],e[1]),n),m=c(Math.max(m,t[1],e[1]),n),{x:i,y:s,w:Math.abs(u-i),h:Math.abs(m-s),x2:u,y2:m}},ao=(t,r,e,n,o=1/0)=>{let i=Ir(t,r,e,n)||[],s=1/0,u=1/0,m=-1/0,a=-1/0;for(let f of i){let p=Vr(f,t,r,e,n),x=p[0],b=p[1];s=Math.min(s,x!=null?x:1/0),m=Math.max(m,x!=null?x:-1/0),u=Math.min(u,b!=null?b:1/0),a=Math.max(a,b!=null?b:-1/0)}return s=c(Math.min(s,t[0],n[0]),o),m=c(Math.max(m,t[0],n[0]),o),u=c(Math.min(u,t[1],n[1]),o),a=c(Math.max(a,t[1],n[1]),o),{x:s,y:u,w:Math.abs(m-s),h:Math.abs(a-u),x2:m,y2:a}};var $t={};M($t,{circleMovement:()=>gr,circleMovementAfterMouse:()=>xo,ellipseMovement:()=>vr,ellipseMovementAfterMouse:()=>fo,lissajousCurve:()=>bo,sineWaveMovement:()=>po});var gr=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),xo=(t,r,e)=>{let n=z(t,r),o=L(n);return o=k(o,0,Math.PI*2,0,Math.PI),gr(r,o,e)},vr=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),fo=(t,r,e)=>{let n=z(t,r),o=L(n);return o=k(o,0,Math.PI*2,0,Math.PI),vr(r,o,e[0],e[1])},po=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},bo=(t,r,e,n,o,i,s)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-s)];var Dt={};M(Dt,{getColorsDelta:()=>No,getRandomGrayscaleHSLColor:()=>Io,getRandomHSLColor:()=>Ct,getRandomHSLColorWithHue:()=>Vo,getRandomHSLColorWithLightness:()=>yo,getRandomHSLColorWithSaturation:()=>lo,getRandomHSLColorWithinRanges:()=>go,getRandomHexColor:()=>Mo,getRandomRGBColor:()=>ho,getShiftedHue:()=>Eo,getShiftedLightness:()=>Ho,getShiftedSaturation:()=>Lo,hexToRgb:()=>Bo,hslToHex:()=>Rr,hslToRgb:()=>Sr,labToRgb:()=>To,rgbToHex:()=>zo,rgbToHsl:()=>Ro,rgbToLab:()=>At});var ho=()=>{let t=Ct();return Sr(t)},Mo=()=>{let t=Ct();return Rr(t)},Ct=()=>{let t=y(1,360),r=y(0,100),e=y(0,100);return[t,r,e]},Vo=t=>{let r=y(0,100),e=y(0,100);return[t,r,e]},lo=t=>{let r=y(1,360),e=y(0,100);return[r,t,e]},yo=t=>{let r=y(1,360),e=y(0,100);return[r,e,t]},Io=()=>[0,0,y(0,100)],go=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let s=y(t,r),u=y(e,n),m=y(o,i);return[s,u,m]},vo=t=>(t*=60,t<0&&(t+=360),t),wo=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,s=0;return o===t&&(s=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),So=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?wr(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),Ro=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),s=Math.max(e,n,o),u=wr(e,n,o,i,s),m=So(e,n,o,i,s,u),a=wo(e,n,o,i,s);return a>360||m>100||u>100?[0,0,100]:a<0||m<0||u<0?[0,0,0]:[c(a,r),c(m,r),c(u,r)]},qt=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),Sr=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let b=o*255;return[b,b,b]}let i=o<.5?o*(1+n):o+n-o*n,s=2*o-i,u=e+.333,m=e,a=e-.333,f=qt(i,s,u),p=qt(i,s,m),x=qt(i,s,a);return f*=255,p*=255,x*=255,f>255||p>255||x>255?[255,255,255]:f<0||p<0||x<0?[0,0,0]:[c(f,r),c(p,r),c(x,r)]},Rr=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,s;if(e===0)o=i=s=n;else{let m=(p,x,b)=>(b<0&&(b+=1),b>1&&(b-=1),b<.16666666666666666?p+(x-p)*6*b:b<.5?x:b<.6666666666666666?p+(x-p)*(.6666666666666666-b)*6:p),a=n<.5?n*(1+e):n+e-n*e,f=2*n-a;o=m(f,a,r+1/3),i=m(f,a,r),s=m(f,a,r-1/3)}let u=m=>{let a=Math.round(m*255).toString(16);return a.length===1?"0"+a:a};return`#${u(o)}${u(i)}${u(s)}`},zo=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},Bo=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,m,a,f)=>m+m+a+a+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),s=parseInt(n[3],16);return[o,i,s]},At=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,s=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,s=s>.008856?Math.pow(s,1/3):7.787*s+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[c(116*s-16,r),c(500*(i-s),r),c(200*(s-u),r)]},To=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,s=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,s=s>.0031308?1.055*Math.pow(s,1/2.4)-.055:12.92*s,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[c(Math.max(0,Math.min(1,i))*255,r),c(Math.max(0,Math.min(1,s))*255,r),c(Math.max(0,Math.min(1,u))*255,r)]},Eo=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=d(e,360)),[e,t[1],t[2]]},Ho=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=d(e,100)),[t[0],t[1],e]},Lo=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},No=(t,r,e=1/0)=>{let n=At(t,e),o=At(r,e),i=n[0]-o[0],s=n[1]-o[1],u=n[2]-o[2],m=Math.sqrt(n[1]*n[1]+n[2]*n[2]),a=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=m-a,p=s*s+u*u-f*f;p=p<0?0:Math.sqrt(p);let x=1+.045*m,b=1+.015*m,S=i/1,A=f/x,g=p/b,F=S*S+A*A+g*g;return F<0?0:Math.sqrt(F)};var zr={};var Xt={};M(Xt,{guid:()=>$o,newId:()=>qo});var $o=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),qo=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var Yt={};M(Yt,{circleCollide:()=>Co,convexPolygonsCollide:()=>Do,rectCollide:()=>Ao});var Ao=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,Co=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},Br=t=>{let r=[];for(let e=0;e{let e=[];e.push(...Br(t)),e.push(...Br(r));for(let n of e){let o=it(n[0],n[1]),i=Tr(t,o),s=Tr(r,o);if(!(i.max>=s.min&&s.max>=i.min))return!1}return!0},Tr=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=et(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var Gt={};M(Gt,{animate:()=>Xo});var Xo=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,s=!1,u,m=()=>{e=void 0,o=void 0,i=void 0,s=!1,n!==void 0&&window.cancelAnimationFrame(n)},a=()=>{m(),S()},f=()=>{s=!1},p=()=>{s=!0},x=T=>{e===void 0&&(e=T),o=T-e,s&&i!==T&&typeof t.callback=="function"&&t.callback(Jt()),o<=r?(i=T,n=window.requestAnimationFrame(x)):m()},b=(T,Ar)=>{a(),typeof t.resizeCallback=="function"&&t.resizeCallback(T,Ar)},S=()=>{e=void 0,o=void 0,i=void 0,s=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(b),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(x)},A=()=>o,g=()=>s,F=()=>e,$r=()=>{if(!(r===1/0||o===void 0))return o*100/r},qr=()=>u,Jt=()=>({start:S,stop:m,pause:f,resume:p,restart:a,isAnimating:g,getElapsedTime:A,getStartTime:F,getPercent:$r,getResizeObserver:qr});return Jt()};var Ot={};M(Ot,{getCircleCircumference:()=>Yo,getEllipseCircumference:()=>Go,getSquareInCircleSide:()=>jo,isAngleInCircleArc:()=>Oo});var Yo=(t,r=1/0)=>c(2*Math.PI*t,r),Go=(t,r,e=1/0)=>c(2*Math.PI*Math.sqrt((V(t,2)+V(r,2))/2),e),Oo=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),jo=(t,r=1/0)=>c(t*2/Math.sqrt(2),r);var jt={};M(jt,{arithmeticSequenceSum:()=>ko,naturalNumbersSequenceSum:()=>Fo});var Fo=t=>t*(t+1)/2,ko=(t,r,e)=>t/2*(2*r+(t-1)*e);var kt={};M(kt,{getArithmeticMean:()=>j,getArithmeticMeanFromFrequency:()=>Qo,getMedian:()=>Zo,getMode:()=>Wo,getStandardDeviation:()=>Ft,getVariance:()=>Er,getVariance1:()=>_o});var j=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return c(e/t.length,r)},Qo=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return c(e,r)},Zo=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?c((e[n]+e[n-1])/2,r):c(e[n],r)},Wo=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},_o=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=j(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+V(i-e,2),0);return c(n/t.length,r)},Er=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=j(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+V(i,2),0);return c(n/t.length-V(e,2),r)},Ft=(t,r=1/0)=>{var n;let e=(n=Er(t))!=null?n:0;return c(Math.sqrt(e),r)};var Wt={};M(Wt,{mlNormalizeArray:()=>Qt,mlNormalizeTestData:()=>Uo,mlNormalizeUnseenData:()=>Ko,mlNormalizeValue:()=>Hr,mlStandardizeArray:()=>Zt,mlStandardizeTestData:()=>Jo,mlStandardizeUnseenData:()=>Po,mlStandardizeValue:()=>Lr});var Hr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:c((t-r)/o,n)},Qt=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=Qt(t,e,n,r);return{min:c(e,r),max:c(n,r),data:o}},Ko=(t,r,e,n=1/0)=>Qt(t,r,e,n),Lr=(t,r,e,n=1/0)=>e===0?0:c((t-r)/e,n),Zt=(t,r,e,n=1/0)=>[...t].map(o=>Lr(o,r,e,n)),Jo=(t,r=1/0)=>{var i;let e=(i=j(t))!=null?i:0,n=Ft(t),o=Zt(t,e,n,r);return{mean:c(e,r),stdDev:c(n,r),data:o}},Po=(t,r,e,n=1/0)=>Zt(t,r,e,n);var _t={};M(_t,{naturalNumbersSum1ToN:()=>ti,naturalNumbersSumMToN:()=>ri});var ti=t=>t/2*(t+1),ri=(t,r)=>(r-t+1)*(t+r)/2;var Ut={};M(Ut,{factorial:()=>oi,factorialIterative:()=>ei,factorialMemoized:()=>ni,factorialRecursive:()=>Nr});var ei=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=1;for(let n=r;n<=t;n++)e*=n;return e},Nr=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}return t===r?r:t*Nr(t-1,r)},ni=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=new Map,n=(o,i)=>{var u;if(o{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===t)return t===0?1:t;r===0&&(r=1);let e=[];e[0]=1;for(let n=1;n<=t;n++)e[n]=e[n-1]*n;return e[t]/e[r-1]};var Kt={};M(Kt,{permutationsWithRepetition:()=>ii,permutationsWithoutRepetition:()=>si});var ii=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return V(t,r)},si=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return V(t,r)};var ci=h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h(h({},st),It),vt),U),tt),wt),K),St),Nt),Ht),$t),Dt),zr),Xt),Et),Yt),Gt),Ot),jt),kt),Wt),_t),Ut),Kt);window.mzMath=window.mzMath||ci;})(); //# sourceMappingURL=mz-math.min.js.map diff --git a/dist/mz-math.min.js.map b/dist/mz-math.min.js.map index e14fa36..4683d75 100644 --- a/dist/mz-math.min.js.map +++ b/dist/mz-math.min.js.map @@ -1,7 +1,7 @@ { "version": 3, - "sources": ["../src/main/linear-algebra/vector.ts", "../src/main/format.ts", "../src/main/angle.ts", "../src/main/other.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/physics.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts", "../src/index.ts"], - "sourcesContent": ["import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "import { Vector2 } from '../types';\n\n/**\n * Speed = how far something moves in a given amount of time.\n * Speed is also a vector:\n * magnitude = distance\n * direction = time\n */\nexport type Speed = Vector2;\n\n/**\n * Velocity is a measure of how fast an object is moving in a particular direction.\n * Velocity = Distance traveled / Time taken\n * It has a magnitude and direction, and can be represented as a vector.\n */\nexport type Velocity = Vector2;\n\n/**\n * Acceleration is a measure of how quickly an object's velocity changes over time.\n * Acceleration = (Final velocity - Initial velocity) / Time taken\n * a = (vf - v0)/t.\n * Distance = Initial velocity * time + (acceleration * time^2) / 2\n * It also has a magnitude and direction, and can be represented as a vector.\n * When the direction is negative ----> it's a \"slowdown\" movement\n */\nexport type Acceleration = Vector2;\n\n/**\n * Gravity is the force that attracts two objects with mass toward each other.\n * Newton's law of universal gravitation formula:\n * Gravitational force = (Gravitational constant * Mass of object 1 * Mass of object 2) / Distance between objects^2\n * It also has a magnitude and direction, and can be represented as a vector.\n * magnitude = the strength of the gravitational force\n * direction = the direction in which the force is acting (the direction of the gravitational force is always toward the center of mass of the objects involved)\n */\nexport type Gravity = Vector2;\n\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};", "import * as vector from './main/linear-algebra/vector';\nimport * as matrix from './main/linear-algebra/matrix';\nimport * as matrixTransformations from './main/linear-algebra/matrix-transformations';\nimport * as format from './main/format';\nimport * as angle from './main/angle';\nimport * as random from './main/random';\nimport * as other from './main/other';\nimport * as convert from './main/convert';\nimport * as bezierCurve from './main/bezier-curves/bezier-curve';\nimport * as equations from './main/equations/linear-equations';\nimport * as pathMovement from './main/path-movement';\nimport * as color from './main/color';\nimport * as physics from './main/physics';\nimport * as id from './main/id';\nimport * as derivative from './main/derivative';\nimport * as collisions from './main/collision-detection';\nimport * as animation from './main/animation';\nimport * as circleEllipse from './main/circle-ellipse';\nimport * as sequence from './main/sequence';\nimport * as statistics from './main/statistics';\nimport * as ml from './main/ml';\nimport * as series from './main/series';\n\nconst api = {\n ...vector,\n ...matrix,\n ...matrixTransformations,\n ...format,\n ...angle,\n ...random,\n ...other,\n ...convert,\n ...bezierCurve,\n ...equations,\n ...pathMovement,\n ...color,\n ...physics,\n ...id,\n ...derivative,\n ...collisions,\n ...animation,\n ...circleEllipse,\n ...sequence,\n ...statistics,\n ...ml,\n ...series,\n};\n\ndeclare global {\n interface Window {\n mzMath: typeof api,\n }\n}\n\nwindow.mzMath = window.mzMath || api;\n\nexport * from './main/linear-algebra/vector';\nexport * from './main/linear-algebra/matrix';\nexport * from './main/linear-algebra/matrix-transformations';\nexport * from './main/format';\nexport * from './main/angle';\nexport * from './main/random';\nexport * from './main/other';\nexport * from './main/convert';\nexport * from './main/bezier-curves/bezier-curve';\nexport * from './main/equations/linear-equations';\nexport * from './main/path-movement';\nexport * from './main/color';\nexport * from './main/physics';\nexport * from './main/id';\nexport * from './main/derivative';\nexport * from './main/collision-detection';\nexport * from './main/animation';\nexport * from './main/circle-ellipse';\nexport * from './main/sequence';\nexport * from './main/statistics';\nexport * from './main/ml';\nexport * from './main/series';"], - "mappings": "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", - "names": ["vector_exports", "__export", "v2", "v2Distance", "v2DivideScalar", "v2DotProduct", "v2FromPolarCoords", "v2GetNormal", "v2Length", "v2MulScalar", "v2Normalize", "v2SetLength", "v2Sub", "v2Sum", "v3", "v3CrossProduct", "v3Distance", "v3DivideScalar", "v3DotProduct", "v3Length", "v3MulScalar", "v3Normalize", "v3Sub", "v3Sum", "v4", "vDistance", "vDivideScalar", "vDotProduct", "vEqual", "vLength", "vMulScalar", "vN", "vNormalize", "vSub", "vSum", "format_exports", "__export", "setDecimalPlaces", "setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "angle_exports", "__export", "degreesToRadians", "getAnglesDistance", "getAnglesSub", "getV2Angle", "getV2AngleBetween", "getV2AngleInEllipse", "getV3AngleBetween", "getVNAngleBetween", "isAngleBetween", "isClockwise", "percentToAngle", "radiansToDegrees", "setV2Angle", "other_exports", "__export", "convertRange", "doRangesOverlap", "isNumber", "mod", "polarToCartesian", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "matrix_exports", "__export", "identity2", "identity3", "identity4", "identityN", "isSingularMatrix", "m2Adjugate", "m2AppendRow", "m2DeepCopy", "m2Determinant", "m2DivideScalar", "m2Inverse", "m2MulScalar", "m2PrependRow", "m2Reset", "m2Sub", "m2Sum", "m2Transpose", "m2x2", "m3Adjugate", "m3AppendRow", "m3DeepCopy", "m3Determinant", "m3DivideScalar", "m3Inverse", "m3MulScalar", "m3PrependRow", "m3Reset", "m3Sub", "m3Sum", "m3Transpose", "m3x3", "m4x4", "mAdjugate", "mAppendCol", "mAppendRow", "mDeepCopy", "mDelFirstColumn", "mDelFirstRow", "mDelLastColumn", "mDelLastRow", "mDeterminant", "mDivideScalar", "mEqual", "mGetColumn", "mGetFirstColumn", "mGetLastColumn", "mInverse", "mMinor", "mMul", "mMulScalar", "mMulVector", "mNxM", "mPrependCol", "mPrependRow", "mReset", "mSub", "mSum", "mTranspose", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "matrix_transformations_exports", "__export", "m2ReflectionOrigin", "m2ReflectionOriginH", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m2ReflectionYmX", "m2RotateAroundPointH", "m2Rotation", "m2RotationAroundPointH", "m2RotationH", "m2Scale", "m2ScaleAtPointH", "m2ScaleAtPointHMatrix", "m2ScaleH", "m2ScaleX", "m2ScaleXH", "m2ScaleY", "m2ScaleYH", "m2ShearingX", "m2ShearingY", "m2ToCSS", "m2Translation", "m2TranslationH", "m2hToCSS", "m2hToCSS3d", "m3ReflectionOrigin", "m3ReflectionOriginH", "m3ReflectionXY", "m3ReflectionXYH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionYZ", "m3ReflectionYZH", "m3RotationX", "m3RotationXH", "m3RotationY", "m3RotationYH", "m3RotationZ", "m3RotationZH", "m3Scale", "m3ScaleH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m3Translation", "m3TranslationH", "m3hToCSS3d", "v2Rotate", "v2RotateH", "v2Scale", "v3RotateX", "v3RotateY", "v3RotateZ", "v3Scale", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "random_exports", "__export", "getRandom", "getRandomBoolean", "getRandomInt", "getRandomItemFromArray", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "convert_exports", "__export", "stringToNumber", "value", "defaultNumber", "_a", "res", "bezier_curve_exports", "__export", "v2CubicBezierBBox", "v2CubicBezierCurve", "v2CubicBezierCurveExtrema", "v2CubicBezierCurveNormal", "v2CubicBezierCurveTangent", "v2QuadraticBezierBBox", "v2QuadraticBezierCurve", "v2QuadraticBezierCurveExtrema", "v2QuadraticBezierCurveNormal", "v2QuadraticBezierCurveTangent", "v3CubicBezierCurve", "v3CubicBezierCurveTangent", "v3QuadraticBezierCurve", "v3QuadraticBezierCurveTangent", "derivative_exports", "__export", "dxArcCos", "dxArcCot", "dxArcSin", "dxArcTan", "dxCos", "dxCot", "dxPolynomial", "dxSin", "dxTan", "dxV2CubicBezierCurve", "dxV2QuadraticBezierCurve", "dxV3CubicBezierCurve", "dxV3QuadraticBezierCurve", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linear_equations_exports", "__export", "getLinearEquationBy2Points", "linearEquation", "linearEquationSystem2", "linearEquationSystem3", "linearEquationSystemN", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "path_movement_exports", "__export", "circleMovement", "circleMovementAfterMouse", "ellipseMovement", "ellipseMovementAfterMouse", "lissajousCurve", "sineWaveMovement", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "color_exports", "__export", "getColorsDelta", "getRandomGrayscaleHSLColor", "getRandomHSLColor", "getRandomHSLColorWithHue", "getRandomHSLColorWithLightness", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithinRanges", "getRandomHexColor", "getRandomRGBColor", "getShiftedHue", "getShiftedLightness", "getShiftedSaturation", "hexToRgb", "hslToHex", "hslToRgb", "labToRgb", "rgbToHex", "rgbToHsl", "rgbToLab", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "x", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "physics_exports", "id_exports", "__export", "guid", "newId", "c", "collision_detection_exports", "__export", "circleCollide", "convexPolygonsCollide", "rectCollide", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animation_exports", "__export", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "circle_ellipse_exports", "__export", "getCircleCircumference", "getEllipseCircumference", "getSquareInCircleSide", "isAngleInCircleArc", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "sequence_exports", "__export", "arithmeticSequenceSum", "naturalNumbersSequenceSum", "n", "a", "d", "statistics_exports", "__export", "getArithmeticMean", "getArithmeticMeanFromFrequency", "getMedian", "getMode", "getStandardDeviation", "getVariance", "getVariance1", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "ml_exports", "__export", "mlNormalizeArray", "mlNormalizeTestData", "mlNormalizeUnseenData", "mlNormalizeValue", "mlStandardizeArray", "mlStandardizeTestData", "mlStandardizeUnseenData", "mlStandardizeValue", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "series_exports", "__export", "naturalNumbersSum1ToN", "naturalNumbersSumMToN", "n", "m", "api", "__spreadValues", "vector_exports", "matrix_exports", "matrix_transformations_exports", "format_exports", "angle_exports", "random_exports", "other_exports", "convert_exports", "bezier_curve_exports", "linear_equations_exports", "path_movement_exports", "color_exports", "physics_exports", "id_exports", "derivative_exports", "collision_detection_exports", "animation_exports", "circle_ellipse_exports", "sequence_exports", "statistics_exports", "ml_exports", "series_exports"] + "sources": ["../src/main/linear-algebra/vector.ts", "../src/main/format.ts", "../src/main/angle.ts", "../src/main/other.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/physics.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts", "../src/main/combinatorics/factorial.ts", "../src/main/combinatorics/combinatorics.ts", "../src/index.ts"], + "sourcesContent": ["import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "import { Vector2 } from '../types';\n\n/**\n * Speed = how far something moves in a given amount of time.\n * Speed is also a vector:\n * magnitude = distance\n * direction = time\n */\nexport type Speed = Vector2;\n\n/**\n * Velocity is a measure of how fast an object is moving in a particular direction.\n * Velocity = Distance traveled / Time taken\n * It has a magnitude and direction, and can be represented as a vector.\n */\nexport type Velocity = Vector2;\n\n/**\n * Acceleration is a measure of how quickly an object's velocity changes over time.\n * Acceleration = (Final velocity - Initial velocity) / Time taken\n * a = (vf - v0)/t.\n * Distance = Initial velocity * time + (acceleration * time^2) / 2\n * It also has a magnitude and direction, and can be represented as a vector.\n * When the direction is negative ----> it's a \"slowdown\" movement\n */\nexport type Acceleration = Vector2;\n\n/**\n * Gravity is the force that attracts two objects with mass toward each other.\n * Newton's law of universal gravitation formula:\n * Gravitational force = (Gravitational constant * Mass of object 1 * Mass of object 2) / Distance between objects^2\n * It also has a magnitude and direction, and can be represented as a vector.\n * magnitude = the strength of the gravitational force\n * direction = the direction in which the force is acting (the direction of the gravitational force is always toward the center of mass of the objects involved)\n */\nexport type Gravity = Vector2;\n\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};", "/**\n * The simplest and straightforward method\n * but can become inefficient for extremely large numbers\n * due to growing computational time.\n */\nexport const factorialIterative = (n: number, start = 0): number => {\n\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n let result = 1;\n for (let i = start; i <= n; i++) {\n result *= i;\n }\n return result;\n};\n\n/**\n * A recursive approach is a classic method for calculating factorials\n * but can lead to stack overflow errors\n * for very large inputs because of deep recursion.\n * However, it's a direct translation\n * of the mathematical definition of factorial.\n */\nexport const factorialRecursive = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n // Base case: when n reaches start, return start instead of further reducing\n if (n === start) return start;\n\n // Recursive call\n return n * factorialRecursive(n - 1, start);\n};\n\n/**\n * Memoization (Top-Down Dynamic Programming).\n */\nexport const factorialMemoized = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n const memo = new Map();\n\n const traverse = (num: number, end: number): number => {\n if (num < end) return 1; // Adjust the base case to return 1 if we're below 'end'\n // if (num === 0) return 1;\n\n if (memo.has(num)) return memo.get(num) ?? 1;\n\n if (num === end) {\n memo.set(num, num);\n return num;\n }\n\n const result = num * traverse(num - 1, end);\n\n memo.set(num, result);\n\n return result;\n };\n\n return traverse(n, start);\n};\n\n/**\n * Tabulation (Bottom-Up Dynamic Programming).\n */\nexport const factorial = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === n) {\n return n === 0 ? 1 : n; // If start == n and n == 0, return 1 (0!), otherwise return n\n }\n\n if (start === 0) {\n start = 1;\n }\n\n const table = []; // new Array(n + 1);\n table[0] = 1;\n for (let i = 1; i <= n; i++) {\n table[i] = table[i - 1] * i;\n }\n return table[n] / table[start - 1];\n};", "/**\n * Order doesn't matter.\n */\n/*\nexport const combinations = (n: number) => {\n\n};\n*/\n\n/**\n * Order does matter.\n * A Permutation is an ordered Combination.\n */\n/*\nexport const permutations = (n: number, isRepetitionAllowed: boolean) => {\n if(isRepetitionAllowed) {\n // n!\n }\n};*/\n\n/**\n * Permutations with repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - repetition is allowed\n *\n * Formula:\n * --------\n * n^r\n *\n * Intuition:\n * ----------\n * In other words, there are n possibilities for the first choice,\n * THEN there are n possibilities for the second choice, and so on,\n * multiplying each time.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n/**\n * Permutations without repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - no repetitions\n *\n * Formula:\n * --------\n * P(n,r) = n! / (n \u2212 r)!\n *\n * Intuition:\n * ----------\n * In this case, we have to reduce the number of available choices each time.\n * After choosing, say, number \"14\" we can't choose it again.\n * So, our first choice has 16 possibilities, and our next choice has 15 possibilities,\n * then 14, 13, 12, 11, ... etc.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithoutRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n", "import * as vector from './main/linear-algebra/vector';\nimport * as matrix from './main/linear-algebra/matrix';\nimport * as matrixTransformations from './main/linear-algebra/matrix-transformations';\nimport * as format from './main/format';\nimport * as angle from './main/angle';\nimport * as random from './main/random';\nimport * as other from './main/other';\nimport * as convert from './main/convert';\nimport * as bezierCurve from './main/bezier-curves/bezier-curve';\nimport * as equations from './main/equations/linear-equations';\nimport * as pathMovement from './main/path-movement';\nimport * as color from './main/color';\nimport * as physics from './main/physics';\nimport * as id from './main/id';\nimport * as derivative from './main/derivative';\nimport * as collisions from './main/collision-detection';\nimport * as animation from './main/animation';\nimport * as circleEllipse from './main/circle-ellipse';\nimport * as sequence from './main/sequence';\nimport * as statistics from './main/statistics';\nimport * as ml from './main/ml';\nimport * as series from './main/series';\nimport * as factorial from './main/combinatorics/factorial';\nimport * as combinatorics from './main/combinatorics/combinatorics';\n\nconst api = {\n ...vector,\n ...matrix,\n ...matrixTransformations,\n ...format,\n ...angle,\n ...random,\n ...other,\n ...convert,\n ...bezierCurve,\n ...equations,\n ...pathMovement,\n ...color,\n ...physics,\n ...id,\n ...derivative,\n ...collisions,\n ...animation,\n ...circleEllipse,\n ...sequence,\n ...statistics,\n ...ml,\n ...series,\n ...factorial,\n ...combinatorics,\n};\n\ndeclare global {\n interface Window {\n mzMath: typeof api,\n }\n}\n\nwindow.mzMath = window.mzMath || api;\n\nexport * from './main/linear-algebra/vector';\nexport * from './main/linear-algebra/matrix';\nexport * from './main/linear-algebra/matrix-transformations';\nexport * from './main/format';\nexport * from './main/angle';\nexport * from './main/random';\nexport * from './main/other';\nexport * from './main/convert';\nexport * from './main/bezier-curves/bezier-curve';\nexport * from './main/equations/linear-equations';\nexport * from './main/path-movement';\nexport * from './main/color';\nexport * from './main/physics';\nexport * from './main/id';\nexport * from './main/derivative';\nexport * from './main/collision-detection';\nexport * from './main/animation';\nexport * from './main/circle-ellipse';\nexport * from './main/sequence';\nexport * from './main/statistics';\nexport * from './main/ml';\nexport * from './main/series';\nexport * from './main/combinatorics/factorial';\nexport * from './main/combinatorics/combinatorics';"], + "mappings": "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", + "names": ["vector_exports", "__export", "v2", "v2Distance", "v2DivideScalar", "v2DotProduct", "v2FromPolarCoords", "v2GetNormal", "v2Length", "v2MulScalar", "v2Normalize", "v2SetLength", "v2Sub", "v2Sum", "v3", "v3CrossProduct", "v3Distance", "v3DivideScalar", "v3DotProduct", "v3Length", "v3MulScalar", "v3Normalize", "v3Sub", "v3Sum", "v4", "vDistance", "vDivideScalar", "vDotProduct", "vEqual", "vLength", "vMulScalar", "vN", "vNormalize", "vSub", "vSum", "format_exports", "__export", "setDecimalPlaces", "setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "angle_exports", "__export", "degreesToRadians", "getAnglesDistance", "getAnglesSub", "getV2Angle", "getV2AngleBetween", "getV2AngleInEllipse", "getV3AngleBetween", "getVNAngleBetween", "isAngleBetween", "isClockwise", "percentToAngle", "radiansToDegrees", "setV2Angle", "other_exports", "__export", "convertRange", "doRangesOverlap", "isNumber", "mod", "polarToCartesian", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "matrix_exports", "__export", "identity2", "identity3", "identity4", "identityN", "isSingularMatrix", "m2Adjugate", "m2AppendRow", "m2DeepCopy", "m2Determinant", "m2DivideScalar", "m2Inverse", "m2MulScalar", "m2PrependRow", "m2Reset", "m2Sub", "m2Sum", "m2Transpose", "m2x2", "m3Adjugate", "m3AppendRow", "m3DeepCopy", "m3Determinant", "m3DivideScalar", "m3Inverse", "m3MulScalar", "m3PrependRow", "m3Reset", "m3Sub", "m3Sum", "m3Transpose", "m3x3", "m4x4", "mAdjugate", "mAppendCol", "mAppendRow", "mDeepCopy", "mDelFirstColumn", "mDelFirstRow", "mDelLastColumn", "mDelLastRow", "mDeterminant", "mDivideScalar", "mEqual", "mGetColumn", "mGetFirstColumn", "mGetLastColumn", "mInverse", "mMinor", "mMul", "mMulScalar", "mMulVector", "mNxM", "mPrependCol", "mPrependRow", "mReset", "mSub", "mSum", "mTranspose", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "matrix_transformations_exports", "__export", "m2ReflectionOrigin", "m2ReflectionOriginH", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m2ReflectionYmX", "m2RotateAroundPointH", "m2Rotation", "m2RotationAroundPointH", "m2RotationH", "m2Scale", "m2ScaleAtPointH", "m2ScaleAtPointHMatrix", "m2ScaleH", "m2ScaleX", "m2ScaleXH", "m2ScaleY", "m2ScaleYH", "m2ShearingX", "m2ShearingY", "m2ToCSS", "m2Translation", "m2TranslationH", "m2hToCSS", "m2hToCSS3d", "m3ReflectionOrigin", "m3ReflectionOriginH", "m3ReflectionXY", "m3ReflectionXYH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionYZ", "m3ReflectionYZH", "m3RotationX", "m3RotationXH", "m3RotationY", "m3RotationYH", "m3RotationZ", "m3RotationZH", "m3Scale", "m3ScaleH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m3Translation", "m3TranslationH", "m3hToCSS3d", "v2Rotate", "v2RotateH", "v2Scale", "v3RotateX", "v3RotateY", "v3RotateZ", "v3Scale", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "random_exports", "__export", "getRandom", "getRandomBoolean", "getRandomInt", "getRandomItemFromArray", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "convert_exports", "__export", "stringToNumber", "value", "defaultNumber", "_a", "res", "bezier_curve_exports", "__export", "v2CubicBezierBBox", "v2CubicBezierCurve", "v2CubicBezierCurveExtrema", "v2CubicBezierCurveNormal", "v2CubicBezierCurveTangent", "v2QuadraticBezierBBox", "v2QuadraticBezierCurve", "v2QuadraticBezierCurveExtrema", "v2QuadraticBezierCurveNormal", "v2QuadraticBezierCurveTangent", "v3CubicBezierCurve", "v3CubicBezierCurveTangent", "v3QuadraticBezierCurve", "v3QuadraticBezierCurveTangent", "derivative_exports", "__export", "dxArcCos", "dxArcCot", "dxArcSin", "dxArcTan", "dxCos", "dxCot", "dxPolynomial", "dxSin", "dxTan", "dxV2CubicBezierCurve", "dxV2QuadraticBezierCurve", "dxV3CubicBezierCurve", "dxV3QuadraticBezierCurve", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linear_equations_exports", "__export", "getLinearEquationBy2Points", "linearEquation", "linearEquationSystem2", "linearEquationSystem3", "linearEquationSystemN", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "path_movement_exports", "__export", "circleMovement", "circleMovementAfterMouse", "ellipseMovement", "ellipseMovementAfterMouse", "lissajousCurve", "sineWaveMovement", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "color_exports", "__export", "getColorsDelta", "getRandomGrayscaleHSLColor", "getRandomHSLColor", "getRandomHSLColorWithHue", "getRandomHSLColorWithLightness", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithinRanges", "getRandomHexColor", "getRandomRGBColor", "getShiftedHue", "getShiftedLightness", "getShiftedSaturation", "hexToRgb", "hslToHex", "hslToRgb", "labToRgb", "rgbToHex", "rgbToHsl", "rgbToLab", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "x", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "physics_exports", "id_exports", "__export", "guid", "newId", "c", "collision_detection_exports", "__export", "circleCollide", "convexPolygonsCollide", "rectCollide", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animation_exports", "__export", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "circle_ellipse_exports", "__export", "getCircleCircumference", "getEllipseCircumference", "getSquareInCircleSide", "isAngleInCircleArc", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "sequence_exports", "__export", "arithmeticSequenceSum", "naturalNumbersSequenceSum", "n", "a", "d", "statistics_exports", "__export", "getArithmeticMean", "getArithmeticMeanFromFrequency", "getMedian", "getMode", "getStandardDeviation", "getVariance", "getVariance1", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "ml_exports", "__export", "mlNormalizeArray", "mlNormalizeTestData", "mlNormalizeUnseenData", "mlNormalizeValue", "mlStandardizeArray", "mlStandardizeTestData", "mlStandardizeUnseenData", "mlStandardizeValue", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "series_exports", "__export", "naturalNumbersSum1ToN", "naturalNumbersSumMToN", "n", "m", "factorial_exports", "__export", "factorial", "factorialIterative", "factorialMemoized", "factorialRecursive", "n", "start", "result", "i", "memo", "traverse", "num", "end", "_a", "table", "combinatorics_exports", "__export", "permutationsWithRepetition", "permutationsWithoutRepetition", "permutationsWithRepetition", "n", "__pow", "permutationsWithoutRepetition", "api", "__spreadValues", "vector_exports", "matrix_exports", "matrix_transformations_exports", "format_exports", "angle_exports", "random_exports", "other_exports", "convert_exports", "bezier_curve_exports", "linear_equations_exports", "path_movement_exports", "color_exports", "physics_exports", "id_exports", "derivative_exports", "collision_detection_exports", "animation_exports", "circle_ellipse_exports", "sequence_exports", "statistics_exports", "ml_exports", "series_exports", "factorial_exports", "combinatorics_exports"] } diff --git a/dist/mz-math.node.cjs b/dist/mz-math.node.cjs index 20f4836..334f731 100644 --- a/dist/mz-math.node.cjs +++ b/dist/mz-math.node.cjs @@ -5,10 +5,10 @@ https://github.com/mzusin/mz-math Licensed GPLv3 for open source use, or Commercial License for commercial use - https://github.com/mzusin/index/blob/main/LICENSE.md Copyright (c) 2023-present, Miriam Zusin */ -var _=Object.defineProperty;var ur=Object.getOwnPropertyDescriptor;var xr=Object.getOwnPropertyNames;var mr=Object.prototype.hasOwnProperty;var b=Math.pow;var ar=(t,r)=>{for(var e in r)_(t,e,{get:r[e],enumerable:!0})},fr=(t,r,e,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of xr(r))!mr.call(t,o)&&o!==e&&_(t,o,{get:()=>r[o],enumerable:!(n=ur(r,o))||n.enumerable});return t};var pr=t=>fr(_({},"__esModule",{value:!0}),t);var Lo={};ar(Lo,{animate:()=>po,arithmeticSequenceSum:()=>yo,circleCollide:()=>ao,circleMovement:()=>Wt,circleMovementAfterMouse:()=>Yn,convertRange:()=>j,convexPolygonsCollide:()=>fo,degreesToRadians:()=>lr,doRangesOverlap:()=>Mr,dxArcCos:()=>Rn,dxArcCot:()=>zn,dxArcSin:()=>Sn,dxArcTan:()=>wn,dxCos:()=>dn,dxCot:()=>gn,dxPolynomial:()=>yn,dxSin:()=>In,dxTan:()=>vn,dxV2CubicBezierCurve:()=>yt,dxV2QuadraticBezierCurve:()=>Vt,dxV3CubicBezierCurve:()=>It,dxV3QuadraticBezierCurve:()=>lt,ellipseMovement:()=>Ut,ellipseMovementAfterMouse:()=>Gn,getAnglesDistance:()=>Bt,getAnglesSub:()=>k,getArithmeticMean:()=>G,getArithmeticMeanFromFrequency:()=>Io,getCircleCircumference:()=>Mo,getColorsDelta:()=>so,getEllipseCircumference:()=>bo,getLinearEquationBy2Points:()=>Ln,getMedian:()=>vo,getMode:()=>go,getRandom:()=>V,getRandomBoolean:()=>hn,getRandomGrayscaleHSLColor:()=>Wn,getRandomHSLColor:()=>St,getRandomHSLColorWithHue:()=>Qn,getRandomHSLColorWithLightness:()=>_n,getRandomHSLColorWithSaturation:()=>Zn,getRandomHSLColorWithinRanges:()=>Un,getRandomHexColor:()=>Fn,getRandomInt:()=>Ot,getRandomItemFromArray:()=>Vn,getRandomRGBColor:()=>kn,getShiftedHue:()=>oo,getShiftedLightness:()=>io,getShiftedSaturation:()=>co,getSquareInCircleSide:()=>Vo,getStandardDeviation:()=>Rt,getV2Angle:()=>B,getV2AngleBetween:()=>yr,getV2AngleInEllipse:()=>hr,getV3AngleBetween:()=>Ir,getVNAngleBetween:()=>Tt,getVariance:()=>er,getVariance1:()=>So,guid:()=>uo,hexToRgb:()=>eo,hslToHex:()=>Pt,hslToRgb:()=>Jt,identity2:()=>te,identity3:()=>re,identity4:()=>ee,identityN:()=>ne,isAngleBetween:()=>dr,isAngleInCircleArc:()=>ho,isClockwise:()=>U,isNumber:()=>H,isSingularMatrix:()=>de,labToRgb:()=>no,linearEquation:()=>E,linearEquationSystem2:()=>Hn,linearEquationSystem3:()=>Tn,linearEquationSystemN:()=>Bn,lissajousCurve:()=>jn,m2Adjugate:()=>ft,m2AppendRow:()=>se,m2DeepCopy:()=>ct,m2Determinant:()=>at,m2DivideScalar:()=>$t,m2Inverse:()=>Mt,m2MulScalar:()=>jr,m2PrependRow:()=>me,m2ReflectionOrigin:()=>Je,m2ReflectionOriginH:()=>Pe,m2ReflectionX:()=>nn,m2ReflectionXH:()=>on,m2ReflectionY:()=>cn,m2ReflectionYH:()=>sn,m2ReflectionYmX:()=>en,m2Reset:()=>_r,m2RotateAroundPointH:()=>Te,m2Rotation:()=>Et,m2RotationAroundPointH:()=>qt,m2RotationH:()=>ht,m2Scale:()=>Xt,m2ScaleAtPointH:()=>De,m2ScaleAtPointHMatrix:()=>Dt,m2ScaleH:()=>Yt,m2ScaleX:()=>Oe,m2ScaleXH:()=>je,m2ScaleY:()=>Ue,m2ScaleYH:()=>Ke,m2ShearingX:()=>bn,m2ShearingY:()=>Mn,m2Sub:()=>Gr,m2Sum:()=>Xr,m2ToCSS:()=>ve,m2Translation:()=>we,m2TranslationH:()=>Y,m2Transpose:()=>Qr,m2hToCSS:()=>ge,m2hToCSS3d:()=>Se,m2x2:()=>Ur,m3Adjugate:()=>Ie,m3AppendRow:()=>ue,m3DeepCopy:()=>st,m3Determinant:()=>ye,m3DivideScalar:()=>Fr,m3Inverse:()=>bt,m3MulScalar:()=>kr,m3PrependRow:()=>ae,m3ReflectionOrigin:()=>tn,m3ReflectionOriginH:()=>rn,m3ReflectionXY:()=>fn,m3ReflectionXYH:()=>pn,m3ReflectionXZ:()=>mn,m3ReflectionXZH:()=>an,m3ReflectionYZ:()=>un,m3ReflectionYZH:()=>xn,m3Reset:()=>Wr,m3RotationX:()=>At,m3RotationXH:()=>$e,m3RotationY:()=>Nt,m3RotationYH:()=>qe,m3RotationZ:()=>Ct,m3RotationZH:()=>Ne,m3Scale:()=>Gt,m3ScaleH:()=>Ye,m3ScaleX:()=>ke,m3ScaleXH:()=>Fe,m3ScaleY:()=>Qe,m3ScaleYH:()=>Ze,m3ScaleZ:()=>_e,m3ScaleZH:()=>We,m3Sub:()=>Or,m3Sum:()=>Yr,m3Translation:()=>ze,m3TranslationH:()=>He,m3Transpose:()=>Zr,m3hToCSS3d:()=>Re,m3x3:()=>Kr,m4x4:()=>Jr,mAdjugate:()=>pt,mAppendCol:()=>oe,mAppendRow:()=>ce,mDeepCopy:()=>y,mDelFirstColumn:()=>Me,mDelFirstRow:()=>pe,mDelLastColumn:()=>ut,mDelLastRow:()=>fe,mDeterminant:()=>X,mDivideScalar:()=>Q,mEqual:()=>Ve,mGetColumn:()=>he,mGetFirstColumn:()=>be,mGetLastColumn:()=>xt,mInverse:()=>Z,mMinor:()=>mt,mMul:()=>$,mMulScalar:()=>ot,mMulVector:()=>h,mNxM:()=>Pr,mPrependCol:()=>ie,mPrependRow:()=>xe,mReset:()=>it,mSub:()=>nt,mSum:()=>et,mTranspose:()=>D,mlNormalizeArray:()=>wt,mlNormalizeTestData:()=>Ro,mlNormalizeUnseenData:()=>wo,mlNormalizeValue:()=>nr,mlStandardizeArray:()=>zt,mlStandardizeTestData:()=>zo,mlStandardizeUnseenData:()=>Ho,mlStandardizeValue:()=>or,mod:()=>l,naturalNumbersSequenceSum:()=>lo,naturalNumbersSum1ToN:()=>To,naturalNumbersSumMToN:()=>Bo,newId:()=>xo,percentToAngle:()=>vr,polarToCartesian:()=>br,radiansToDegrees:()=>Vr,rectCollide:()=>mo,rgbToHex:()=>ro,rgbToHsl:()=>to,rgbToLab:()=>gt,setDecimalPlaces:()=>s,setV2Angle:()=>W,sineWaveMovement:()=>On,stringToNumber:()=>ln,v2:()=>Ar,v2CubicBezierBBox:()=>Xn,v2CubicBezierCurve:()=>kt,v2CubicBezierCurveExtrema:()=>_t,v2CubicBezierCurveNormal:()=>Cn,v2CubicBezierCurveTangent:()=>Qt,v2Distance:()=>Lr,v2DivideScalar:()=>zr,v2DotProduct:()=>J,v2FromPolarCoords:()=>Dr,v2GetNormal:()=>rt,v2Length:()=>K,v2MulScalar:()=>wr,v2Normalize:()=>L,v2QuadraticBezierBBox:()=>Dn,v2QuadraticBezierCurve:()=>jt,v2QuadraticBezierCurveExtrema:()=>Zt,v2QuadraticBezierCurveNormal:()=>Nn,v2QuadraticBezierCurveTangent:()=>Ft,v2Rotate:()=>Be,v2RotateH:()=>Le,v2Scale:()=>Xe,v2SetLength:()=>Lt,v2Sub:()=>R,v2Sum:()=>gr,v3:()=>Nr,v3CrossProduct:()=>qr,v3CubicBezierCurve:()=>En,v3CubicBezierCurveTangent:()=>An,v3Distance:()=>$r,v3DivideScalar:()=>Hr,v3DotProduct:()=>Er,v3Length:()=>Tr,v3MulScalar:()=>F,v3Normalize:()=>v,v3QuadraticBezierCurve:()=>$n,v3QuadraticBezierCurveTangent:()=>qn,v3RotateX:()=>Ee,v3RotateY:()=>Ae,v3RotateZ:()=>Ce,v3Scale:()=>Ge,v3Sub:()=>Rr,v3Sum:()=>Sr,v4:()=>Cr,vDistance:()=>Br,vDivideScalar:()=>C,vDotProduct:()=>S,vEqual:()=>tt,vLength:()=>w,vMulScalar:()=>N,vN:()=>P,vNormalize:()=>T,vSub:()=>d,vSum:()=>A});module.exports=pr(Lo);var s=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=b(10,r);return Math.round(t*e)/e};var l=(t,r)=>(t%r+r)%r,j=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,Mr=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),H=t=>!isNaN(parseFloat(t))&&isFinite(t),br=(t,r,e,n=1/0)=>{let[o,i]=t,[c,u]=r;return[s(o+c*Math.cos(e),n),s(i+u*Math.sin(e),n)]};var B=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return s(e,r)},hr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return s(n,e)},W=(t,r,e=1/0)=>{let n=K(t);return[s(Math.cos(r)*n,e),s(Math.sin(r)*n,e)]},Vr=(t,r=1/0)=>{let e=t*(180/Math.PI);return s(e,r)},lr=(t,r=1/0)=>{let e=t*(Math.PI/180);return s(e,r)},Tt=(t,r,e=1/0)=>{let n=T(t),o=T(r),i=S(n,o),c=Math.acos(i);return s(c,e)},yr=(t,r,e=1/0)=>{let n=d(t,r),o=Math.atan2(n[1],n[0]);return s(o,e)},Ir=(t,r,e=1/0)=>Tt(t,r,e),dr=(t,r,e)=>{let n=k(r,e),o=k(r,t),i=k(e,t),c=o+i;return Math.abs(c-n)<=.001},U=(t,r,e=0)=>(t=t%360,r=r%360,t=t),k=(t,r,e=1/0)=>{let n=Math.abs(l(t,360)-l(r,360));return s(n<=180?n:360-n,e)},Bt=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=Bt(r,e,n);return U(r,e,n)?l(n+t*o/100,360):l(n-t*o/100,360)};var A=(t,r,e=1/0)=>{let n=[];for(let o=0;oA(t,r,e),Sr=(t,r,e=1/0)=>A(t,r,e),d=(t,r,e=1/0)=>{let n=[];for(let o=0;od(t,r,e),Rr=(t,r,e=1/0)=>d(t,r,e),N=(t,r,e=1/0)=>{let n=[];for(let o=0;oN(t,r,e),F=(t,r,e=1/0)=>N(t,r,e),C=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oC(t,r,e),Hr=(t,r,e=1/0)=>C(t,r,e),w=(t,r=1/0)=>{let e=0;for(let n=0;nw(t,r),Tr=(t,r=1/0)=>w(t,r),Lt=(t,r,e=1/0)=>{let n=B(t);return[s(Math.cos(n)*r,e),s(Math.sin(n)*r,e)]},Br=(t,r,e=1/0)=>{let n=d(t,r);return w(n,e)},Lr=(t,r,e=1/0)=>{let n=d(t,r);return w(n,e)},$r=(t,r,e=1/0)=>{let n=d(t,r);return w(n,e)},T=(t,r=1/0)=>{let e=w(t),n=[];for(let o=0;oT(t,r),v=(t,r=1/0)=>T(t,r),S=(t,r,e=1/0)=>{let n=0;for(let o=0;oS(t,r,e),Er=(t,r,e=1/0)=>S(t,r,e),qr=(t,r,e=1/0)=>[s(t[1]*r[2]-t[2]*r[1],e),s(t[2]*r[0]-t[0]*r[2],e),s(t[0]*r[1]-t[1]*r[0],e)],Ar=(t=0)=>[t,t],Nr=(t=0)=>[t,t,t],Cr=(t=0)=>[t,t,t,t],P=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=Lt(e,t),W(e,r)},tt=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=R(r,t);return[-s(n[1],e),s(n[0],e)]};var et=(t,r,e=1/0)=>{let n=[];for(let o=0;oet(t,r,e),Yr=(t,r,e=1/0)=>et(t,r,e),nt=(t,r,e=1/0)=>{let n=[];for(let o=0;ont(t,r,e),Or=(t,r,e=1/0)=>nt(t,r,e),ot=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(N(o,r,e));return n},jr=(t,r,e=1/0)=>ot(t,r,e),kr=(t,r,e=1/0)=>ot(t,r,e),Q=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(C(o,r,e));return n},$t=(t,r,e=1/0)=>Q(t,r,e),Fr=(t,r,e=1/0)=>Q(t,r,e),D=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oD(t),Zr=t=>D(t),it=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nit(t,r),Wr=(t,r=0)=>it(t,r),Ur=(t=0)=>[[t,t],[t,t]],Kr=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],Jr=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],Pr=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],re=()=>[[1,0,0],[0,1,0],[0,0,1]],ee=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],ne=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;ey(t),st=t=>y(t),oe=(t,r)=>{if(t.length<=0)return[];let e=y(t);for(let n=0;n{if(t.length<=0)return[];let e=y(t);for(let n=0;n{let e=y(t);return e.push(r),e},se=(t,r)=>{let e=ct(t);return e.push(r),e},ue=(t,r)=>{let e=st(t);return e.push(r),e},xe=(t,r)=>{let e=y(t);return e.unshift(r),e},me=(t,r)=>{let e=ct(t);return e.unshift(r),e},ae=(t,r)=>{let e=st(t);return e.unshift(r),e},fe=t=>{if(t.length<=0)return[];let r=y(t);return r.pop(),r},pe=t=>{if(t.length<=0)return[];let r=y(t);return r.shift(),r},ut=t=>{if(t.length<=0)return[];let r=y(t);for(let e=0;e{if(t.length<=0)return[];let r=y(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=le(t,r,e);return X(o)},X=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return at(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},ye=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return X(t)},ft=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},Ie=t=>pt(t),pt=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return ft(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return X(t)===0},Mt=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=at(t);if(e===0)return null;let n=ft(t);return n===null?null:$t(n,e,r)},bt=(t,r=1/0)=>Z(t,r),Z=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=X(t),o=pt(t);return o===null?null:Q(o,n,r)};var ve=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},ge=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${c})`},Se=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${c}, 0, 1)`},Re=t=>`matrix3d( +var W=Object.defineProperty;var xr=Object.getOwnPropertyDescriptor;var mr=Object.getOwnPropertyNames;var ar=Object.prototype.hasOwnProperty;var h=Math.pow;var fr=(t,r)=>{for(var e in r)W(t,e,{get:r[e],enumerable:!0})},pr=(t,r,e,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let o of mr(r))!ar.call(t,o)&&o!==e&&W(t,o,{get:()=>r[o],enumerable:!(n=xr(r,o))||n.enumerable});return t};var br=t=>pr(W({},"__esModule",{value:!0}),t);var Co={};fr(Co,{animate:()=>bo,arithmeticSequenceSum:()=>Io,circleCollide:()=>fo,circleMovement:()=>_t,circleMovementAfterMouse:()=>Gn,convertRange:()=>j,convexPolygonsCollide:()=>po,degreesToRadians:()=>yr,doRangesOverlap:()=>hr,dxArcCos:()=>Rn,dxArcCot:()=>Bn,dxArcSin:()=>wn,dxArcTan:()=>zn,dxCos:()=>gn,dxCot:()=>Sn,dxPolynomial:()=>dn,dxSin:()=>In,dxTan:()=>vn,dxV2CubicBezierCurve:()=>yt,dxV2QuadraticBezierCurve:()=>Vt,dxV3CubicBezierCurve:()=>dt,dxV3QuadraticBezierCurve:()=>lt,ellipseMovement:()=>Ut,ellipseMovementAfterMouse:()=>On,factorial:()=>$o,factorialIterative:()=>Lo,factorialMemoized:()=>No,factorialRecursive:()=>ir,getAnglesDistance:()=>Tt,getAnglesSub:()=>F,getArithmeticMean:()=>G,getArithmeticMeanFromFrequency:()=>go,getCircleCircumference:()=>ho,getColorsDelta:()=>uo,getEllipseCircumference:()=>Mo,getLinearEquationBy2Points:()=>Ln,getMedian:()=>vo,getMode:()=>So,getRandom:()=>V,getRandomBoolean:()=>Vn,getRandomGrayscaleHSLColor:()=>Un,getRandomHSLColor:()=>St,getRandomHSLColorWithHue:()=>Zn,getRandomHSLColorWithLightness:()=>_n,getRandomHSLColorWithSaturation:()=>Wn,getRandomHSLColorWithinRanges:()=>Kn,getRandomHexColor:()=>Qn,getRandomInt:()=>Ot,getRandomItemFromArray:()=>ln,getRandomRGBColor:()=>kn,getShiftedHue:()=>io,getShiftedLightness:()=>co,getShiftedSaturation:()=>so,getSquareInCircleSide:()=>lo,getStandardDeviation:()=>wt,getV2Angle:()=>T,getV2AngleBetween:()=>dr,getV2AngleInEllipse:()=>Vr,getV3AngleBetween:()=>Ir,getVNAngleBetween:()=>Ht,getVariance:()=>er,getVariance1:()=>wo,guid:()=>xo,hexToRgb:()=>no,hslToHex:()=>Pt,hslToRgb:()=>Jt,identity2:()=>re,identity3:()=>ee,identity4:()=>ne,identityN:()=>oe,isAngleBetween:()=>gr,isAngleInCircleArc:()=>Vo,isClockwise:()=>U,isNumber:()=>B,isSingularMatrix:()=>ge,labToRgb:()=>oo,linearEquation:()=>N,linearEquationSystem2:()=>Hn,linearEquationSystem3:()=>Tn,linearEquationSystemN:()=>En,lissajousCurve:()=>Fn,m2Adjugate:()=>ft,m2AppendRow:()=>ue,m2DeepCopy:()=>ct,m2Determinant:()=>at,m2DivideScalar:()=>Lt,m2Inverse:()=>bt,m2MulScalar:()=>Fr,m2PrependRow:()=>ae,m2ReflectionOrigin:()=>Pe,m2ReflectionOriginH:()=>tn,m2ReflectionX:()=>on,m2ReflectionXH:()=>cn,m2ReflectionY:()=>sn,m2ReflectionYH:()=>un,m2ReflectionYmX:()=>nn,m2Reset:()=>_r,m2RotateAroundPointH:()=>Te,m2Rotation:()=>Nt,m2RotationAroundPointH:()=>$t,m2RotationH:()=>Mt,m2Scale:()=>Xt,m2ScaleAtPointH:()=>Xe,m2ScaleAtPointHMatrix:()=>Dt,m2ScaleH:()=>Yt,m2ScaleX:()=>je,m2ScaleXH:()=>Fe,m2ScaleY:()=>Ke,m2ScaleYH:()=>Je,m2ShearingX:()=>Mn,m2ShearingY:()=>hn,m2Sub:()=>Or,m2Sum:()=>Yr,m2ToCSS:()=>ve,m2Translation:()=>ze,m2TranslationH:()=>Y,m2Transpose:()=>Zr,m2hToCSS:()=>Se,m2hToCSS3d:()=>we,m2x2:()=>Kr,m3Adjugate:()=>Ie,m3AppendRow:()=>xe,m3DeepCopy:()=>st,m3Determinant:()=>de,m3DivideScalar:()=>Qr,m3Inverse:()=>ht,m3MulScalar:()=>kr,m3PrependRow:()=>fe,m3ReflectionOrigin:()=>rn,m3ReflectionOriginH:()=>en,m3ReflectionXY:()=>pn,m3ReflectionXYH:()=>bn,m3ReflectionXZ:()=>an,m3ReflectionXZH:()=>fn,m3ReflectionYZ:()=>xn,m3ReflectionYZH:()=>mn,m3Reset:()=>Ur,m3RotationX:()=>qt,m3RotationXH:()=>Ne,m3RotationY:()=>At,m3RotationYH:()=>qe,m3RotationZ:()=>Ct,m3RotationZH:()=>Ce,m3Scale:()=>Gt,m3ScaleH:()=>Ge,m3ScaleX:()=>ke,m3ScaleXH:()=>Qe,m3ScaleY:()=>Ze,m3ScaleYH:()=>We,m3ScaleZ:()=>_e,m3ScaleZH:()=>Ue,m3Sub:()=>jr,m3Sum:()=>Gr,m3Translation:()=>Be,m3TranslationH:()=>He,m3Transpose:()=>Wr,m3hToCSS3d:()=>Re,m3x3:()=>Jr,m4x4:()=>Pr,mAdjugate:()=>pt,mAppendCol:()=>ie,mAppendRow:()=>se,mDeepCopy:()=>y,mDelFirstColumn:()=>he,mDelFirstRow:()=>be,mDelLastColumn:()=>ut,mDelLastRow:()=>pe,mDeterminant:()=>X,mDivideScalar:()=>Q,mEqual:()=>le,mGetColumn:()=>Ve,mGetFirstColumn:()=>Me,mGetLastColumn:()=>xt,mInverse:()=>Z,mMinor:()=>mt,mMul:()=>L,mMulScalar:()=>ot,mMulVector:()=>M,mNxM:()=>te,mPrependCol:()=>ce,mPrependRow:()=>me,mReset:()=>it,mSub:()=>nt,mSum:()=>et,mTranspose:()=>D,mlNormalizeArray:()=>Rt,mlNormalizeTestData:()=>Ro,mlNormalizeUnseenData:()=>zo,mlNormalizeValue:()=>nr,mlStandardizeArray:()=>zt,mlStandardizeTestData:()=>Bo,mlStandardizeUnseenData:()=>Ho,mlStandardizeValue:()=>or,mod:()=>l,naturalNumbersSequenceSum:()=>yo,naturalNumbersSum1ToN:()=>To,naturalNumbersSumMToN:()=>Eo,newId:()=>mo,percentToAngle:()=>vr,permutationsWithRepetition:()=>qo,permutationsWithoutRepetition:()=>Ao,polarToCartesian:()=>Mr,radiansToDegrees:()=>lr,rectCollide:()=>ao,rgbToHex:()=>eo,rgbToHsl:()=>ro,rgbToLab:()=>vt,setDecimalPlaces:()=>s,setV2Angle:()=>_,sineWaveMovement:()=>jn,stringToNumber:()=>yn,v2:()=>Ar,v2CubicBezierBBox:()=>Yn,v2CubicBezierCurve:()=>Ft,v2CubicBezierCurveExtrema:()=>Wt,v2CubicBezierCurveNormal:()=>Dn,v2CubicBezierCurveTangent:()=>Qt,v2Distance:()=>Lr,v2DivideScalar:()=>Br,v2DotProduct:()=>J,v2FromPolarCoords:()=>Xr,v2GetNormal:()=>rt,v2Length:()=>K,v2MulScalar:()=>zr,v2Normalize:()=>E,v2QuadraticBezierBBox:()=>Xn,v2QuadraticBezierCurve:()=>jt,v2QuadraticBezierCurveExtrema:()=>Zt,v2QuadraticBezierCurveNormal:()=>Cn,v2QuadraticBezierCurveTangent:()=>kt,v2Rotate:()=>Ee,v2RotateH:()=>Le,v2Scale:()=>Ye,v2SetLength:()=>Et,v2Sub:()=>w,v2Sum:()=>Sr,v3:()=>Cr,v3CrossProduct:()=>qr,v3CubicBezierCurve:()=>$n,v3CubicBezierCurveTangent:()=>An,v3Distance:()=>Nr,v3DivideScalar:()=>Hr,v3DotProduct:()=>$r,v3Length:()=>Tr,v3MulScalar:()=>k,v3Normalize:()=>g,v3QuadraticBezierCurve:()=>Nn,v3QuadraticBezierCurveTangent:()=>qn,v3RotateX:()=>$e,v3RotateY:()=>Ae,v3RotateZ:()=>De,v3Scale:()=>Oe,v3Sub:()=>Rr,v3Sum:()=>wr,v4:()=>Dr,vDistance:()=>Er,vDivideScalar:()=>C,vDotProduct:()=>S,vEqual:()=>tt,vLength:()=>R,vMulScalar:()=>A,vN:()=>P,vNormalize:()=>H,vSub:()=>I,vSum:()=>q});module.exports=br(Co);var s=(t,r=1/0)=>{if(r===1/0)return t;r<0&&(r=0);let e=h(10,r);return Math.round(t*e)/e};var l=(t,r)=>(t%r+r)%r,j=(t,r,e,n,o)=>(o-n)*(t-r)/(e-r)+n,hr=(t,r,e,n)=>Math.max(t,e)<=Math.min(r,n),B=t=>!isNaN(parseFloat(t))&&isFinite(t),Mr=(t,r,e,n=1/0)=>{let[o,i]=t,[c,u]=r;return[s(o+c*Math.cos(e),n),s(i+u*Math.sin(e),n)]};var T=(t,r=1/0)=>{let e=Math.atan2(t[1],t[0]);return s(e,r)},Vr=(t,r,e=1/0)=>{let n=Math.atan2(t[1]/r[1],t[0]/r[0]);return s(n,e)},_=(t,r,e=1/0)=>{let n=K(t);return[s(Math.cos(r)*n,e),s(Math.sin(r)*n,e)]},lr=(t,r=1/0)=>{let e=t*(180/Math.PI);return s(e,r)},yr=(t,r=1/0)=>{let e=t*(Math.PI/180);return s(e,r)},Ht=(t,r,e=1/0)=>{let n=H(t),o=H(r),i=S(n,o),c=Math.acos(i);return s(c,e)},dr=(t,r,e=1/0)=>{let n=I(t,r),o=Math.atan2(n[1],n[0]);return s(o,e)},Ir=(t,r,e=1/0)=>Ht(t,r,e),gr=(t,r,e)=>{let n=F(r,e),o=F(r,t),i=F(e,t),c=o+i;return Math.abs(c-n)<=.001},U=(t,r,e=0)=>(t=t%360,r=r%360,t=t),F=(t,r,e=1/0)=>{let n=Math.abs(l(t,360)-l(r,360));return s(n<=180?n:360-n,e)},Tt=(t,r,e=0,n=1/0)=>(t=t%360,r=r%360,t{t<0&&(t=0),t>100&&(t=100);let o=Tt(r,e,n);return U(r,e,n)?l(n+t*o/100,360):l(n-t*o/100,360)};var q=(t,r,e=1/0)=>{let n=[];for(let o=0;oq(t,r,e),wr=(t,r,e=1/0)=>q(t,r,e),I=(t,r,e=1/0)=>{let n=[];for(let o=0;oI(t,r,e),Rr=(t,r,e=1/0)=>I(t,r,e),A=(t,r,e=1/0)=>{let n=[];for(let o=0;oA(t,r,e),k=(t,r,e=1/0)=>A(t,r,e),C=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o=0;oC(t,r,e),Hr=(t,r,e=1/0)=>C(t,r,e),R=(t,r=1/0)=>{let e=0;for(let n=0;nR(t,r),Tr=(t,r=1/0)=>R(t,r),Et=(t,r,e=1/0)=>{let n=T(t);return[s(Math.cos(n)*r,e),s(Math.sin(n)*r,e)]},Er=(t,r,e=1/0)=>{let n=I(t,r);return R(n,e)},Lr=(t,r,e=1/0)=>{let n=I(t,r);return R(n,e)},Nr=(t,r,e=1/0)=>{let n=I(t,r);return R(n,e)},H=(t,r=1/0)=>{let e=R(t),n=[];for(let o=0;oH(t,r),g=(t,r=1/0)=>H(t,r),S=(t,r,e=1/0)=>{let n=0;for(let o=0;oS(t,r,e),$r=(t,r,e=1/0)=>S(t,r,e),qr=(t,r,e=1/0)=>[s(t[1]*r[2]-t[2]*r[1],e),s(t[2]*r[0]-t[0]*r[2],e),s(t[0]*r[1]-t[1]*r[0],e)],Ar=(t=0)=>[t,t],Cr=(t=0)=>[t,t,t],Dr=(t=0)=>[t,t,t,t],P=(t,r=0)=>{if(t<0)throw new Error("N must be a non-negative number.");let e=[];for(let n=0;n{let e=[0,0];return e=Et(e,t),_(e,r)},tt=(t,r)=>{if(t.length!==r.length)return!1;for(let e=0;e{let n=w(r,t);return[-s(n[1],e),s(n[0],e)]};var et=(t,r,e=1/0)=>{let n=[];for(let o=0;oet(t,r,e),Gr=(t,r,e=1/0)=>et(t,r,e),nt=(t,r,e=1/0)=>{let n=[];for(let o=0;ont(t,r,e),jr=(t,r,e=1/0)=>nt(t,r,e),ot=(t,r,e=1/0)=>{let n=[];for(let o of t)n.push(A(o,r,e));return n},Fr=(t,r,e=1/0)=>ot(t,r,e),kr=(t,r,e=1/0)=>ot(t,r,e),Q=(t,r,e=1/0)=>{if(r===0)throw new Error("Division by zero error.");let n=[];for(let o of t)n.push(C(o,r,e));return n},Lt=(t,r,e=1/0)=>Q(t,r,e),Qr=(t,r,e=1/0)=>Q(t,r,e),D=t=>{let r=t.length;if(r<=0)return t;let e=t[0].length;if(e<=0)return t;let n=[];for(let o=0;oD(t),Wr=t=>D(t),it=(t,r=0)=>{if(t.length<=0)return[];let e=[];for(let n=0;nit(t,r),Ur=(t,r=0)=>it(t,r),Kr=(t=0)=>[[t,t],[t,t]],Jr=(t=0)=>[[t,t,t],[t,t,t],[t,t,t]],Pr=(t=0)=>[[t,t,t,t],[t,t,t,t],[t,t,t,t],[t,t,t,t]],te=(t,r,e=0)=>{if(t<=0||r<=0)throw new Error("M and N must be positive numbers.");let n=[];for(let o=0;o[[1,0],[0,1]],ee=()=>[[1,0,0],[0,1,0],[0,0,1]],ne=()=>[[1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],oe=t=>{if(t<0)throw new Error("N must be a non-negative number.");if(t===0)return[];let r=[];for(let e=0;e{let r=[];for(let e=0;ey(t),st=t=>y(t),ie=(t,r)=>{if(t.length<=0)return[];let e=y(t);for(let n=0;n{if(t.length<=0)return[];let e=y(t);for(let n=0;n{let e=y(t);return e.push(r),e},ue=(t,r)=>{let e=ct(t);return e.push(r),e},xe=(t,r)=>{let e=st(t);return e.push(r),e},me=(t,r)=>{let e=y(t);return e.unshift(r),e},ae=(t,r)=>{let e=ct(t);return e.unshift(r),e},fe=(t,r)=>{let e=st(t);return e.unshift(r),e},pe=t=>{if(t.length<=0)return[];let r=y(t);return r.pop(),r},be=t=>{if(t.length<=0)return[];let r=y(t);return r.shift(),r},ut=t=>{if(t.length<=0)return[];let r=y(t);for(let e=0;e{if(t.length<=0)return[];let r=y(t);for(let e=0;e{if(t.length<=0)return[];let r=[];for(let e=0;e{if(t.length<=0)return[];let r=t[0].length,e=[];for(let n=0;n{if(t.length<=0)return[];let e=[];for(let n=0;n{let n=[];for(let i=0;i{if(t.length<0)return[];if(t[0].length!==r.length)throw new Error("The number of columns in the matrix must be equal to the length of the vector.");let n=[];for(let o=0;o{if(t.length!==r.length)return!1;for(let e=0;e{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=[];for(let i=0;i{let n=t.length;if(n<=0)throw new Error("The matrix should not be empty.");if(n!==t[0].length)throw new Error("The matrix must be square.");let o=ye(t,r,e);return X(o)},X=t=>{let r=t.length;if(r===0)return 1;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t[0][0];if(r===2)return at(t);let e=0;for(let n=0;n{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return t[0][0]*t[1][1]-t[1][0]*t[0][1]},de=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return X(t)},ft=t=>{if(t.length!==t[0].length)throw new Error("The matrix must be square.");return[[t[1][1],-t[0][1]],[-t[1][0],t[0][0]]]},Ie=t=>pt(t),pt=t=>{let r=t.length;if(r<=0)return null;if(r!==t[0].length)throw new Error("The matrix must be square.");if(r===1)return t;if(r===2)return ft(t);let e=[];for(let n=0;n{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");return X(t)===0},bt=(t,r=1/0)=>{if(t.length>0&&t.length!==t[0].length)throw new Error("The matrix must be square.");let e=at(t);if(e===0)return null;let n=ft(t);return n===null?null:Lt(n,e,r)},ht=(t,r=1/0)=>Z(t,r),Z=(t,r=1/0)=>{let e=t.length;if(e>0&&e!==t[0].length)throw new Error("The matrix must be square.");let n=X(t),o=pt(t);return o===null?null:Q(o,n,r)};var ve=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1];return`matrix(${r}, ${e}, ${n}, ${o}, 0, 0)`},Se=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix(${r}, ${e}, ${n}, ${o}, ${i}, ${c})`},we=t=>{let r=t[0][0],e=t[1][0],n=t[0][1],o=t[1][1],i=t[0][2],c=t[1][2];return`matrix3d(${r}, ${e}, 0, 0, ${n}, ${o}, 0, 0, 0, 0, 1, 0, ${i}, ${c}, 0, 1)`},Re=t=>`matrix3d( ${t[0][0]}, ${t[0][1]}, ${t[0][2]}, ${t[0][3]}, ${t[1][0]}, ${t[1][1]}, ${t[1][2]}, ${t[1][3]}, ${t[2][0]}, ${t[2][1]}, ${t[2][2]}, ${t[2][3]}, ${t[3][0]}, ${t[3][1]}, ${t[3][2]}, ${t[3][3]} - )`,we=(t,r=1/0)=>[[1,0],[0,1],[s(t[0],r),s(t[1],r)]],ze=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[s(t[0],r),s(t[1],r),s(t[2],r)]],Y=(t,r=1/0)=>[[1,0,s(t[0],r)],[0,1,s(t[1],r)],[0,0,1]],He=(t,r=1/0)=>[[1,0,0,s(t[0],r)],[0,1,0,s(t[1],r)],[0,0,1,s(t[2],r)],[0,0,0,1]],Et=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},ht=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},qt=(t,r,e=!0,n=1/0)=>{let o=Y(r,n),i=ht(t,e,n),c=Y(F(r,-1),n),u=$(o,i);return $(u,c)},Te=(t,r,e,n=!0,o=1/0)=>{let i=qt(t,r,n,o);return h(i,e)},Be=(t,r,e=!0,n=1/0)=>{let o=L(r);return h(Et(t,e,n),o)},Le=(t,r,e=!0,n=1/0)=>{let o=v(r);return h(ht(t,e,n),o)},At=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},$e=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},Ee=(t,r,e=!0,n=1/0)=>{let o=v(r);return h(At(t,e,n),o)},Nt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},qe=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},Ae=(t,r,e=!0,n=1/0)=>{let o=v(r);return h(Nt(t,e,n),o)},Ct=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},Ne=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},Ce=(t,r,e=!0,n=1/0)=>{let o=v(r);return h(Ct(t,e,n),o)},Dt=(t,r,e=1/0)=>{let n=Y(r,e),o=Yt(t),i=Y(F(r,-1),e),c=$(n,o);return $(c,i)},De=(t,r,e,n=1/0)=>{let o=Dt(t,r,n);return h(o,e)},Xt=t=>[[t[0],0],[0,t[1]]],Xe=(t,r)=>h(Xt(t),r),Yt=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],Gt=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],Ye=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],Ge=(t,r)=>h(Gt(t),r),Oe=t=>[[t,0],[0,1]],je=t=>[[t,0,0],[0,1,0],[0,0,1]],ke=t=>[[t,0,0],[0,1,0],[0,0,1]],Fe=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],Qe=t=>[[1,0,0],[0,t,0],[0,0,1]],Ze=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],_e=t=>[[1,0,0],[0,1,0],[0,0,t]],We=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],Ue=t=>[[1,0],[0,t]],Ke=t=>[[1,0,0],[0,t,0],[0,0,1]],Je=()=>[[-1,0],[0,-1]],Pe=()=>[[-1,0,0],[0,-1,0],[0,0,1]],tn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],rn=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],en=()=>[[0,-1],[-1,0]],nn=()=>[[1,0],[0,-1]],on=()=>[[1,0,0],[0,-1,0],[0,0,1]],cn=()=>[[-1,0],[0,1]],sn=()=>[[-1,0,0],[0,1,0],[0,0,1]],un=()=>[[-1,0,0],[0,1,0],[0,0,1]],xn=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],mn=()=>[[1,0,0],[0,-1,0],[0,0,1]],an=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],fn=()=>[[1,0,0],[0,1,0],[0,0,-1]],pn=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],Mn=t=>[[1,t],[0,1]],bn=t=>[[1,0],[t,1]];var V=(t,r,e=1/0)=>s(Math.random()*(r-t)+t,e),Ot=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),hn=()=>Math.random()<.5,Vn=t=>{let r=Ot(0,t.length-1);return t[r]};var ln=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var yn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],c=o[1];n+=i*c*Math.pow(t,c-1)}return s(n,e)},Vt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},lt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},yt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},It=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},In=(t,r=1/0)=>s(Math.cos(t),r),dn=(t,r=1/0)=>s(-Math.sin(t),r),vn=(t,r=1/0)=>s(1/b(Math.cos(t),2),r),gn=(t,r=1/0)=>s(-1/b(Math.sin(t),2),r),Sn=(t,r=1/0)=>s(1/Math.sqrt(1-b(t,2)),r),Rn=(t,r=1/0)=>s(-1/Math.sqrt(1-b(t,2)),r),wn=(t,r=1/0)=>s(1/(1+b(t,2)),r),zn=(t,r=1/0)=>s(-1/(1+b(t,2)),r);var E=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:s(i/e,r)},Hn=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=Mt(n);if(o===null)return null;let i=[t[2],r[2]];return h(o,i,e)},Tn=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=bt(o);if(i===null)return null;let c=[t[3],r[3],e[3]];return h(i,c,n)},Bn=(t,r=1/0)=>{if(t.length<=0)return null;let e=ut(t),n=Z(e);if(n===null)return null;let o=xt(t);return h(n,o,r)},Ln=(t,r)=>{let[e,n]=R(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let c=n/e,u=i-c*o,x="";return c===0?x=`y = ${u}`:(x=`y = ${c===1?"":c}x`,u!==0&&(x+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:c,xIntercept:void 0,yIntercept:u,formula:x}};var dt=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=E([n,o,i],r);return H(f)?[f]:[]}let c=o-i,u=n*n-4*e*c;if(u<0)return[];if(u===0)return[s(-n/(2*e),r)];let x=2*e,m=Math.sqrt(u);return[s((-n+m)/x,r),s((-n-m)/x,r)]};var jt=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},$n=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},kt=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},En=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},Ft=(t,r,e,n,o=1/0)=>{let i=Vt(t,r,e,n);return L(i,o)},qn=(t,r,e,n,o=1/0)=>{let i=lt(t,r,e,n);return v(i,o)},Qt=(t,r,e,n,o,i=1/0)=>{let c=yt(t,r,e,n,o);return L(c,i)},An=(t,r,e,n,o,i=1/0)=>{let c=It(t,r,e,n,o);return v(c,i)},Nn=(t,r,e,n,o=1/0)=>{let i=Ft(t,r,e,n,o);return[-i[1],i[0]]},Cn=(t,r,e,n,o,i=1/0)=>{let c=Qt(t,r,e,n,o,i);return[-c[1],c[0]]},Zt=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=E([o,i,0],n),x=2*t[1]-4*r[1]+2*e[1],m=-2*t[1]+2*r[1],p=E([x,m,0],n),a=[];return H(u)&&a.push(u),H(p)&&a.push(p),a},_t=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],c=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],x=[i,c,u,0],m=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],a=[m,f,p,0],M=dt(x,o).filter(I=>I>=0&&I<=1),g=dt(a,o).filter(I=>I>=0&&I<=1);return[...M,...g].length===2?[...M,...g]:null},Dn=(t,r,e,n=1/0)=>{let o=Zt(t,r,e),i=1/0,c=1/0,u=-1/0,x=-1/0;for(let m of o){let f=jt(m,t,r,e),p=f[0],a=f[1];i=Math.min(i,p),u=Math.max(u,p),c=Math.min(c,a),x=Math.max(x,a)}return i=s(Math.min(i,t[0],e[0]),n),u=s(Math.max(u,t[0],e[0]),n),c=s(Math.min(c,t[1],e[1]),n),x=s(Math.max(x,t[1],e[1]),n),{x:i,y:c,w:Math.abs(u-i),h:Math.abs(x-c),x2:u,y2:x}},Xn=(t,r,e,n,o=1/0)=>{let i=_t(t,r,e,n)||[],c=1/0,u=1/0,x=-1/0,m=-1/0;for(let f of i){let p=kt(f,t,r,e,n),a=p[0],M=p[1];c=Math.min(c,a!=null?a:1/0),x=Math.max(x,a!=null?a:-1/0),u=Math.min(u,M!=null?M:1/0),m=Math.max(m,M!=null?M:-1/0)}return c=s(Math.min(c,t[0],n[0]),o),x=s(Math.max(x,t[0],n[0]),o),u=s(Math.min(u,t[1],n[1]),o),m=s(Math.max(m,t[1],n[1]),o),{x:c,y:u,w:Math.abs(x-c),h:Math.abs(m-u),x2:x,y2:m}};var Wt=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),Yn=(t,r,e)=>{let n=R(t,r),o=B(n);return o=j(o,0,Math.PI*2,0,Math.PI),Wt(r,o,e)},Ut=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),Gn=(t,r,e)=>{let n=R(t,r),o=B(n);return o=j(o,0,Math.PI*2,0,Math.PI),Ut(r,o,e[0],e[1])},On=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},jn=(t,r,e,n,o,i,c)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-c)];var kn=()=>{let t=St();return Jt(t)},Fn=()=>{let t=St();return Pt(t)},St=()=>{let t=V(1,360),r=V(0,100),e=V(0,100);return[t,r,e]},Qn=t=>{let r=V(0,100),e=V(0,100);return[t,r,e]},Zn=t=>{let r=V(1,360),e=V(0,100);return[r,t,e]},_n=t=>{let r=V(1,360),e=V(0,100);return[r,e,t]},Wn=()=>[0,0,V(0,100)],Un=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let c=V(t,r),u=V(e,n),x=V(o,i);return[c,u,x]},Kn=t=>(t*=60,t<0&&(t+=360),t),Jn=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,c=0;return o===t&&(c=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),Pn=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?Kt(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),to=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),c=Math.max(e,n,o),u=Kt(e,n,o,i,c),x=Pn(e,n,o,i,c,u),m=Jn(e,n,o,i,c);return m>360||x>100||u>100?[0,0,100]:m<0||x<0||u<0?[0,0,0]:[s(m,r),s(x,r),s(u,r)]},vt=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),Jt=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let M=o*255;return[M,M,M]}let i=o<.5?o*(1+n):o+n-o*n,c=2*o-i,u=e+.333,x=e,m=e-.333,f=vt(i,c,u),p=vt(i,c,x),a=vt(i,c,m);return f*=255,p*=255,a*=255,f>255||p>255||a>255?[255,255,255]:f<0||p<0||a<0?[0,0,0]:[s(f,r),s(p,r),s(a,r)]},Pt=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,c;if(e===0)o=i=c=n;else{let x=(p,a,M)=>(M<0&&(M+=1),M>1&&(M-=1),M<.16666666666666666?p+(a-p)*6*M:M<.5?a:M<.6666666666666666?p+(a-p)*(.6666666666666666-M)*6:p),m=n<.5?n*(1+e):n+e-n*e,f=2*n-m;o=x(f,m,r+1/3),i=x(f,m,r),c=x(f,m,r-1/3)}let u=x=>{let m=Math.round(x*255).toString(16);return m.length===1?"0"+m:m};return`#${u(o)}${u(i)}${u(c)}`},ro=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},eo=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,x,m,f)=>x+x+m+m+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),c=parseInt(n[3],16);return[o,i,c]},gt=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,c=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,c=c>.008856?Math.pow(c,1/3):7.787*c+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[s(116*c-16,r),s(500*(i-c),r),s(200*(c-u),r)]},no=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,c=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,c=c>.0031308?1.055*Math.pow(c,1/2.4)-.055:12.92*c,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[s(Math.max(0,Math.min(1,i))*255,r),s(Math.max(0,Math.min(1,c))*255,r),s(Math.max(0,Math.min(1,u))*255,r)]},oo=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=l(e,360)),[e,t[1],t[2]]},io=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=l(e,100)),[t[0],t[1],e]},co=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},so=(t,r,e=1/0)=>{let n=gt(t,e),o=gt(r,e),i=n[0]-o[0],c=n[1]-o[1],u=n[2]-o[2],x=Math.sqrt(n[1]*n[1]+n[2]*n[2]),m=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=x-m,p=c*c+u*u-f*f;p=p<0?0:Math.sqrt(p);let a=1+.045*x,M=1+.015*x,g=i/1,q=f/a,I=p/M,O=g*g+q*q+I*I;return O<0?0:Math.sqrt(O)};var uo=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),xo=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var mo=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,ao=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},tr=t=>{let r=[];for(let e=0;e{let e=[];e.push(...tr(t)),e.push(...tr(r));for(let n of e){let o=rt(n[0],n[1]),i=rr(t,o),c=rr(r,o);if(!(i.max>=c.min&&c.max>=i.min))return!1}return!0},rr=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=J(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var po=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,c=!1,u,x=()=>{e=void 0,o=void 0,i=void 0,c=!1,n!==void 0&&window.cancelAnimationFrame(n)},m=()=>{x(),g()},f=()=>{c=!1},p=()=>{c=!0},a=z=>{e===void 0&&(e=z),o=z-e,c&&i!==z&&typeof t.callback=="function"&&t.callback(Ht()),o<=r?(i=z,n=window.requestAnimationFrame(a)):x()},M=(z,sr)=>{m(),typeof t.resizeCallback=="function"&&t.resizeCallback(z,sr)},g=()=>{e=void 0,o=void 0,i=void 0,c=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(M),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(a)},q=()=>o,I=()=>c,O=()=>e,ir=()=>{if(!(r===1/0||o===void 0))return o*100/r},cr=()=>u,Ht=()=>({start:g,stop:x,pause:f,resume:p,restart:m,isAnimating:I,getElapsedTime:q,getStartTime:O,getPercent:ir,getResizeObserver:cr});return Ht()};var Mo=(t,r=1/0)=>s(2*Math.PI*t,r),bo=(t,r,e=1/0)=>s(2*Math.PI*Math.sqrt((b(t,2)+b(r,2))/2),e),ho=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),Vo=(t,r=1/0)=>s(t*2/Math.sqrt(2),r);var lo=t=>t*(t+1)/2,yo=(t,r,e)=>t/2*(2*r+(t-1)*e);var G=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return s(e/t.length,r)},Io=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return s(e,r)},vo=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?s((e[n]+e[n-1])/2,r):s(e[n],r)},go=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},So=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=G(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+b(i-e,2),0);return s(n/t.length,r)},er=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=G(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+b(i,2),0);return s(n/t.length-b(e,2),r)},Rt=(t,r=1/0)=>{var n;let e=(n=er(t))!=null?n:0;return s(Math.sqrt(e),r)};var nr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:s((t-r)/o,n)},wt=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=wt(t,e,n,r);return{min:s(e,r),max:s(n,r),data:o}},wo=(t,r,e,n=1/0)=>wt(t,r,e,n),or=(t,r,e,n=1/0)=>e===0?0:s((t-r)/e,n),zt=(t,r,e,n=1/0)=>[...t].map(o=>or(o,r,e,n)),zo=(t,r=1/0)=>{var i;let e=(i=G(t))!=null?i:0,n=Rt(t),o=zt(t,e,n,r);return{mean:s(e,r),stdDev:s(n,r),data:o}},Ho=(t,r,e,n=1/0)=>zt(t,r,e,n);var To=t=>t/2*(t+1),Bo=(t,r)=>(r-t+1)*(t+r)/2;0&&(module.exports={animate,arithmeticSequenceSum,circleCollide,circleMovement,circleMovementAfterMouse,convertRange,convexPolygonsCollide,degreesToRadians,doRangesOverlap,dxArcCos,dxArcCot,dxArcSin,dxArcTan,dxCos,dxCot,dxPolynomial,dxSin,dxTan,dxV2CubicBezierCurve,dxV2QuadraticBezierCurve,dxV3CubicBezierCurve,dxV3QuadraticBezierCurve,ellipseMovement,ellipseMovementAfterMouse,getAnglesDistance,getAnglesSub,getArithmeticMean,getArithmeticMeanFromFrequency,getCircleCircumference,getColorsDelta,getEllipseCircumference,getLinearEquationBy2Points,getMedian,getMode,getRandom,getRandomBoolean,getRandomGrayscaleHSLColor,getRandomHSLColor,getRandomHSLColorWithHue,getRandomHSLColorWithLightness,getRandomHSLColorWithSaturation,getRandomHSLColorWithinRanges,getRandomHexColor,getRandomInt,getRandomItemFromArray,getRandomRGBColor,getShiftedHue,getShiftedLightness,getShiftedSaturation,getSquareInCircleSide,getStandardDeviation,getV2Angle,getV2AngleBetween,getV2AngleInEllipse,getV3AngleBetween,getVNAngleBetween,getVariance,getVariance1,guid,hexToRgb,hslToHex,hslToRgb,identity2,identity3,identity4,identityN,isAngleBetween,isAngleInCircleArc,isClockwise,isNumber,isSingularMatrix,labToRgb,linearEquation,linearEquationSystem2,linearEquationSystem3,linearEquationSystemN,lissajousCurve,m2Adjugate,m2AppendRow,m2DeepCopy,m2Determinant,m2DivideScalar,m2Inverse,m2MulScalar,m2PrependRow,m2ReflectionOrigin,m2ReflectionOriginH,m2ReflectionX,m2ReflectionXH,m2ReflectionY,m2ReflectionYH,m2ReflectionYmX,m2Reset,m2RotateAroundPointH,m2Rotation,m2RotationAroundPointH,m2RotationH,m2Scale,m2ScaleAtPointH,m2ScaleAtPointHMatrix,m2ScaleH,m2ScaleX,m2ScaleXH,m2ScaleY,m2ScaleYH,m2ShearingX,m2ShearingY,m2Sub,m2Sum,m2ToCSS,m2Translation,m2TranslationH,m2Transpose,m2hToCSS,m2hToCSS3d,m2x2,m3Adjugate,m3AppendRow,m3DeepCopy,m3Determinant,m3DivideScalar,m3Inverse,m3MulScalar,m3PrependRow,m3ReflectionOrigin,m3ReflectionOriginH,m3ReflectionXY,m3ReflectionXYH,m3ReflectionXZ,m3ReflectionXZH,m3ReflectionYZ,m3ReflectionYZH,m3Reset,m3RotationX,m3RotationXH,m3RotationY,m3RotationYH,m3RotationZ,m3RotationZH,m3Scale,m3ScaleH,m3ScaleX,m3ScaleXH,m3ScaleY,m3ScaleYH,m3ScaleZ,m3ScaleZH,m3Sub,m3Sum,m3Translation,m3TranslationH,m3Transpose,m3hToCSS3d,m3x3,m4x4,mAdjugate,mAppendCol,mAppendRow,mDeepCopy,mDelFirstColumn,mDelFirstRow,mDelLastColumn,mDelLastRow,mDeterminant,mDivideScalar,mEqual,mGetColumn,mGetFirstColumn,mGetLastColumn,mInverse,mMinor,mMul,mMulScalar,mMulVector,mNxM,mPrependCol,mPrependRow,mReset,mSub,mSum,mTranspose,mlNormalizeArray,mlNormalizeTestData,mlNormalizeUnseenData,mlNormalizeValue,mlStandardizeArray,mlStandardizeTestData,mlStandardizeUnseenData,mlStandardizeValue,mod,naturalNumbersSequenceSum,naturalNumbersSum1ToN,naturalNumbersSumMToN,newId,percentToAngle,polarToCartesian,radiansToDegrees,rectCollide,rgbToHex,rgbToHsl,rgbToLab,setDecimalPlaces,setV2Angle,sineWaveMovement,stringToNumber,v2,v2CubicBezierBBox,v2CubicBezierCurve,v2CubicBezierCurveExtrema,v2CubicBezierCurveNormal,v2CubicBezierCurveTangent,v2Distance,v2DivideScalar,v2DotProduct,v2FromPolarCoords,v2GetNormal,v2Length,v2MulScalar,v2Normalize,v2QuadraticBezierBBox,v2QuadraticBezierCurve,v2QuadraticBezierCurveExtrema,v2QuadraticBezierCurveNormal,v2QuadraticBezierCurveTangent,v2Rotate,v2RotateH,v2Scale,v2SetLength,v2Sub,v2Sum,v3,v3CrossProduct,v3CubicBezierCurve,v3CubicBezierCurveTangent,v3Distance,v3DivideScalar,v3DotProduct,v3Length,v3MulScalar,v3Normalize,v3QuadraticBezierCurve,v3QuadraticBezierCurveTangent,v3RotateX,v3RotateY,v3RotateZ,v3Scale,v3Sub,v3Sum,v4,vDistance,vDivideScalar,vDotProduct,vEqual,vLength,vMulScalar,vN,vNormalize,vSub,vSum}); + )`,ze=(t,r=1/0)=>[[1,0],[0,1],[s(t[0],r),s(t[1],r)]],Be=(t,r=1/0)=>[[1,0,0],[0,1,0],[0,0,1],[s(t[0],r),s(t[1],r),s(t[2],r)]],Y=(t,r=1/0)=>[[1,0,s(t[0],r)],[0,1,s(t[1],r)],[0,0,1]],He=(t,r=1/0)=>[[1,0,0,s(t[0],r)],[0,1,0,s(t[1],r)],[0,0,1,s(t[2],r)],[0,0,0,1]],Nt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o],[o,n]]:[[n,o],[-o,n]]},Mt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},$t=(t,r,e=!0,n=1/0)=>{let o=Y(r,n),i=Mt(t,e,n),c=Y(k(r,-1),n),u=L(o,i);return L(u,c)},Te=(t,r,e,n=!0,o=1/0)=>{let i=$t(t,r,n,o);return M(i,e)},Ee=(t,r,e=!0,n=1/0)=>{let o=E(r);return M(Nt(t,e,n),o)},Le=(t,r,e=!0,n=1/0)=>{let o=g(r);return M(Mt(t,e,n),o)},qt=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0],[0,n,-o],[0,o,n]]:[[1,0,0],[0,n,o],[0,-o,n]]},Ne=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[1,0,0,0],[0,n,-o,0],[0,o,n,0],[0,0,0,1]]:[[1,0,0,0],[0,n,o,0],[0,-o,n,0],[0,0,0,1]]},$e=(t,r,e=!0,n=1/0)=>{let o=g(r);return M(qt(t,e,n),o)},At=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o],[0,1,0],[-o,0,n]]:[[n,0,-o],[0,1,0],[o,0,n]]},qe=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,0,o,0],[0,1,0,0],[-o,0,n,0],[0,0,0,1]]:[[n,0,-o,0],[0,1,0,0],[o,0,n,0],[0,0,0,1]]},Ae=(t,r,e=!0,n=1/0)=>{let o=g(r);return M(At(t,e,n),o)},Ct=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0],[o,n,0],[0,0,1]]:[[n,o,0],[-o,n,0],[0,0,1]]},Ce=(t,r=!0,e=1/0)=>{let n=s(Math.cos(t),e),o=s(Math.sin(t),e);return r?[[n,-o,0,0],[o,n,0,0],[0,0,1,0],[0,0,0,1]]:[[n,o,0,0],[-o,n,0,0],[0,0,1,0],[0,0,0,1]]},De=(t,r,e=!0,n=1/0)=>{let o=g(r);return M(Ct(t,e,n),o)},Dt=(t,r,e=1/0)=>{let n=Y(r,e),o=Yt(t),i=Y(k(r,-1),e),c=L(n,o);return L(c,i)},Xe=(t,r,e,n=1/0)=>{let o=Dt(t,r,n);return M(o,e)},Xt=t=>[[t[0],0],[0,t[1]]],Ye=(t,r)=>M(Xt(t),r),Yt=t=>[[t[0],0,0],[0,t[1],0],[0,0,1]],Gt=t=>[[t[0],0,0],[0,t[1],0],[0,0,t[2]]],Ge=t=>[[t[0],0,0,0],[0,t[1],0,0],[0,0,t[2],0],[0,0,0,1]],Oe=(t,r)=>M(Gt(t),r),je=t=>[[t,0],[0,1]],Fe=t=>[[t,0,0],[0,1,0],[0,0,1]],ke=t=>[[t,0,0],[0,1,0],[0,0,1]],Qe=t=>[[t,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],Ze=t=>[[1,0,0],[0,t,0],[0,0,1]],We=t=>[[1,0,0,0],[0,t,0,0],[0,0,1,0],[0,0,0,1]],_e=t=>[[1,0,0],[0,1,0],[0,0,t]],Ue=t=>[[1,0,0,0],[0,1,0,0],[0,0,t,0],[0,0,0,1]],Ke=t=>[[1,0],[0,t]],Je=t=>[[1,0,0],[0,t,0],[0,0,1]],Pe=()=>[[-1,0],[0,-1]],tn=()=>[[-1,0,0],[0,-1,0],[0,0,1]],rn=()=>[[-1,0,0],[0,-1,0],[0,0,-1]],en=()=>[[-1,0,0,0],[0,-1,0,0],[0,0,-1,0],[0,0,0,1]],nn=()=>[[0,-1],[-1,0]],on=()=>[[1,0],[0,-1]],cn=()=>[[1,0,0],[0,-1,0],[0,0,1]],sn=()=>[[-1,0],[0,1]],un=()=>[[-1,0,0],[0,1,0],[0,0,1]],xn=()=>[[-1,0,0],[0,1,0],[0,0,1]],mn=()=>[[-1,0,0,0],[0,1,0,0],[0,0,1,0],[0,0,0,1]],an=()=>[[1,0,0],[0,-1,0],[0,0,1]],fn=()=>[[1,0,0,0],[0,-1,0,0],[0,0,1,0],[0,0,0,1]],pn=()=>[[1,0,0],[0,1,0],[0,0,-1]],bn=()=>[[1,0,0,0],[0,1,0,0],[0,0,-1,0],[0,0,0,1]],hn=t=>[[1,t],[0,1]],Mn=t=>[[1,0],[t,1]];var V=(t,r,e=1/0)=>s(Math.random()*(r-t)+t,e),Ot=(t,r)=>Math.floor(Math.random()*(r-t+1)+t),Vn=()=>Math.random()<.5,ln=t=>{let r=Ot(0,t.length-1);return t[r]};var yn=(t,r)=>{var n;if(t==null)return r;let e=(n=Number(t))!=null?n:r;return isNaN(e)?r:e};var dn=(t,r,e=1/0)=>{let n=0;for(let o of r){if(o.length!==2)return NaN;let i=o[0],c=o[1];n+=i*c*Math.pow(t,c-1)}return s(n,e)},Vt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},lt=(t,r,e,n,o=1/0)=>{let i=-2*(1-t),c=2-4*t,u=2*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},yt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},dt=(t,r,e,n,o,i=1/0)=>{let c=-3*Math.pow(1-t,2),u=3*(t-1)*(3*t-1),x=6*t-9*t*t,m=3*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},In=(t,r=1/0)=>s(Math.cos(t),r),gn=(t,r=1/0)=>s(-Math.sin(t),r),vn=(t,r=1/0)=>s(1/h(Math.cos(t),2),r),Sn=(t,r=1/0)=>s(-1/h(Math.sin(t),2),r),wn=(t,r=1/0)=>s(1/Math.sqrt(1-h(t,2)),r),Rn=(t,r=1/0)=>s(-1/Math.sqrt(1-h(t,2)),r),zn=(t,r=1/0)=>s(1/(1+h(t,2)),r),Bn=(t,r=1/0)=>s(-1/(1+h(t,2)),r);var N=(t,r=1/0)=>{let e=t[0],n=t[1],i=t[2]-n;return e===0&&i===0?1/0:e===0?NaN:s(i/e,r)},Hn=(t,r,e=1/0)=>{let n=[[t[0],t[1]],[r[0],r[1]]],o=bt(n);if(o===null)return null;let i=[t[2],r[2]];return M(o,i,e)},Tn=(t,r,e,n=1/0)=>{let o=[[t[0],t[1],t[2]],[r[0],r[1],r[2]],[e[0],e[1],e[2]]],i=ht(o);if(i===null)return null;let c=[t[3],r[3],e[3]];return M(i,c,n)},En=(t,r=1/0)=>{if(t.length<=0)return null;let e=ut(t),n=Z(e);if(n===null)return null;let o=xt(t);return M(n,o,r)},Ln=(t,r)=>{let[e,n]=w(r,t),[o,i]=t;if(e===0)return{slope:void 0,xIntercept:o,yIntercept:void 0,formula:`x = ${o}`};let c=n/e,u=i-c*o,x="";return c===0?x=`y = ${u}`:(x=`y = ${c===1?"":c}x`,u!==0&&(x+=` ${u<0?"-":"+"} ${Math.abs(u)}`)),{slope:c,xIntercept:void 0,yIntercept:u,formula:x}};var It=(t,r=1/0)=>{let e=t[0],n=t[1],o=t[2],i=t[3];if(e===0){let f=N([n,o,i],r);return B(f)?[f]:[]}let c=o-i,u=n*n-4*e*c;if(u<0)return[];if(u===0)return[s(-n/(2*e),r)];let x=2*e,m=Math.sqrt(u);return[s((-n+m)/x,r),s((-n-m)/x,r)]};var jt=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o)]},Nn=(t,r,e,n,o=1/0)=>{let i=Math.pow(1-t,2),c=(1-t)*2*t,u=t*t;return[s(i*r[0]+c*e[0]+u*n[0],o),s(i*r[1]+c*e[1]+u*n[1],o),s(i*r[2]+c*e[2]+u*n[2],o)]},Ft=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i)]},$n=(t,r,e,n,o,i=1/0)=>{let c=Math.pow(1-t,3),u=Math.pow(1-t,2)*3*t,x=(1-t)*3*t*t,m=t*t*t;return[s(c*r[0]+u*e[0]+x*n[0]+m*o[0],i),s(c*r[1]+u*e[1]+x*n[1]+m*o[1],i),s(c*r[2]+u*e[2]+x*n[2]+m*o[2],i)]},kt=(t,r,e,n,o=1/0)=>{let i=Vt(t,r,e,n);return E(i,o)},qn=(t,r,e,n,o=1/0)=>{let i=lt(t,r,e,n);return g(i,o)},Qt=(t,r,e,n,o,i=1/0)=>{let c=yt(t,r,e,n,o);return E(c,i)},An=(t,r,e,n,o,i=1/0)=>{let c=dt(t,r,e,n,o);return g(c,i)},Cn=(t,r,e,n,o=1/0)=>{let i=kt(t,r,e,n,o);return[-i[1],i[0]]},Dn=(t,r,e,n,o,i=1/0)=>{let c=Qt(t,r,e,n,o,i);return[-c[1],c[0]]},Zt=(t,r,e,n=1/0)=>{let o=2*t[0]-4*r[0]+2*e[0],i=-2*t[0]+2*r[0],u=N([o,i,0],n),x=2*t[1]-4*r[1]+2*e[1],m=-2*t[1]+2*r[1],p=N([x,m,0],n),a=[];return B(u)&&a.push(u),B(p)&&a.push(p),a},Wt=(t,r,e,n,o=1/0)=>{let i=-3*t[0]+9*r[0]-9*e[0]+3*n[0],c=6*t[0]-12*r[0]+6*e[0],u=-3*t[0]+3*r[0],x=[i,c,u,0],m=-3*t[1]+9*r[1]-9*e[1]+3*n[1],f=6*t[1]-12*r[1]+6*e[1],p=-3*t[1]+3*r[1],a=[m,f,p,0],b=It(x,o).filter(d=>d>=0&&d<=1),v=It(a,o).filter(d=>d>=0&&d<=1);return[...b,...v].length===2?[...b,...v]:null},Xn=(t,r,e,n=1/0)=>{let o=Zt(t,r,e),i=1/0,c=1/0,u=-1/0,x=-1/0;for(let m of o){let f=jt(m,t,r,e),p=f[0],a=f[1];i=Math.min(i,p),u=Math.max(u,p),c=Math.min(c,a),x=Math.max(x,a)}return i=s(Math.min(i,t[0],e[0]),n),u=s(Math.max(u,t[0],e[0]),n),c=s(Math.min(c,t[1],e[1]),n),x=s(Math.max(x,t[1],e[1]),n),{x:i,y:c,w:Math.abs(u-i),h:Math.abs(x-c),x2:u,y2:x}},Yn=(t,r,e,n,o=1/0)=>{let i=Wt(t,r,e,n)||[],c=1/0,u=1/0,x=-1/0,m=-1/0;for(let f of i){let p=Ft(f,t,r,e,n),a=p[0],b=p[1];c=Math.min(c,a!=null?a:1/0),x=Math.max(x,a!=null?a:-1/0),u=Math.min(u,b!=null?b:1/0),m=Math.max(m,b!=null?b:-1/0)}return c=s(Math.min(c,t[0],n[0]),o),x=s(Math.max(x,t[0],n[0]),o),u=s(Math.min(u,t[1],n[1]),o),m=s(Math.max(m,t[1],n[1]),o),{x:c,y:u,w:Math.abs(x-c),h:Math.abs(m-u),x2:x,y2:m}};var _t=(t,r,e)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*e]),Gn=(t,r,e)=>{let n=w(t,r),o=T(n);return o=j(o,0,Math.PI*2,0,Math.PI),_t(r,o,e)},Ut=(t,r,e,n)=>(r=r%Math.PI*2,[t[0]+Math.cos(r)*e,t[1]+Math.sin(r)*n]),On=(t,r,e)=>{let n=w(t,r),o=T(n);return o=j(o,0,Math.PI*2,0,Math.PI),Ut(r,o,e[0],e[1])},jn=(t,r,e,n)=>{let o=r*Math.sin(2*Math.PI*e*t+n);return[t,o]},Fn=(t,r,e,n,o,i,c)=>[t*Math.cos(n*e-i),r*Math.cos(o*e-c)];var kn=()=>{let t=St();return Jt(t)},Qn=()=>{let t=St();return Pt(t)},St=()=>{let t=V(1,360),r=V(0,100),e=V(0,100);return[t,r,e]},Zn=t=>{let r=V(0,100),e=V(0,100);return[t,r,e]},Wn=t=>{let r=V(1,360),e=V(0,100);return[r,t,e]},_n=t=>{let r=V(1,360),e=V(0,100);return[r,e,t]},Un=()=>[0,0,V(0,100)],Kn=(t=1,r=360,e=0,n=100,o=0,i=100)=>{let c=V(t,r),u=V(e,n),x=V(o,i);return[c,u,x]},Jn=t=>(t*=60,t<0&&(t+=360),t),Pn=(t,r,e,n=void 0,o=void 0)=>{if(n=n===void 0?Math.min(t,r,e):n,o=o===void 0?Math.max(t,r,e):o,n===o)return 0;let i=o-n,c=0;return o===t&&(c=(r-e)/i+(r(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,(n+o)/2*100),to=(t,r,e,n=void 0,o=void 0,i=void 0)=>(n=n===void 0?Math.min(t,r,e):n,o=n===void 0?Math.max(t,r,e):o,n===o?0:(i=i===void 0?Kt(t,r,e):i,(i<=50?(o-n)/(o+n):(o-n)/(2-o-n))*100)),ro=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255,i=Math.min(e,n,o),c=Math.max(e,n,o),u=Kt(e,n,o,i,c),x=to(e,n,o,i,c,u),m=Pn(e,n,o,i,c);return m>360||x>100||u>100?[0,0,100]:m<0||x<0||u<0?[0,0,0]:[s(m,r),s(x,r),s(u,r)]},gt=(t,r,e)=>(e<0&&(e+=1),e>1&&(e-=1),e*6<1?r+(t-r)*6*e:e*2<1?t:e*3<2?r+(t-r)*(.666-e)*6:r),Jt=(t,r=1/0)=>{let e=t[0]/100,n=t[1]/100,o=t[2]/100;if(n===0){let b=o*255;return[b,b,b]}let i=o<.5?o*(1+n):o+n-o*n,c=2*o-i,u=e+.333,x=e,m=e-.333,f=gt(i,c,u),p=gt(i,c,x),a=gt(i,c,m);return f*=255,p*=255,a*=255,f>255||p>255||a>255?[255,255,255]:f<0||p<0||a<0?[0,0,0]:[s(f,r),s(p,r),s(a,r)]},Pt=t=>{if(t[0]>360||t[1]>100||t[2]>100)return"#ffffff";if(t[0]<0||t[1]<0||t[2]<0)return"#000000";let r=t[0]/360,e=t[1]/100,n=t[2]/100,o,i,c;if(e===0)o=i=c=n;else{let x=(p,a,b)=>(b<0&&(b+=1),b>1&&(b-=1),b<.16666666666666666?p+(a-p)*6*b:b<.5?a:b<.6666666666666666?p+(a-p)*(.6666666666666666-b)*6:p),m=n<.5?n*(1+e):n+e-n*e,f=2*n-m;o=x(f,m,r+1/3),i=x(f,m,r),c=x(f,m,r-1/3)}let u=x=>{let m=Math.round(x*255).toString(16);return m.length===1?"0"+m:m};return`#${u(o)}${u(i)}${u(c)}`},eo=t=>{let[r,e,n]=t;return"#"+(1<<24|r<<16|e<<8|n).toString(16).slice(1)},no=t=>{let r=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,e=t.replace(r,(u,x,m,f)=>x+x+m+m+f+f),n=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);if(!n)return null;let o=parseInt(n[1],16),i=parseInt(n[2],16),c=parseInt(n[3],16);return[o,i,c]},vt=(t,r=1/0)=>{let e=t[0]/255,n=t[1]/255,o=t[2]/255;e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92,n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92,o=o>.04045?Math.pow((o+.055)/1.055,2.4):o/12.92;let i=(e*.4124+n*.3576+o*.1805)/.95047,c=(e*.2126+n*.7152+o*.0722)/1,u=(e*.0193+n*.1192+o*.9505)/1.08883;return i=i>.008856?Math.pow(i,1/3):7.787*i+16/116,c=c>.008856?Math.pow(c,1/3):7.787*c+16/116,u=u>.008856?Math.pow(u,1/3):7.787*u+16/116,[s(116*c-16,r),s(500*(i-c),r),s(200*(c-u),r)]},oo=(t,r=1/0)=>{let e=(t[0]+16)/116,n=t[1]/500+e,o=e-t[2]/200;n=.95047*(n*n*n>.008856?n*n*n:(n-16/116)/7.787),e=1*(e*e*e>.008856?e*e*e:(e-16/116)/7.787),o=1.08883*(o*o*o>.008856?o*o*o:(o-16/116)/7.787);let i=n*3.2406+e*-1.5372+o*-.4986,c=n*-.9689+e*1.8758+o*.0415,u=n*.0557+e*-.204+o*1.057;return i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,c=c>.0031308?1.055*Math.pow(c,1/2.4)-.055:12.92*c,u=u>.0031308?1.055*Math.pow(u,1/2.4)-.055:12.92*u,[s(Math.max(0,Math.min(1,i))*255,r),s(Math.max(0,Math.min(1,c))*255,r),s(Math.max(0,Math.min(1,u))*255,r)]},io=(t,r=180)=>{let e=t[0];return e+=r,(e>360||e<0)&&(e=l(e,360)),[e,t[1],t[2]]},co=(t,r=10)=>{let e=t[2];return e+=r,(e>100||e<0)&&(e=l(e,100)),[t[0],t[1],e]},so=(t,r=10)=>{let e=t[1];return e+=r,e>100&&(e-=100),e<0&&(e+=100),[t[0],e,t[2]]},uo=(t,r,e=1/0)=>{let n=vt(t,e),o=vt(r,e),i=n[0]-o[0],c=n[1]-o[1],u=n[2]-o[2],x=Math.sqrt(n[1]*n[1]+n[2]*n[2]),m=Math.sqrt(o[1]*o[1]+o[2]*o[2]),f=x-m,p=c*c+u*u-f*f;p=p<0?0:Math.sqrt(p);let a=1+.045*x,b=1+.015*x,v=i/1,$=f/a,d=p/b,O=v*v+$*$+d*d;return O<0?0:Math.sqrt(O)};var xo=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{let r=Math.random()*16|0;return(t=="x"?r:r&3|8).toString(16)}),mo=()=>Math.random().toString(36).substring(2)+new Date().getTime().toString(36);var ao=(t,r)=>t.x<=r.x+r.w&&t.x+t.w>=r.x&&t.y<=r.y+r.h&&t.h+t.y>=r.y,fo=(t,r)=>{let e=Math.abs(t.cx-r.cx),n=Math.abs(t.cy-r.cy);return Math.sqrt(e*e+n*n)<=t.r+r.r},tr=t=>{let r=[];for(let e=0;e{let e=[];e.push(...tr(t)),e.push(...tr(r));for(let n of e){let o=rt(n[0],n[1]),i=rr(t,o),c=rr(r,o);if(!(i.max>=c.min&&c.max>=i.min))return!1}return!0},rr=(t,r)=>{let e=1/0,n=-1/0;for(let o of t){let i=J(o,r);e=Math.min(e,i),n=Math.max(n,i)}return{min:e,max:n}};var bo=t=>{let r=t.duration!==void 0?t.duration:1/0,e,n,o,i,c=!1,u,x=()=>{e=void 0,o=void 0,i=void 0,c=!1,n!==void 0&&window.cancelAnimationFrame(n)},m=()=>{x(),v()},f=()=>{c=!1},p=()=>{c=!0},a=z=>{e===void 0&&(e=z),o=z-e,c&&i!==z&&typeof t.callback=="function"&&t.callback(Bt()),o<=r?(i=z,n=window.requestAnimationFrame(a)):x()},b=(z,ur)=>{m(),typeof t.resizeCallback=="function"&&t.resizeCallback(z,ur)},v=()=>{e=void 0,o=void 0,i=void 0,c=!0,t.restartOnResize&&window.ResizeObserver&&u===void 0?(u=new ResizeObserver(b),u.observe(document.body,{box:"border-box"})):n=window.requestAnimationFrame(a)},$=()=>o,d=()=>c,O=()=>e,cr=()=>{if(!(r===1/0||o===void 0))return o*100/r},sr=()=>u,Bt=()=>({start:v,stop:x,pause:f,resume:p,restart:m,isAnimating:d,getElapsedTime:$,getStartTime:O,getPercent:cr,getResizeObserver:sr});return Bt()};var ho=(t,r=1/0)=>s(2*Math.PI*t,r),Mo=(t,r,e=1/0)=>s(2*Math.PI*Math.sqrt((h(t,2)+h(r,2))/2),e),Vo=(t,r,e)=>(t>r&&(r+=360),e>=t&&e<=r||e+360>=t&&e+360<=r),lo=(t,r=1/0)=>s(t*2/Math.sqrt(2),r);var yo=t=>t*(t+1)/2,Io=(t,r,e)=>t/2*(2*r+(t-1)*e);var G=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=t.reduce((n,o)=>n+o,0);return s(e/t.length,r)},go=(t,r=1/0)=>{let e=0;for(let[n,o]of t)e+=n*o;return s(e,r)},vo=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=[...t].sort((o,i)=>o-i),n=Math.floor(e.length/2);return e.length%2===0?s((e[n]+e[n-1])/2,r):s(e[n],r)},So=t=>{if(!t||t.length<=0)return;let r=new Map;for(let o of t)r.set(o,(r.get(o)||0)+1);let e=0,n=[];for(let[o,i]of r)i>e?(e=i,n=[o]):i===e&&n.push(o);if(n.length!==t.length)return n.length===1?[n[0]]:n},wo=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=G(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+h(i-e,2),0);return s(n/t.length,r)},er=(t,r=1/0)=>{if(!t||t.length<=0)return;let e=G(t);if(e===void 0)return;let n=t.reduce((o,i)=>o+h(i,2),0);return s(n/t.length-h(e,2),r)},wt=(t,r=1/0)=>{var n;let e=(n=er(t))!=null?n:0;return s(Math.sqrt(e),r)};var nr=(t,r,e,n=1/0)=>{let o=e-r;return o===0?0:s((t-r)/o,n)},Rt=(t,r,e,n=1/0)=>{let o=[...t];for(let i=0;i{let e=Math.min(...t),n=Math.max(...t),o=Rt(t,e,n,r);return{min:s(e,r),max:s(n,r),data:o}},zo=(t,r,e,n=1/0)=>Rt(t,r,e,n),or=(t,r,e,n=1/0)=>e===0?0:s((t-r)/e,n),zt=(t,r,e,n=1/0)=>[...t].map(o=>or(o,r,e,n)),Bo=(t,r=1/0)=>{var i;let e=(i=G(t))!=null?i:0,n=wt(t),o=zt(t,e,n,r);return{mean:s(e,r),stdDev:s(n,r),data:o}},Ho=(t,r,e,n=1/0)=>zt(t,r,e,n);var To=t=>t/2*(t+1),Eo=(t,r)=>(r-t+1)*(t+r)/2;var Lo=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=1;for(let n=r;n<=t;n++)e*=n;return e},ir=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}return t===r?r:t*ir(t-1,r)},No=(t,r=0)=>{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===0){if(t===0)return 1;r=1}let e=new Map,n=(o,i)=>{var u;if(o{if(t<0)throw new Error("Factorial is not defined for negative numbers.");if(r>t)throw new Error("Start cannot be greater than n.");if(r<0)throw new Error("Start must be non-negative.");if(r===t)return t===0?1:t;r===0&&(r=1);let e=[];e[0]=1;for(let n=1;n<=t;n++)e[n]=e[n-1]*n;return e[t]/e[r-1]};var qo=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return h(t,r)},Ao=(t,r)=>{if(t<0||r<0)throw new Error("Both n and r should be non-negative integers.");if(!Number.isInteger(t)||!Number.isInteger(r))throw new Error("Both n and r should be integers.");return h(t,r)};0&&(module.exports={animate,arithmeticSequenceSum,circleCollide,circleMovement,circleMovementAfterMouse,convertRange,convexPolygonsCollide,degreesToRadians,doRangesOverlap,dxArcCos,dxArcCot,dxArcSin,dxArcTan,dxCos,dxCot,dxPolynomial,dxSin,dxTan,dxV2CubicBezierCurve,dxV2QuadraticBezierCurve,dxV3CubicBezierCurve,dxV3QuadraticBezierCurve,ellipseMovement,ellipseMovementAfterMouse,factorial,factorialIterative,factorialMemoized,factorialRecursive,getAnglesDistance,getAnglesSub,getArithmeticMean,getArithmeticMeanFromFrequency,getCircleCircumference,getColorsDelta,getEllipseCircumference,getLinearEquationBy2Points,getMedian,getMode,getRandom,getRandomBoolean,getRandomGrayscaleHSLColor,getRandomHSLColor,getRandomHSLColorWithHue,getRandomHSLColorWithLightness,getRandomHSLColorWithSaturation,getRandomHSLColorWithinRanges,getRandomHexColor,getRandomInt,getRandomItemFromArray,getRandomRGBColor,getShiftedHue,getShiftedLightness,getShiftedSaturation,getSquareInCircleSide,getStandardDeviation,getV2Angle,getV2AngleBetween,getV2AngleInEllipse,getV3AngleBetween,getVNAngleBetween,getVariance,getVariance1,guid,hexToRgb,hslToHex,hslToRgb,identity2,identity3,identity4,identityN,isAngleBetween,isAngleInCircleArc,isClockwise,isNumber,isSingularMatrix,labToRgb,linearEquation,linearEquationSystem2,linearEquationSystem3,linearEquationSystemN,lissajousCurve,m2Adjugate,m2AppendRow,m2DeepCopy,m2Determinant,m2DivideScalar,m2Inverse,m2MulScalar,m2PrependRow,m2ReflectionOrigin,m2ReflectionOriginH,m2ReflectionX,m2ReflectionXH,m2ReflectionY,m2ReflectionYH,m2ReflectionYmX,m2Reset,m2RotateAroundPointH,m2Rotation,m2RotationAroundPointH,m2RotationH,m2Scale,m2ScaleAtPointH,m2ScaleAtPointHMatrix,m2ScaleH,m2ScaleX,m2ScaleXH,m2ScaleY,m2ScaleYH,m2ShearingX,m2ShearingY,m2Sub,m2Sum,m2ToCSS,m2Translation,m2TranslationH,m2Transpose,m2hToCSS,m2hToCSS3d,m2x2,m3Adjugate,m3AppendRow,m3DeepCopy,m3Determinant,m3DivideScalar,m3Inverse,m3MulScalar,m3PrependRow,m3ReflectionOrigin,m3ReflectionOriginH,m3ReflectionXY,m3ReflectionXYH,m3ReflectionXZ,m3ReflectionXZH,m3ReflectionYZ,m3ReflectionYZH,m3Reset,m3RotationX,m3RotationXH,m3RotationY,m3RotationYH,m3RotationZ,m3RotationZH,m3Scale,m3ScaleH,m3ScaleX,m3ScaleXH,m3ScaleY,m3ScaleYH,m3ScaleZ,m3ScaleZH,m3Sub,m3Sum,m3Translation,m3TranslationH,m3Transpose,m3hToCSS3d,m3x3,m4x4,mAdjugate,mAppendCol,mAppendRow,mDeepCopy,mDelFirstColumn,mDelFirstRow,mDelLastColumn,mDelLastRow,mDeterminant,mDivideScalar,mEqual,mGetColumn,mGetFirstColumn,mGetLastColumn,mInverse,mMinor,mMul,mMulScalar,mMulVector,mNxM,mPrependCol,mPrependRow,mReset,mSub,mSum,mTranspose,mlNormalizeArray,mlNormalizeTestData,mlNormalizeUnseenData,mlNormalizeValue,mlStandardizeArray,mlStandardizeTestData,mlStandardizeUnseenData,mlStandardizeValue,mod,naturalNumbersSequenceSum,naturalNumbersSum1ToN,naturalNumbersSumMToN,newId,percentToAngle,permutationsWithRepetition,permutationsWithoutRepetition,polarToCartesian,radiansToDegrees,rectCollide,rgbToHex,rgbToHsl,rgbToLab,setDecimalPlaces,setV2Angle,sineWaveMovement,stringToNumber,v2,v2CubicBezierBBox,v2CubicBezierCurve,v2CubicBezierCurveExtrema,v2CubicBezierCurveNormal,v2CubicBezierCurveTangent,v2Distance,v2DivideScalar,v2DotProduct,v2FromPolarCoords,v2GetNormal,v2Length,v2MulScalar,v2Normalize,v2QuadraticBezierBBox,v2QuadraticBezierCurve,v2QuadraticBezierCurveExtrema,v2QuadraticBezierCurveNormal,v2QuadraticBezierCurveTangent,v2Rotate,v2RotateH,v2Scale,v2SetLength,v2Sub,v2Sum,v3,v3CrossProduct,v3CubicBezierCurve,v3CubicBezierCurveTangent,v3Distance,v3DivideScalar,v3DotProduct,v3Length,v3MulScalar,v3Normalize,v3QuadraticBezierCurve,v3QuadraticBezierCurveTangent,v3RotateX,v3RotateY,v3RotateZ,v3Scale,v3Sub,v3Sum,v4,vDistance,vDivideScalar,vDotProduct,vEqual,vLength,vMulScalar,vN,vNormalize,vSub,vSum}); //# sourceMappingURL=mz-math.node.cjs.map diff --git a/dist/mz-math.node.cjs.map b/dist/mz-math.node.cjs.map index 0fdfdaf..4b7f832 100644 --- a/dist/mz-math.node.cjs.map +++ b/dist/mz-math.node.cjs.map @@ -1,7 +1,7 @@ { "version": 3, - "sources": ["../src/index-esm.ts", "../src/main/format.ts", "../src/main/other.ts", "../src/main/angle.ts", "../src/main/linear-algebra/vector.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts"], - "sourcesContent": ["export * from './main/linear-algebra/vector';\nexport * from './main/linear-algebra/matrix';\nexport * from './main/linear-algebra/matrix-transformations';\nexport * from './main/format';\nexport * from './main/angle';\nexport * from './main/random';\nexport * from './main/other';\nexport * from './main/convert';\nexport * from './main/bezier-curves/bezier-curve';\nexport * from './main/equations/linear-equations';\nexport * from './main/path-movement';\nexport * from './main/color';\nexport * from './main/physics';\nexport * from './main/id';\nexport * from './main/derivative';\nexport * from './main/collision-detection';\nexport * from './main/animation';\nexport * from './main/circle-ellipse';\nexport * from './main/sequence';\nexport * from './main/statistics';\nexport * from './main/ml';\nexport * from './main/series';", "export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};"], - "mappings": "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", - "names": ["index_esm_exports", "__export", "animate", "arithmeticSequenceSum", "circleCollide", "circleMovement", "circleMovementAfterMouse", "convertRange", "convexPolygonsCollide", "degreesToRadians", "doRangesOverlap", "dxArcCos", "dxArcCot", "dxArcSin", "dxArcTan", "dxCos", "dxCot", "dxPolynomial", "dxSin", "dxTan", "dxV2CubicBezierCurve", "dxV2QuadraticBezierCurve", "dxV3CubicBezierCurve", "dxV3QuadraticBezierCurve", "ellipseMovement", "ellipseMovementAfterMouse", "getAnglesDistance", "getAnglesSub", "getArithmeticMean", "getArithmeticMeanFromFrequency", "getCircleCircumference", "getColorsDelta", "getEllipseCircumference", "getLinearEquationBy2Points", "getMedian", "getMode", "getRandom", "getRandomBoolean", "getRandomGrayscaleHSLColor", "getRandomHSLColor", "getRandomHSLColorWithHue", "getRandomHSLColorWithLightness", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithinRanges", "getRandomHexColor", "getRandomInt", "getRandomItemFromArray", "getRandomRGBColor", "getShiftedHue", "getShiftedLightness", "getShiftedSaturation", "getSquareInCircleSide", "getStandardDeviation", "getV2Angle", "getV2AngleBetween", "getV2AngleInEllipse", "getV3AngleBetween", "getVNAngleBetween", "getVariance", "getVariance1", "guid", "hexToRgb", "hslToHex", "hslToRgb", "identity2", "identity3", "identity4", "identityN", "isAngleBetween", "isAngleInCircleArc", "isClockwise", "isNumber", "isSingularMatrix", "labToRgb", "linearEquation", "linearEquationSystem2", "linearEquationSystem3", "linearEquationSystemN", "lissajousCurve", "m2Adjugate", "m2AppendRow", "m2DeepCopy", "m2Determinant", "m2DivideScalar", "m2Inverse", "m2MulScalar", "m2PrependRow", "m2ReflectionOrigin", "m2ReflectionOriginH", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m2ReflectionYmX", "m2Reset", "m2RotateAroundPointH", "m2Rotation", "m2RotationAroundPointH", "m2RotationH", "m2Scale", "m2ScaleAtPointH", "m2ScaleAtPointHMatrix", "m2ScaleH", "m2ScaleX", "m2ScaleXH", "m2ScaleY", "m2ScaleYH", "m2ShearingX", "m2ShearingY", "m2Sub", "m2Sum", "m2ToCSS", "m2Translation", "m2TranslationH", "m2Transpose", "m2hToCSS", "m2hToCSS3d", "m2x2", "m3Adjugate", "m3AppendRow", "m3DeepCopy", "m3Determinant", "m3DivideScalar", "m3Inverse", "m3MulScalar", "m3PrependRow", "m3ReflectionOrigin", "m3ReflectionOriginH", "m3ReflectionXY", "m3ReflectionXYH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionYZ", "m3ReflectionYZH", "m3Reset", "m3RotationX", "m3RotationXH", "m3RotationY", "m3RotationYH", "m3RotationZ", "m3RotationZH", "m3Scale", "m3ScaleH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m3Sub", "m3Sum", "m3Translation", "m3TranslationH", "m3Transpose", "m3hToCSS3d", "m3x3", "m4x4", "mAdjugate", "mAppendCol", "mAppendRow", "mDeepCopy", "mDelFirstColumn", "mDelFirstRow", "mDelLastColumn", "mDelLastRow", "mDeterminant", "mDivideScalar", "mEqual", "mGetColumn", "mGetFirstColumn", "mGetLastColumn", "mInverse", "mMinor", "mMul", "mMulScalar", "mMulVector", "mNxM", "mPrependCol", "mPrependRow", "mReset", "mSub", "mSum", "mTranspose", "mlNormalizeArray", "mlNormalizeTestData", "mlNormalizeUnseenData", "mlNormalizeValue", "mlStandardizeArray", "mlStandardizeTestData", "mlStandardizeUnseenData", "mlStandardizeValue", "mod", "naturalNumbersSequenceSum", "naturalNumbersSum1ToN", "naturalNumbersSumMToN", "newId", "percentToAngle", "polarToCartesian", "radiansToDegrees", "rectCollide", "rgbToHex", "rgbToHsl", "rgbToLab", "setDecimalPlaces", "setV2Angle", "sineWaveMovement", "stringToNumber", "v2", "v2CubicBezierBBox", "v2CubicBezierCurve", "v2CubicBezierCurveExtrema", "v2CubicBezierCurveNormal", "v2CubicBezierCurveTangent", "v2Distance", "v2DivideScalar", "v2DotProduct", "v2FromPolarCoords", "v2GetNormal", "v2Length", "v2MulScalar", "v2Normalize", "v2QuadraticBezierBBox", "v2QuadraticBezierCurve", "v2QuadraticBezierCurveExtrema", "v2QuadraticBezierCurveNormal", "v2QuadraticBezierCurveTangent", "v2Rotate", "v2RotateH", "v2Scale", "v2SetLength", "v2Sub", "v2Sum", "v3", "v3CrossProduct", "v3CubicBezierCurve", "v3CubicBezierCurveTangent", "v3Distance", "v3DivideScalar", "v3DotProduct", "v3Length", "v3MulScalar", "v3Normalize", "v3QuadraticBezierCurve", "v3QuadraticBezierCurveTangent", "v3RotateX", "v3RotateY", "v3RotateZ", "v3Scale", "v3Sub", "v3Sum", "v4", "vDistance", "vDivideScalar", "vDotProduct", "vEqual", "vLength", "vMulScalar", "vN", "vNormalize", "vSub", "vSum", "__toCommonJS", "setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "stringToNumber", "value", "defaultNumber", "_a", "res", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "x", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "guid", "c", "newId", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "naturalNumbersSequenceSum", "n", "arithmeticSequenceSum", "a", "d", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "naturalNumbersSum1ToN", "n", "naturalNumbersSumMToN", "m"] + "sources": ["../src/index-esm.ts", "../src/main/format.ts", "../src/main/other.ts", "../src/main/angle.ts", "../src/main/linear-algebra/vector.ts", "../src/main/linear-algebra/matrix.ts", "../src/main/linear-algebra/matrix-transformations.ts", "../src/main/random.ts", "../src/main/convert.ts", "../src/main/derivative.ts", "../src/main/equations/linear-equations.ts", "../src/main/equations/quadratic-equations.ts", "../src/main/bezier-curves/bezier-curve.ts", "../src/main/path-movement.ts", "../src/main/color.ts", "../src/main/id.ts", "../src/main/collision-detection.ts", "../src/main/animation.ts", "../src/main/circle-ellipse.ts", "../src/main/sequence.ts", "../src/main/statistics.ts", "../src/main/ml.ts", "../src/main/series.ts", "../src/main/combinatorics/factorial.ts", "../src/main/combinatorics/combinatorics.ts"], + "sourcesContent": ["export * from './main/linear-algebra/vector';\nexport * from './main/linear-algebra/matrix';\nexport * from './main/linear-algebra/matrix-transformations';\nexport * from './main/format';\nexport * from './main/angle';\nexport * from './main/random';\nexport * from './main/other';\nexport * from './main/convert';\nexport * from './main/bezier-curves/bezier-curve';\nexport * from './main/equations/linear-equations';\nexport * from './main/path-movement';\nexport * from './main/color';\nexport * from './main/physics';\nexport * from './main/id';\nexport * from './main/derivative';\nexport * from './main/collision-detection';\nexport * from './main/animation';\nexport * from './main/circle-ellipse';\nexport * from './main/sequence';\nexport * from './main/statistics';\nexport * from './main/ml';\nexport * from './main/series';\nexport * from './main/combinatorics/factorial';\nexport * from './main/combinatorics/combinatorics';", "export const setDecimalPlaces = (num: number, decimalPlaces: number | undefined = Infinity) => {\n if(decimalPlaces === Infinity) return num;\n\n if(decimalPlaces < 0){\n decimalPlaces = 0;\n }\n\n const coefficient = 10 ** decimalPlaces;\n return Math.round(num * coefficient) / coefficient;\n};", "import { Vector2 } from '../types';\nimport { setDecimalPlaces } from './format';\n\nexport const mod = (n: number, m: number) => {\n return ((n % m) + m) % m;\n};\n\n/**\n * Convert range [a, b] to [c, d].\n * f(x) = (d - c) * (x - a) / (b - a) + c\n */\nexport const convertRange = (x: number, a: number, b: number, c: number, d: number) => {\n return (d - c) * (x - a) / (b - a) + c;\n};\n\n/**\n * Check if 2 ranges [a,b] and [c,d] overlap.\n */\nexport const doRangesOverlap = (a: number, b: number, c: number, d: number) => {\n return Math.max(a, c) <= Math.min(b, d) ;\n};\n\n// eslint-disable-next-line\nexport const isNumber = (value: any) => {\n return !isNaN(parseFloat(value)) && isFinite(value);\n};\n\n/**\n * Convert polar coordinates to cartesian coordinates.\n */\nexport const polarToCartesian = (center: Vector2, radii: Vector2, angleInRad: number, decimalPlaces = Infinity) : Vector2 => {\n const [cx, cy] = center;\n const [rx, ry] = radii;\n\n return [\n setDecimalPlaces(cx + (rx * Math.cos(angleInRad)), decimalPlaces),\n setDecimalPlaces(cy + (ry * Math.sin(angleInRad)), decimalPlaces),\n ];\n};", "import { Vector, Vector2, Vector3 } from '../types';\nimport { setDecimalPlaces } from './format';\nimport { v2Length, vNormalize, vDotProduct, vSub } from './linear-algebra/vector';\nimport { mod } from './other';\n\nexport const getV2Angle = (v2: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1], v2[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleInEllipse = (v2: Vector2, radii: Vector2, decimalPlaces = Infinity) => {\n const angle = Math.atan2(v2[1]/radii[1], v2[0]/radii[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const setV2Angle = (v2: Vector2, newAngleRad: number, decimalPlaces = Infinity): Vector2 => {\n const length = v2Length(v2);\n return [\n setDecimalPlaces(Math.cos(newAngleRad) * length, decimalPlaces),\n setDecimalPlaces(Math.sin(newAngleRad) * length, decimalPlaces),\n ];\n};\n\nexport const radiansToDegrees = (radians: number, decimalPlaces = Infinity) => {\n const res = radians * (180 / Math.PI);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\nexport const degreesToRadians = (degrees: number, decimalPlaces = Infinity) => {\n const res = degrees * (Math.PI / 180);\n return setDecimalPlaces(res, decimalPlaces);\n};\n\n/**\n * Returns the range [0, Math.PI]\n * A = Math.acos( dot(v1, v2)/(v1.length()*v2.length()) );\n */\nexport const getVNAngleBetween = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n const unitVector1 = vNormalize(vector1);\n const unitVector2 = vNormalize(vector2);\n const dotProduct = vDotProduct(unitVector1, unitVector2);\n const angle = Math.acos(dotProduct);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV2AngleBetween = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) : number => {\n // return getVNAngleBetween(vector1, vector2, decimalPlaces);\n const diff = vSub(vector1, vector2);\n const angle = Math.atan2(diff[1], diff[0]);\n return setDecimalPlaces(angle, decimalPlaces);\n};\n\nexport const getV3AngleBetween = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return getVNAngleBetween(vector1, vector2, decimalPlaces);\n};\n\nexport const isAngleBetween = (angleDegrees: number, startAngleDegrees: number, endAngleDegrees: number) : boolean => {\n const distance = getAnglesSub(startAngleDegrees, endAngleDegrees);\n const distance1 = getAnglesSub(startAngleDegrees, angleDegrees);\n const distance2 = getAnglesSub(endAngleDegrees, angleDegrees);\n const totalDistance = distance1 + distance2;\n\n // Use a small threshold for floating point errors\n return Math.abs(totalDistance - distance) <= 0.001;\n}\n\nexport const isClockwise = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n return angle2Deg >= angle1Deg;\n};\n\n/**\n * Shortest distance (angular) between two angles.\n */\nexport const getAnglesSub = (angleDegrees1: number, angleDegrees2: number, decimalPlaces = Infinity) : number => {\n const angleDistance = Math.abs(mod(angleDegrees1, 360) - mod(angleDegrees2, 360));\n return setDecimalPlaces(angleDistance <= 180 ? angleDistance : 360 - angleDistance, decimalPlaces);\n};\n\nexport const getAnglesDistance = (angle1Deg: number, angle2Deg: number, startAngleDeg = 0, decimalPlaces = Infinity) => {\n angle1Deg = angle1Deg % 360;\n angle2Deg = angle2Deg % 360;\n\n if(angle1Deg < startAngleDeg) {\n angle1Deg += 360;\n }\n\n if(angle2Deg < startAngleDeg) {\n angle2Deg += 360;\n }\n\n if(isClockwise(angle1Deg, angle2Deg, startAngleDeg)) {\n return setDecimalPlaces((angle2Deg - angle1Deg + 360) % 360, decimalPlaces);\n }\n else{\n return setDecimalPlaces((angle1Deg - angle2Deg + 360) % 360, decimalPlaces);\n }\n};\n\nexport const percentToAngle = (percent: number, startAngleDeg: number, endAngleDeg: number, circleStartAngle = 0) => {\n if(percent < 0) {\n percent = 0;\n }\n\n if(percent > 100) {\n percent = 100;\n }\n\n const distance = getAnglesDistance(startAngleDeg, endAngleDeg, circleStartAngle);\n\n const clockwise = isClockwise(startAngleDeg, endAngleDeg, circleStartAngle);\n if(clockwise) {\n return mod(circleStartAngle + (percent * distance / 100), 360);\n }\n else {\n return mod(circleStartAngle - (percent * distance / 100), 360);\n }\n};", "import { Vector, Vector2, Vector3, Vector4 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { getV2Angle, setV2Angle } from '../angle';\n\n// ------------ SUM ------------------------\n\nexport const vSum = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSum(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sum = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSum(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ SUB ------------------------\n\nexport const vSub = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : Vector => {\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vSub(vector1, vector2, decimalPlaces) as Vector2;\n};\n\nexport const v3Sub = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vSub(vector1, vector2, decimalPlaces) as Vector3;\n};\n\n// ------------ MUL SCALAR ------------------------\n\nexport const vMulScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n const vector: Vector = [];\n\n for(let i=0; i {\n return vMulScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3MulScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vMulScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ DIVIDE ------------------------\n\nexport const vDivideScalar = (v: Vector, scalar: number, decimalPlaces = Infinity): Vector => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const vector: Vector = [];\n\n for(let i=0; i {\n return vDivideScalar(v2, scalar, decimalPlaces) as Vector2;\n};\n\nexport const v3DivideScalar = (v3: Vector3, scalar: number, decimalPlaces = Infinity): Vector3 => {\n return vDivideScalar(v3, scalar, decimalPlaces) as Vector3;\n};\n\n// ------------ LENGTH ------------------------\n\nexport const vLength = (vector: Vector, decimalPlaces = Infinity) => {\n let sum = 0;\n\n for(let i=0; i {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v3Length = (vector: Vector3, decimalPlaces = Infinity) => {\n return vLength(vector, decimalPlaces);\n};\n\nexport const v2SetLength = (v2: Vector2, newLength: number, decimalPlaces = Infinity): Vector2 => {\n const angle = getV2Angle(v2);\n return [\n setDecimalPlaces(Math.cos(angle) * newLength, decimalPlaces),\n setDecimalPlaces(Math.sin(angle) * newLength, decimalPlaces),\n ];\n};\n\n// ----------- DISTANCE ------------------------\n\nexport const vDistance = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v2Distance = (vector1: Vector2, vector2: Vector2, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\nexport const v3Distance = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) => {\n const diff = vSub(vector1, vector2);\n return vLength(diff, decimalPlaces);\n};\n\n// ------------ NORMALIZE ------------------------\n\n/**\n * Normalization creates a unit vector, which is a vector of length 1.\n */\nexport const vNormalize = (v: Vector, decimalPlaces = Infinity) : Vector => {\n const length = vLength(v);\n const unitVector: Vector = [];\n\n for(let i=0; i {\n return vNormalize(v2, decimalPlaces) as Vector2;\n};\n\nexport const v3Normalize = (v3: Vector3, decimalPlaces = Infinity) : Vector3 => {\n return vNormalize(v3, decimalPlaces) as Vector3;\n};\n\n// ------------ DOT PRODUCT ------------------------\n\nexport const vDotProduct = (vector1: Vector, vector2: Vector, decimalPlaces = Infinity) : number => {\n let sum = 0;\n\n for(let i=0; i {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\nexport const v3DotProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity) : number => {\n return vDotProduct(vector1, vector2, decimalPlaces);\n};\n\n// ------------ CROSS PRODUCT ------------------------\n\n/**\n * Cross product is possible on 3D vectors only.\n * The cross product a \u00D7 b is defined as a vector c that is perpendicular (orthogonal) to both a and b.\n */\nexport const v3CrossProduct = (vector1: Vector3, vector2: Vector3, decimalPlaces = Infinity): Vector3 => {\n return [\n setDecimalPlaces(vector1[1] * vector2[2] - vector1[2] * vector2[1], decimalPlaces),\n setDecimalPlaces(vector1[2] * vector2[0] - vector1[0] * vector2[2], decimalPlaces),\n setDecimalPlaces(vector1[0] * vector2[1] - vector1[1] * vector2[0], decimalPlaces),\n ];\n};\n\n// --------------- INIT VECTOR HELPER -----------------\n\nexport const v2 = (defaultValue = 0): Vector2 => {\n return [defaultValue, defaultValue];\n};\n\nexport const v3 = (defaultValue = 0): Vector3 => {\n return [defaultValue, defaultValue, defaultValue];\n};\n\nexport const v4 = (defaultValue = 0): Vector4 => {\n return [defaultValue, defaultValue, defaultValue, defaultValue];\n};\n\nexport const vN = (N: number, defaultValue = 0): Vector => {\n\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n const vector: Vector = [];\n for(let i=0; i {\n let vector: Vector2 = [0, 0];\n vector = v2SetLength(vector, distance);\n return setV2Angle(vector, angleRad);\n};\n\n// --------------- EQUALITY -------------------------\n\nexport const vEqual = (vector1: Vector, vector2: Vector): boolean => {\n if(vector1.length !== vector2.length) return false;\n\n for(let i=0; i {\n const sub = v2Sub(vector2, vector1);\n return [\n -setDecimalPlaces(sub[1], decimalPlaces),\n setDecimalPlaces(sub[0], decimalPlaces)\n ];\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector, Vector2, Vector3 } from '../../types';\nimport { vMulScalar, vSum, vSub, vDotProduct, vN, vEqual, vDivideScalar } from './vector';\n\n// --------------- SUM ----------------------\n\nexport const mSum = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sum = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSum(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- SUB ----------------------\n\nexport const mSub = (matrix1: Matrix, matrix2: Matrix, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix2;\n};\n\nexport const m3Sub = (matrix1: Matrix3, matrix2: Matrix3, decimalPlaces = Infinity): Matrix3 => {\n return mSub(matrix1, matrix2, decimalPlaces) as Matrix3;\n};\n\n// --------------- MUL SCALAR ----------------------\n\nexport const mMulScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vMulScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2MulScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mMulScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3MulScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mMulScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n// --------------- DIVIDE SCALAR ----------------------\n\nexport const mDivideScalar = (m: Matrix, scalar: number, decimalPlaces = Infinity): Matrix => {\n if(scalar === 0){\n throw new Error('Division by zero error.');\n }\n\n const matrix: Matrix = [];\n\n for(const v of m){\n matrix.push(vDivideScalar(v, scalar, decimalPlaces));\n }\n\n return matrix;\n};\n\nexport const m2DivideScalar = (m2: Matrix2, scalar: number, decimalPlaces = Infinity): Matrix2 => {\n return mDivideScalar(m2, scalar, decimalPlaces) as Matrix2;\n};\n\nexport const m3DivideScalar = (m3: Matrix3, scalar: number, decimalPlaces = Infinity): Matrix3 => {\n return mDivideScalar(m3, scalar, decimalPlaces) as Matrix3;\n};\n\n\n// --------------- TRANSPOSE ----------------------\n\nexport const mTranspose = (m: Matrix): Matrix => {\n\n const vectorsCount = m.length;\n if(vectorsCount <= 0) return m;\n\n const vectorLength = m[0].length;\n if(vectorLength <= 0) return m;\n\n const matrix: Matrix = [];\n for(let i=0; i {\n return mTranspose(m2);\n};\n\nexport const m3Transpose = (m3: Matrix3): Matrix => {\n return mTranspose(m3);\n};\n\n// ----------------- RESET ----------------------\n\nexport const mReset = (m: Matrix, defaultValue = 0): Matrix => {\n\n if(m.length <= 0) return [];\n\n const res: Matrix = [];\n\n for(let i=0; i {\n return mReset(m2, defaultValue) as Matrix2;\n};\n\nexport const m3Reset = (m3: Matrix3, defaultValue = 0): Matrix3 => {\n return mReset(m3, defaultValue) as Matrix3;\n};\n\n// --------------- MATRIX INIT HELPERS -----------------\n\nexport const m2x2 = (defaultValue = 0): Matrix2 => {\n return [\n [defaultValue, defaultValue],\n [defaultValue, defaultValue],\n ];\n};\n\nexport const m3x3 = (defaultValue = 0): Matrix3 => {\n return [\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const m4x4 = (defaultValue = 0): Matrix4 => {\n return [\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n [defaultValue, defaultValue, defaultValue, defaultValue],\n ];\n};\n\nexport const mNxM = (N: number, M: number, defaultValue = 0): Matrix => {\n if(N <= 0 || M <= 0){\n throw new Error('M and N must be positive numbers.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return [\n [1, 0],\n [0, 1],\n ];\n};\n\nexport const identity3 = (): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\nexport const identity4 = (): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Identity Matrix (I).\n * M x I = I x M = M for any matrix M.\n * Identity Matrix is a special case of scale matrix.\n */\nexport const identityN = (N: number): Matrix => {\n if(N < 0){\n throw new Error('N must be a non-negative number.');\n }\n\n if(N === 0) return [];\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const matrix: Matrix = [];\n\n for(let i=0; i {\n return mDeepCopy(m2) as Matrix2;\n};\n\nexport const m3DeepCopy = (m3: Matrix3): Matrix3 => {\n return mDeepCopy(m3) as Matrix3;\n};\n\n// -------------- APPEND / PREPEND ROW OR COLUMN ---------------\n\nexport const mAppendCol = (m: Matrix, col: Vector): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n const copy = mDeepCopy(m);\n copy.push(row);\n return copy;\n};\n\nexport const m2AppendRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.push(row);\n return copy;\n};\n\nexport const m3AppendRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.push(row);\n return copy;\n};\n\nexport const mPrependRow = (m: Matrix, row: Vector) : Matrix => {\n const copy = mDeepCopy(m);\n copy.unshift(row);\n return copy;\n};\n\nexport const m2PrependRow = (m2: Matrix2, row: Vector2) : Matrix2 => {\n const copy = m2DeepCopy(m2);\n copy.unshift(row);\n return copy;\n};\n\nexport const m3PrependRow = (m3: Matrix3, row: Vector3) : Matrix3 => {\n const copy = m3DeepCopy(m3);\n copy.unshift(row);\n return copy;\n};\n\n// ------------ DELETE ROW OR COLUMN ----------------------------\n\nexport const mDelLastRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.pop();\n return copy;\n};\n\nexport const mDelFirstRow = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n copy.shift();\n return copy;\n};\n\nexport const mDelLastColumn = (m: Matrix): Matrix => {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const copy = mDeepCopy(m);\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const size = m[0].length;\n\n const vector: Vector = [];\n for(let i=0; i {\n if(m.length <= 0) return [];\n\n const vector: Vector = [];\n for(let i=0; i {\n\n const matrix: Matrix = [];\n for(let i=0; i {\n\n if(matrix.length < 0) return [];\n\n if(matrix[0].length !== vector.length){\n throw new Error('The number of columns in the matrix must be equal to the length of the vector.');\n }\n\n const res: Vector = [];\n\n for(let i=0; i {\n if(matrix1.length !== matrix2.length) return false;\n\n for(let i=0; i returns matrix N (m-1 x m-1)\n * The matrix must be square.\n */\nconst mMinorHelper = (m: Matrix, row: number, col: number) => {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const matrix: Matrix = [];\n\n for(let i=0; i {\n const size = m.length;\n\n if(size <= 0){\n throw new Error('The matrix should not be empty.');\n }\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // prepare the matrix without provided row and column\n const matrix = mMinorHelper(m, row, col);\n\n // calculate the matrix determinant\n return mDeterminant(matrix);\n};\n\n/**\n * Calculate determinant for NxN matrix.\n * Matrix should be square.\n */\nexport const mDeterminant = (matrix: Matrix): number => {\n const size = matrix.length;\n if(size === 0) return 1;\n\n if(size !== matrix[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return matrix[0][0];\n if(size === 2) return m2Determinant(matrix as Matrix2);\n\n let d = 0;\n\n for(let i=0; i {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return m2[0][0] * m2[1][1] - m2[1][0] * m2[0][1];\n};\n\n/**\n * Calculate determinant for 3x3 matrix.\n * Matrix should be square.\n */\nexport const m3Determinant = (m3: Matrix3): number => {\n if(m3.length !== m3[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return mDeterminant(m3);\n};\n\n// ------------------ INVERSE -----------------------\n\nexport const m2Adjugate = (m2: Matrix2): Matrix2|null => {\n if(m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n return [\n [m2[1][1], -m2[0][1]],\n [-m2[1][0], m2[0][0]],\n ];\n};\n\nexport const m3Adjugate = (m3: Matrix3) : Matrix3|null => {\n return mAdjugate(m3) as (Matrix3|null);\n};\n\n/**\n * Adjugate is a transpose of a cofactor matrix\n */\nexport const mAdjugate = (m: Matrix): Matrix|null => {\n\n const size = m.length;\n if(size <= 0) return null;\n\n if(size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n if(size === 1) return m;\n\n if(size === 2) return m2Adjugate(m as Matrix2);\n\n // build a cofactor matrix ----------------\n const cofactors: Matrix = [];\n\n for(let i=0; i {\n if(m.length > 0 && m.length !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = mDeterminant(m);\n return d === 0;\n};\n\n/**\n * Square matrix A (nxn) is invertible is there is another square matrix B (nxn) so AxB = BxA = I\n * For A (2x2) matrix, the inverse is:\n * (1 / (determinant(A))) * adj(A)\n */\nexport const m2Inverse = (m2: Matrix2, decimalPlaces = Infinity): (Matrix2 | null) => {\n if(m2.length > 0 && m2.length !== m2[0].length){\n throw new Error('The matrix must be square.');\n }\n\n const d = m2Determinant(m2);\n if(d === 0) return null;\n\n const adj = m2Adjugate(m2);\n if(adj === null) return null;\n\n return m2DivideScalar(adj, d, decimalPlaces);\n};\n\nexport const m3Inverse = (m3: Matrix3, decimalPlaces = Infinity): (Matrix3 | null) => {\n return mInverse(m3, decimalPlaces) as (Matrix3|null);\n};\n\nexport const mInverse = (m: Matrix, decimalPlaces = Infinity): (Matrix | null) => {\n const size = m.length;\n\n if(size > 0 && size !== m[0].length){\n throw new Error('The matrix must be square.');\n }\n\n // find a determinant ----------------------\n const d = mDeterminant(m);\n\n // find an Adjugate - a transpose of a cofactor matrix\n const adj = mAdjugate(m);\n if(adj === null) return null;\n\n return mDivideScalar(adj, d, decimalPlaces);\n};", "import { Matrix2, Matrix3, Matrix4, Matrix, Vector2, Vector3, Vector4 } from '../../types';\nimport { v2Normalize, v3MulScalar, v3Normalize } from './vector';\nimport { mMulVector, mMul } from './matrix';\nimport { setDecimalPlaces } from '../format';\n\n/*\nAny 2D affine transformation can be decomposed\ninto a rotation, followed by a scaling, followed by a\nshearing, and followed by a translation.\n---------------------------------------------------------\nAffine matrix = translation x shearing x scaling x rotation\n */\n\n// ----------------- CSS -------------------------------------\n\n/**\n * Matrix 2D in non-homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2ToCSS = (m: Matrix2) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, 0, 0)`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix\n */\nexport const m2hToCSS = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix(${ a }, ${ b }, ${ c }, ${ d }, ${ tx }, ${ ty })`;\n};\n\n/**\n * Matrix 2D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m2hToCSS3d = (m: Matrix3) : string => {\n const a = m[0][0];\n const b = m[1][0];\n const c = m[0][1];\n const d = m[1][1];\n const tx = m[0][2];\n const ty = m[1][2];\n\n return `matrix3d(${ a }, ${ b }, 0, 0, ${ c }, ${ d }, 0, 0, 0, 0, 1, 0, ${ tx }, ${ ty }, 0, 1)`;\n};\n\n/**\n * Matrix 3D in homogeneous coordinates to CSS matrix3d() function\n * https://developer.mozilla.org/en-US/docs/Web/CSS/transform-function/matrix3d\n */\nexport const m3hToCSS3d = (m: Matrix4) : string => {\n\n return `matrix3d(\n ${ m[0][0] }, ${ m[0][1] }, ${ m[0][2] }, ${ m[0][3] },\n ${ m[1][0] }, ${ m[1][1] }, ${ m[1][2] }, ${ m[1][3] },\n ${ m[2][0] }, ${ m[2][1] }, ${ m[2][2] }, ${ m[2][3] },\n ${ m[3][0] }, ${ m[3][1] }, ${ m[3][2] }, ${ m[3][3] }\n )`;\n};\n\n// ---------------- TRANSLATION MATRICES ----------------------\n\nexport const m2Translation = (position: Vector2, decimalPlaces = Infinity): Matrix2 => {\n\n return [\n [1, 0],\n [0, 1],\n [setDecimalPlaces(position[0], decimalPlaces), setDecimalPlaces(position[1], decimalPlaces)],\n ];\n};\n\nexport const m3Translation = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n [\n setDecimalPlaces(position[0], decimalPlaces),\n setDecimalPlaces(position[1], decimalPlaces),\n setDecimalPlaces(position[2], decimalPlaces)\n ],\n ];\n};\n\n/**\n * 2D Translation matrix in homogeneous coordinates.\n */\nexport const m2TranslationH = (position: Vector3, decimalPlaces = Infinity): Matrix3 => {\n\n return [\n [1, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1],\n ];\n};\n\n/**\n * 3D Translation matrix in homogeneous coordinates.\n */\nexport const m3TranslationH = (position: Vector4, decimalPlaces = Infinity): Matrix4 => {\n\n return [\n [1, 0, 0, setDecimalPlaces(position[0], decimalPlaces)],\n [0, 1, 0, setDecimalPlaces(position[1], decimalPlaces)],\n [0, 0, 1, setDecimalPlaces(position[2], decimalPlaces)],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- ROTATION MATRICES -------------------------\n\n/**\n * Rotation of an angle about the origin.\n */\nexport const m2Rotation = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix2 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin],\n [sin, cos],\n ] :\n [\n [cos, sin],\n [-sin, cos],\n ];\n};\n\n/**\n * Rotation of an angle about the origin in homogeneous coordinates (clockwise).\n */\nexport const m2RotationH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ]:\n [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation of an angle \"angleRad\" around the given point (transformOrigin) in homogeneous coordinates (clockwise).\n * result_vector = TranslationMatrix(x, y) * RotationMatrix() * TranslationMatrix(-x, -y) * position_vector\n */\nexport const m2RotationAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const rotation = m2RotationH(angleRad, isClockwise, decimalPlaces);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, rotation);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2RotateAroundPointH = (\n angleRad: number,\n transformOrigin: Vector3,\n position: Vector3,\n isClockwise = true,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2RotationAroundPointH(angleRad, transformOrigin, isClockwise, decimalPlaces);\n return mMulVector(mat3h, position) as Vector3;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2Rotate = (angleRad: number, vector: Vector2, isClockwise = true, decimalPlaces = Infinity): Vector2 => {\n const unitVector = v2Normalize(vector);\n return mMulVector(m2Rotation(angleRad, isClockwise, decimalPlaces), unitVector) as Vector2;\n};\n\n/**\n * Rotate vector around the origin by angle \"angleRad\" (clockwise).\n */\nexport const v2RotateH = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m2RotationH(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the X axis (clockwise).\n */\nexport const m3RotationX = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0],\n [0, cos, -sin],\n [0, sin, cos],\n ] :\n [\n [1, 0, 0],\n [0, cos, sin],\n [0, -sin, cos],\n ];\n};\n\n/**\n * Rotation around the X axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationXH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [1, 0, 0, 0],\n [0, cos, -sin, 0],\n [0, sin, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [1, 0, 0, 0],\n [0, cos, sin, 0],\n [0, -sin, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateX = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationX(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Y axis (clockwise).\n */\nexport const m3RotationY = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin],\n [0, 1, 0],\n [-sin, 0, cos],\n ] :\n [\n [cos, 0, -sin],\n [0, 1, 0],\n [sin, 0, cos],\n ];\n};\n\n/**\n * Rotation around the Y axis (clockwise) - in homogeneous coordinates\n */\nexport const m3RotationYH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, 0, sin, 0],\n [0, 1, 0, 0],\n [-sin, 0, cos, 0],\n [0, 0, 0, 1],\n ] :\n [\n [cos, 0, -sin, 0],\n [0, 1, 0, 0],\n [sin, 0, cos, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateY = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationY(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n/**\n * Rotation around the Z axis (clockwise).\n */\nexport const m3RotationZ = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix3 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0],\n [sin, cos, 0],\n [0, 0, 1],\n ] : [\n [cos, sin, 0],\n [-sin, cos, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Rotation around the Z axis (clockwise)- in homogeneous coordinates\n */\nexport const m3RotationZH = (angleRad: number, isClockwise = true, decimalPlaces = Infinity): Matrix4 => {\n\n const cos = setDecimalPlaces(Math.cos(angleRad), decimalPlaces);\n const sin = setDecimalPlaces(Math.sin(angleRad), decimalPlaces);\n\n return isClockwise ? [\n [cos, -sin, 0, 0],\n [sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ] : [\n [cos, sin, 0, 0],\n [-sin, cos, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\nexport const v3RotateZ = (angleRad: number, vector: Vector3, isClockwise = true, decimalPlaces = Infinity): Vector3 => {\n const unitVector = v3Normalize(vector);\n return mMulVector(m3RotationZ(angleRad, isClockwise, decimalPlaces), unitVector) as Vector3;\n};\n\n// ---------------- SCALE MATRICES -------------\n\n/**\n * Get matrix for arbitrary scaling pivot point.\n * result_vector = TranslationMatrix(x, y) * ScaleMatrix() * TranslationMatrix(-x, -y) * scale_vector\n */\nexport const m2ScaleAtPointHMatrix = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n decimalPlaces = Infinity): Matrix3 => {\n\n const translation = m2TranslationH(transformOrigin, decimalPlaces);\n const scale = m2ScaleH(scaleVector);\n const translationBack = m2TranslationH(v3MulScalar(transformOrigin, -1), decimalPlaces);\n const temp1 = mMul(translation, scale);\n return mMul(temp1, translationBack) as Matrix3;\n};\n\nexport const m2ScaleAtPointH = (\n scaleVector: Vector3,\n transformOrigin: Vector3,\n point: Vector3,\n decimalPlaces = Infinity): Vector3 => {\n\n const mat3h = m2ScaleAtPointHMatrix(scaleVector, transformOrigin, decimalPlaces);\n return mMulVector(mat3h, point) as Vector3;\n};\n\nexport const m2Scale = (scaleVector: Vector2): Matrix2 => {\n return [\n [scaleVector[0], 0],\n [0, scaleVector[1]],\n ];\n};\n\nexport const v2Scale = (scaleVector: Vector2, vector: Vector2): Vector2 => {\n return mMulVector(m2Scale(scaleVector), vector) as Vector2;\n};\n\n/**\n * homogeneous coordinates\n */\nexport const m2ScaleH = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, 1],\n ];\n};\n\nexport const m3Scale = (scaleVector: Vector3): Matrix3 => {\n return [\n [scaleVector[0], 0, 0],\n [0, scaleVector[1], 0],\n [0, 0, scaleVector[2]],\n ];\n};\n\nexport const m3ScaleH = (scaleVector: Vector4): Matrix4 => {\n return [\n [scaleVector[0], 0, 0, 0],\n [0, scaleVector[1], 0, 0],\n [0, 0, scaleVector[2], 0],\n [0, 0, 0, 1]\n ];\n};\n\nexport const v3Scale = (scaleVector: Vector3, vector: Vector3): Vector3 => {\n return mMulVector(m3Scale(scaleVector), vector) as Vector3;\n};\n\n/**\n * Stretch, parallel to the x-axis.\n */\nexport const m2ScaleX = (scale: number): Matrix2 => {\n return [\n [scale, 0],\n [0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the x-axis - homogeneous coordinates\n */\nexport const m2ScaleXH = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleX = (scale: number): Matrix3 => {\n return [\n [scale, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in x-direction\n */\nexport const m3ScaleXH = (scale: number): Matrix4 => {\n return [\n [scale, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleY = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Stretch in y-direction\n */\nexport const m3ScaleYH = (scale: number): Matrix => {\n return [\n [1, 0, 0, 0],\n [0, scale, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZ = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, scale],\n ];\n};\n\n/**\n * Stretch in z-direction\n */\nexport const m3ScaleZH = (scale: number): Matrix4 => {\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, scale, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis.\n */\nexport const m2ScaleY = (scale: number): Matrix2 => {\n return [\n [1, 0],\n [0, scale],\n ];\n};\n\n/**\n * Stretch, parallel to the y-axis - homogeneous coordinates\n */\nexport const m2ScaleYH = (scale: number): Matrix3 => {\n return [\n [1, 0, 0],\n [0, scale, 0],\n [0, 0, 1],\n ];\n};\n\n// ---------------- REFLECTION MATRICES -------------------------\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOrigin = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection about the origin.\n */\nexport const m2ReflectionOriginH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection about the origin in non-homogeneous coordinates\n */\nexport const m3ReflectionOrigin = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, -1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection about the origin in homogeneous coordinates\n */\nexport const m3ReflectionOriginH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection about y=-x\n */\nexport const m2ReflectionYmX = (): Matrix2 => {\n\n return [\n [0, -1],\n [-1, 0],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionX = (): Matrix2 => {\n\n return [\n [1, 0],\n [0, -1],\n ];\n};\n\n/**\n * Reflection in the x-axis.\n */\nexport const m2ReflectionXH = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection in the y-axis.\n */\nexport const m2ReflectionY = (): Matrix2 => {\n\n return [\n [-1, 0],\n [0, 1],\n ];\n};\n\nexport const m2ReflectionYH = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionYZ = (): Matrix3 => {\n\n return [\n [-1, 0, 0],\n [0, 1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to YZ plane in homogeneous coordinates\n */\nexport const m3ReflectionYZH = (): Matrix4 => {\n\n return [\n [-1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXZ = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, -1, 0],\n [0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XZ plane in homogeneous coordinates\n */\nexport const m3ReflectionXZH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, -1, 0, 0],\n [0, 0, 1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in non-homogeneous coordinates\n */\nexport const m3ReflectionXY = (): Matrix3 => {\n\n return [\n [1, 0, 0],\n [0, 1, 0],\n [0, 0, -1],\n ];\n};\n\n/**\n * Reflection relative to XY plane in homogeneous coordinates\n */\nexport const m3ReflectionXYH = (): Matrix4 => {\n\n return [\n [1, 0, 0, 0],\n [0, 1, 0, 0],\n [0, 0, -1, 0],\n [0, 0, 0, 1],\n ];\n};\n\n// ---------------- SHEARING MATRICES -------------------------\n\n\n/**\n * Shearing in y-axis, with x-axis fixed with (0,1) moving to (factor, 1)\n */\nexport const m2ShearingY = (factor: number): Matrix2 => {\n\n return [\n [1, factor],\n [0, 1],\n ];\n};\n\n/**\n * Shearing in x-axis, with y-axis fixed with (1,0) moving to (1, factor)\n */\nexport const m2ShearingX = (factor: number): Matrix2 => {\n\n return [\n [1, 0],\n [factor, 1],\n ];\n};", "import { setDecimalPlaces } from './format';\n\n/**\n * Returns a random number in the [min,max] range.\n */\nexport const getRandom = (min: number, max: number, decimalPlaces = Infinity): number => {\n return setDecimalPlaces(Math.random() * (max - min) + min, decimalPlaces);\n};\n\n/**\n * Returns a random integer number in the [min,max] range.\n */\nexport const getRandomInt = (min: number, max: number): number => {\n return Math.floor(Math.random() * (max - min + 1) + min);\n};\n\nexport const getRandomBoolean = () => Math.random() < 0.5;\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport const getRandomItemFromArray = (array: any[]) => {\n const randomIndex = getRandomInt(0, array.length - 1);\n return array[randomIndex];\n};", "export const stringToNumber = (value: string|undefined|null|number, defaultNumber: number) => {\n if(value === undefined || value === null) return defaultNumber;\n const res = Number(value) ?? defaultNumber;\n return isNaN(res) ? defaultNumber : res;\n};", "import { setDecimalPlaces } from './format';\nimport { Vector2, Vector3 } from '../types';\n\n/**\n * u(x) and v(x) are functions ---------->\n *\n * dx(u + v) = dx(u) + dx(v)\n * dx(u - v) = dx(u) - dx(v)\n * dx(u * v) = dx(u) * v + u * dx(v)\n * dx(u / v) = (dx(u) * v - u * dx(v)) / (v ^ 2), when v(x) != 0\n */\n\n// ------------------ Derivatives of Polynomial ---------------------------\n\n/**\n * y = 3x+2\n * dxPolynomial(10, [[3, 1], [2, 0]])\n */\nexport const dxPolynomial = (x: number, polynomial: number[][], decimalPlaces = Infinity) => {\n let res = 0;\n\n for(const part of polynomial){\n if(part.length !== 2) return NaN;\n\n const coeff = part[0];\n const power = part[1];\n res += coeff * power * Math.pow(x, power - 1);\n }\n\n return setDecimalPlaces(res, decimalPlaces);\n}\n\n// ---------------------- Bezier Curves ---------------------------\n\n/**\n * Derivative of Bezier Curve is another Bezier Curve.\n * t must min in range [0, 1]\n */\nexport const dxV2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n // The derivative: P1 * (2t-2) + (2*P3-4*P2) * t + 2 * P2\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -2 * (1 - t); // Math.pow(1 - t, 2)\n const temp2 = 2 - 4 * t; // (1 - t) * 2 * t\n const temp3 = 2 * t; //t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\nexport const dxV2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const dxV3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = -3 * Math.pow(1 - t, 2); //Math.pow(1 - t, 3);\n const temp2 = 3 * (t - 1) * (3 * t - 1); //Math.pow(1 - t, 2) * 3 * t;\n const temp3 = 6 * t - 9 * t * t; // (1 - t) * 3 * t * t;\n const temp4 = 3 * t * t; //t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n\n// ----------------- Derivatives of trigonometry functions ---------------------------\n\nexport const dxSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(Math.cos(x), decimalPlaces);\n};\n\nexport const dxCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-Math.sin(x), decimalPlaces);\n};\n\nexport const dxTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.cos(x) ** 2), decimalPlaces);\n};\n\n/**\n * x != Math.PI * n, where n is an integer\n */\nexport const dxCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sin(x) ** 2), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcSin = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\n/**\n * -1 < x < 1\n */\nexport const dxArcCos = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (Math.sqrt(1 - x ** 2)), decimalPlaces);\n};\n\nexport const dxArcTan = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(1 / (1 + x ** 2), decimalPlaces);\n};\n\nexport const dxArcCot = (x: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(-1 / (1 + x ** 2), decimalPlaces);\n};\n", "import { Matrix, Matrix2, Matrix3, Vector, Vector2, Vector3 } from '../../types';\nimport { m2Inverse, m3Inverse, mInverse, mMulVector, mDelLastColumn, mGetLastColumn } from '../linear-algebra/matrix';\nimport { setDecimalPlaces } from '../format';\nimport { v2Sub } from '../linear-algebra/vector';\n\n/**\n * Linear equation\n * ax + b = c\n * x = (c - b) / a; a != 0\n */\nexport const linearEquation = (equation: Vector3, decimalPlaces = Infinity) : number => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n\n const diff = c - b;\n\n if(a === 0 && diff === 0) return Infinity; // any number is a solution\n if(a === 0) return NaN; // no solution\n\n return setDecimalPlaces(diff / a, decimalPlaces);\n};\n\n/**\n * System of 2 linear equations.\n * [x, y] = inverse(Matrix of equation parameters) x (vector of equation results)\n * ---------------\n * 3x + 2y = 7\n * -6x + 6y = 6\n */\nexport const linearEquationSystem2 = (equation1: Vector3, equation2: Vector3, decimalPlaces = Infinity) : Vector2 | null => {\n const equationParams: Matrix2 = [\n [equation1[0], equation1[1]],\n [equation2[0], equation2[1]],\n ];\n\n const inversed = m2Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector2 = [\n equation1[2],\n equation2[2]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector2;\n};\n\n/**\n * System of 3 linear equations.\n * ---------------------------------------\n * 3x + 2y + 5z = 7\n * -6x + 6y + 6z = 6\n * 2x + 7y - z = 4\n */\nexport const linearEquationSystem3 = (\n equation1: Vector,\n equation2: Vector,\n equation3: Vector,\n decimalPlaces = Infinity) : Vector3 | null => {\n const equationParams: Matrix3 = [\n [equation1[0], equation1[1], equation1[2]],\n [equation2[0], equation2[1], equation2[2]],\n [equation3[0], equation3[1], equation3[2]],\n ];\n\n const inversed = m3Inverse(equationParams);\n if(inversed === null) return null; // no results\n\n const equationResults: Vector3 = [\n equation1[3],\n equation2[3],\n equation3[3]\n ];\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector3;\n};\n\n/**\n * System of N linear equations.\n */\nexport const linearEquationSystemN = (equations: Matrix, decimalPlaces = Infinity) : Vector | null => {\n if(equations.length <= 0) return null;\n\n const equationParams = mDelLastColumn(equations);\n\n const inversed = mInverse(equationParams);\n if(inversed === null) return null; // no results\n\n // the last column of the equations matrix\n const equationResults = mGetLastColumn(equations);\n\n return mMulVector(inversed, equationResults, decimalPlaces) as Vector;\n};\n\n/**\n * Calculate the equation of a line given two points in a 2D space.\n * y = ax + b\n * y - y1 = m(x - x1)\n * m = (y2 - y1) / (x2 - x1)\n */\nexport const getLinearEquationBy2Points = (point1: Vector2, point2: Vector2) : {\n slope: number|undefined,\n yIntercept: number|undefined,\n xIntercept: number|undefined,\n formula: string,\n} => {\n const [deltaX, deltaY] = v2Sub(point2, point1);\n const [x, y] = point1;\n\n if(deltaX === 0) {\n return {\n slope: undefined,\n xIntercept: x,\n yIntercept: undefined,\n formula: `x = ${ x }`,\n };\n }\n\n const m = deltaY / deltaX;\n const b = y - m * x;\n let formula = '';\n\n if(m === 0) {\n formula = `y = ${ b }`;\n }\n else{\n formula = `y = ${ m === 1 ? '' : m }x`;\n\n if(b !== 0) {\n formula += ` ${ b < 0 ? '-' : '+' } ${ Math.abs(b) }`;\n }\n }\n\n return {\n slope: m,\n xIntercept: undefined,\n yIntercept: b,\n formula,\n };\n};", "import { Vector } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport { linearEquation } from './linear-equations';\nimport { isNumber } from '../other';\n\n/**\n * Quadratic Equation.\n * ax^2 + bx + c = d\n */\nexport const quadraticEquation = (equation: Vector, decimalPlaces = Infinity) : Vector => {\n const a = equation[0];\n const b = equation[1];\n const c = equation[2];\n const d = equation[3];\n\n if(a === 0){\n // it's a linear equation -------------------------------------------\n const res = linearEquation([b, c, d], decimalPlaces);\n if(isNumber(res)) return [res];\n return [];\n }\n\n const diff = c - d;\n\n const discriminant = b * b - (4 * a * diff);\n\n if(discriminant < 0){\n return []; // no results\n }\n\n if(discriminant === 0){\n return [ setDecimalPlaces(-b / (2 * a), decimalPlaces) ]; // 1 result\n }\n\n // if(determinant > 0) ---> 2 results\n const t1 = 2 * a;\n const t2 = Math.sqrt(discriminant);\n\n return [\n setDecimalPlaces((-b + t2) / t1, decimalPlaces),\n setDecimalPlaces((-b - t2) / t1, decimalPlaces),\n ];\n};", "import { IBBox, Vector, Vector2, Vector3 } from '../../types';\nimport { setDecimalPlaces } from '../format';\nimport {\n dxV2CubicBezierCurve,\n dxV2QuadraticBezierCurve,\n dxV3CubicBezierCurve,\n dxV3QuadraticBezierCurve\n} from '../derivative';\nimport { v2Normalize, v3Normalize } from '../linear-algebra/vector';\nimport { linearEquation } from '../equations/linear-equations';\nimport { quadraticEquation } from '../equations/quadratic-equations';\nimport { isNumber } from '../other';\n\n/**\n * B\u00E9zier Curves\n * quadratic: y = P1 * (1-t)\u00B2 + P2 * 2 * (1-t)t + P3 * t\u00B2\n * t in range [0, 1]\n */\n\n// -------------------- GET POINT ON CURVE --------------------------\n\n/**\n * Get a point on a quadratic B\u00E9zier curve as a function of time.\n */\nexport const v2QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3QuadraticBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 2);\n const temp2 = (1 - t) * 2 * t;\n const temp3 = t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * centerControlPoint[0] + temp3 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * centerControlPoint[1] + temp3 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * centerControlPoint[2] + temp3 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n/**\n * Get a point on a cubic B\u00E9zier curve as a function of time.\n */\nexport const v2CubicBezierCurve = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n ];\n};\n\nexport const v3CubicBezierCurve = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n\n const temp1 = Math.pow(1 - t, 3);\n const temp2 = Math.pow(1 - t, 2) * 3 * t;\n const temp3 = (1 - t) * 3 * t * t;\n const temp4 = t * t * t;\n\n return [\n setDecimalPlaces(temp1 * startControlPoint[0] + temp2 * center1ControlPoint[0] + temp3 * center2ControlPoint[0] + temp4 * endControlPoint[0], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[1] + temp2 * center1ControlPoint[1] + temp3 * center2ControlPoint[1] + temp4 * endControlPoint[1], decimalPlaces),\n setDecimalPlaces(temp1 * startControlPoint[2] + temp2 * center1ControlPoint[2] + temp3 * center2ControlPoint[2] + temp4 * endControlPoint[2], decimalPlaces),\n ];\n};\n\n// -------------------- TANGENT --------------------------\n\n/**\n * Tangent indicates the direction of travel at specific points along the B\u00E9zier curve,\n * and is literally just the first derivative of our curve.\n */\nexport const v2QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3QuadraticBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n centerControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3QuadraticBezierCurve(t, startControlPoint, centerControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\nexport const v2CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n const dxVector = dxV2CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v2Normalize(dxVector, decimalPlaces);\n};\n\nexport const v3CubicBezierCurveTangent = (\n t: number,\n startControlPoint: Vector3,\n center1ControlPoint: Vector3,\n center2ControlPoint: Vector3,\n endControlPoint: Vector3,\n decimalPlaces = Infinity\n) : Vector3 => {\n const dxVector = dxV3CubicBezierCurve(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n return v3Normalize(dxVector, decimalPlaces);\n};\n\n// -------------------- NORMAL --------------------------\n\n/**\n * Normal is a vector that runs at a right angle to the direction of the curve, and is typically of length 1.\n * To find it, we take the normalised tangent vector, and then rotate it by a 90 degrees.\n */\nexport const v2QuadraticBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2QuadraticBezierCurveTangent(t, startControlPoint, centerControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\nexport const v2CubicBezierCurveNormal = (\n t: number,\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2 => {\n\n const tangent = v2CubicBezierCurveTangent(t, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint, decimalPlaces);\n return [-tangent[1], tangent[0]];\n};\n\n// -------------------- EXTREMA --------------------------\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2QuadraticBezierCurveExtrema = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector => {\n\n /*\n (-2 * (1 - t)) * startControlPoint[0] + (2 - 4 * t) * centerControlPoint[0] + (2 * t) * endControlPoint[0]\n 2 * t * startControlPoint[0] - 4 * t * centerControlPoint[0] + 2 * t * endControlPoint[0] - 2 * startControlPoint[0] + 2 * centerControlPoint[0]\n t * (2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0]) + (- 2 * startControlPoint[0] + 2 * centerControlPoint[0])\n */\n\n const a1 = 2 * startControlPoint[0] - 4 * centerControlPoint[0] + 2 * endControlPoint[0];\n const b1 = -2 * startControlPoint[0] + 2 * centerControlPoint[0];\n const equation1: Vector3 = [a1, b1, 0];\n const res1 = linearEquation(equation1, decimalPlaces);\n\n const a2 = 2 * startControlPoint[1] - 4 * centerControlPoint[1] + 2 * endControlPoint[1];\n const b2 = -2 * startControlPoint[1] + 2 * centerControlPoint[1];\n const equation2: Vector3 = [a2, b2, 0];\n const res2 = linearEquation(equation2, decimalPlaces);\n\n const res: Vector = [];\n\n if(isNumber(res1)){\n res.push(res1);\n }\n\n if(isNumber(res2)){\n res.push(res2);\n }\n\n return res;\n};\n\n/**\n * Find maxima and minima by solving the equation B'(t) = 0\n * Returns result in [0, 1] range.\n */\nexport const v2CubicBezierCurveExtrema = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : Vector2|null => {\n\n const a1 = -3 * startControlPoint[0] + 9 * center1ControlPoint[0] - 9 * center2ControlPoint[0] + 3 * endControlPoint[0];\n const b1 = 6 * startControlPoint[0] - 12 * center1ControlPoint[0] + 6 * center2ControlPoint[0];\n const c1 = -3 * startControlPoint[0] + 3 * center1ControlPoint[0];\n const equation1: Vector = [a1, b1, c1, 0];\n\n const a2 = -3 * startControlPoint[1] + 9 * center1ControlPoint[1] - 9 * center2ControlPoint[1] + 3 * endControlPoint[1];\n const b2 = 6 * startControlPoint[1] - 12 * center1ControlPoint[1] + 6 * center2ControlPoint[1];\n const c2 = -3 * startControlPoint[1] + 3 * center1ControlPoint[1];\n const equation2: Vector = [a2, b2, c2, 0];\n\n // Any value between 0 and 1 is a root that matters for B\u00E9zier curves, anything below or above that is irrelevant (because B\u00E9zier curves are only defined over the interval [0,1]).\n const res1 = quadraticEquation(equation1, decimalPlaces).filter(num => num >= 0 && num <= 1);\n const res2 = quadraticEquation(equation2, decimalPlaces).filter(num => num >= 0 && num <= 1);\n\n const res = [...res1, ...res2];\n if(res.length === 2){\n return [...res1, ...res2] as Vector2;\n }\n\n return null;\n};\n\n// -------------------- BOUNDING BOX --------------------------\n\nexport const v2QuadraticBezierBBox = (\n startControlPoint: Vector2,\n centerControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2QuadraticBezierCurveExtrema(startControlPoint, centerControlPoint, endControlPoint);\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2QuadraticBezierCurve(percent, startControlPoint, centerControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x);\n maxX = Math.max(maxX, x);\n\n minY = Math.min(minY, y);\n maxY = Math.max(maxY, y);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\nexport const v2CubicBezierBBox = (\n startControlPoint: Vector2,\n center1ControlPoint: Vector2,\n center2ControlPoint: Vector2,\n endControlPoint: Vector2,\n decimalPlaces = Infinity\n) : IBBox => {\n\n const extrema = v2CubicBezierCurveExtrema(startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint) || [];\n\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for(const percent of extrema){\n const point = v2CubicBezierCurve(percent, startControlPoint, center1ControlPoint, center2ControlPoint, endControlPoint);\n\n const x = point[0];\n const y = point[1];\n\n minX = Math.min(minX, x ?? Infinity);\n maxX = Math.max(maxX, x ?? -Infinity);\n\n minY = Math.min(minY, y ?? Infinity);\n maxY = Math.max(maxY, y ?? -Infinity);\n }\n\n minX = setDecimalPlaces(Math.min(minX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n maxX = setDecimalPlaces(Math.max(maxX, startControlPoint[0], endControlPoint[0]), decimalPlaces);\n minY = setDecimalPlaces(Math.min(minY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n maxY = setDecimalPlaces(Math.max(maxY, startControlPoint[1], endControlPoint[1]), decimalPlaces);\n\n return {\n x: minX,\n y: minY,\n w: Math.abs(maxX - minX),\n h: Math.abs(maxY - minY),\n x2: maxX,\n y2: maxY,\n }\n};\n\n\n", "import { Vector2 } from '../types';\nimport { v2Sub } from './linear-algebra/vector';\nimport { getV2Angle } from './angle';\nimport { convertRange } from './other';\n\n/**\n * Circle Equation\n * x^2 + y^2 = radius^2\n * ----------------------\n * Circle Parametric Equation\n * x(t) = radius * cos(t)\n * y(t) = radius * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const circleMovement = (center: Vector2, angle: number, radius: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius,\n center[1] + Math.sin(angle) * radius\n ];\n};\n\n/**\n * Circle Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const circleMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radius: number\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return circleMovement(center, angle, radius);\n};\n\n/**\n * Ellipse Equation\n * (x - centerX)^2 / (radius1^2) + (y - centerY)^2 / (radius2^2) = 1\n * -----------------------------------------------------------------\n * Ellipse Parametric Equation\n * x(t) = radius1 * cos(t)\n * y(t) = radius2 * sin(t)\n * t is the parameter = angle\n *\n * Angle should be in the range [0, Math.PI]\n */\nexport const ellipseMovement = (center: Vector2, angle: number, radius1: number, radius2: number): Vector2 => {\n angle = angle % Math.PI * 2;\n\n return [\n center[0] + Math.cos(angle) * radius1,\n center[1] + Math.sin(angle) * radius2\n ];\n};\n\n/**\n * Ellipse Movement After Mouse.\n * Mouse Positions:\n * - pageX/Y coordinates are relative to the top left corner of the whole rendered page (including parts hidden by scrolling),\n * - screenX and screenY: Relative to the top left of the physical screen/monitor, this reference point only moves if you increase or decrease the number of monitors or the monitor resolution.\n * - clientX/Y coordinates are relative to the top left corner of the visible part of the page, \"seen\" through browser window.\n * - offsetX and offsetY are relative to the parent container,\n */\nexport const ellipseMovementAfterMouse = (\n mouse: Vector2,\n center: Vector2,\n radii: Vector2\n): Vector2 => {\n\n const vector = v2Sub(mouse, center);\n\n let angle = getV2Angle(vector);\n\n // convert the angle from the range [0, Math.PI*2] to the range [0, Math.PI]\n angle = convertRange(angle, 0, Math.PI*2, 0, Math.PI);\n\n return ellipseMovement(center, angle, radii[0], radii[1]);\n};\n\n/**\n * Sine Wave Equation (Sinusoid)\n * -----------------------------\n * const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n * amplitude = the peak deviation of the function from zero\n * frequency = number of cycles\n * phase = specifies (in radians) where in its cycle the oscillation is at t = 0.\n * think of it as \"shifting\" the starting point of the function to the right (positive p) or left (negative)\n */\nexport const sineWaveMovement = (x: number, amplitude: number, frequency: number, phase: number) : Vector2 => {\n /*\n example values:\n const amplitude = 50;\n const frequency = 0.005;\n const phase = 0;\n x: [0, 1000]\n */\n const y = amplitude * Math.sin(2 * Math.PI * frequency * x + phase);\n\n return [x, y];\n};\n\n/**\n * Lissajous curve (Lissajous figure or Bowditch curve)\n * Parametric equation #1\n * f(t) = A * sin(k * t + m)\n * f(t) = B * sin(n * t)\n * 0 <= m <= PI/2\n * k, n >= 1\n * -----------------------\n * Parametric equation #2\n * f(t) = A * cos(k * t - m)\n * f(t) = B * cos(n * t - p)\n * -----------------------------\n * Shapes:\n * k = 1, n = 1, m = 0, p = 0 ---> line\n * A = B, k = 1, n = 1, m = PI/2, p = PI/2 ----> circle\n * A != B, k = 1, n = 1, m = PI/2, p = PI/2 ----> ellipse\n * k = 2, n = 2, m = PI/2, p = PI/2 ----> section of a parabola\n */\nexport const lissajousCurve = (\n width: number,\n height: number,\n t: number,\n k: number,\n n: number,\n m: number,\n p: number\n) :Vector2 => {\n return [\n width * Math.cos(k * t - m),\n height * Math.cos(n * t - p),\n ];\n};\n", "import { getRandom } from './random';\nimport { HSLColor, LABColor, RGBColor } from '../types';\nimport { mod } from './other';\nimport { setDecimalPlaces } from './format';\n\n// ------------------------ RANDOM COLOR -------------------------------------\n\nexport const getRandomRGBColor = () : RGBColor => {\n const hslColor = getRandomHSLColor();\n return hslToRgb(hslColor);\n};\n\nexport const getRandomHexColor = () : string => {\n const hslColor = getRandomHSLColor();\n return hslToHex(hslColor);\n};\n\nexport const getRandomHSLColor = () : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given hue\n */\nexport const getRandomHSLColorWithHue = (h: number) : HSLColor => {\n const s = getRandom(0, 100);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given saturation\n */\nexport const getRandomHSLColorWithSaturation = (s: number) : HSLColor => {\n const h = getRandom(1, 360);\n const l = getRandom(0, 100);\n return [h, s, l];\n};\n\n/**\n * generate random color with the given lightness\n */\nexport const getRandomHSLColorWithLightness = (l: number) : HSLColor => {\n const h = getRandom(1, 360);\n const s = getRandom(0, 100);\n return [h, s, l];\n};\n\nexport const getRandomGrayscaleHSLColor = () : HSLColor => {\n const l = getRandom(0, 100);\n return [0, 0, l];\n};\n\nexport const getRandomHSLColorWithinRanges = (\n hueStart = 1, hueEnd = 360,\n saturationStart = 0, saturationEnd = 100,\n lightStart = 0, lightEnd = 100\n) : HSLColor => {\n const h = getRandom(hueStart, hueEnd);\n const s = getRandom(saturationStart, saturationEnd);\n const l = getRandom(lightStart, lightEnd);\n return [h, s, l];\n};\n\n// ----------------------- CONVERT COLORS --------------------------------------\n\n/**\n * helper: convert hue value to degrees.\n * @param {number} h\n * @return {number} [0, 360] degrees\n */\nconst convertHueToDegrees = (h : number) : number => {\n\n // the hue value needs to be multiplied by 60 to convert it to degrees\n h *= 60;\n\n // if hue becomes negative, you need to add 360 to, because a circle has 360 degrees\n if(h < 0){\n h += 360;\n }\n\n return h;\n // convert huw to %\n // return h * 100 / 360;\n};\n\n/**\n * get hue from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] % - we use here % instead of [0, 359] degrees\n */\nconst getHue = (r : number, g : number, b : number, min : number | undefined = undefined, max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (max === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no hue, as it's gray\n if(min === max) return 0;\n\n const diff = max - min;\n\n let h = 0;\n\n // if red is max\n if(max === r){\n h = (g - b) / diff + (g < b ? 6 : 0);\n }\n\n // if green is max\n if(max === g){\n h = 2 + (b - r) / diff;\n }\n\n // if blue is max\n if(max === b){\n h = 4 + (r - g) / diff;\n }\n\n return convertHueToDegrees(h);\n};\n\n/**\n * get luminance from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @return {number} [0, 100] %\n */\nconst getLuminance = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // calculate the luminance value\n // @ts-ignore\n const l = (min + max) / 2; // [0, 1]\n\n // return l value in %\n return l * 100;\n};\n\n/**\n * get saturation from RGB\n * @param {number} r [0, 255]\n * @param {number} g [0, 255]\n * @param {number} b [0, 255]\n * @param {number|undefined=} min - min number of [r, g, b]\n * @param {number|undefined=} max - max number of [r, g, b]\n * @param {number|undefined=} l - luminance in [0, 100] %\n * @return {number} [0, 100] %\n */\nconst getSaturation = (\n r : number,\n g : number,\n b : number,\n min : number | undefined = undefined,\n max : number | undefined = undefined,\n l : number | undefined = undefined) : number => {\n\n // find the minimum and maximum values of r, g, and b if they are not provided\n min = (min === undefined) ? Math.min(r, g, b) : min;\n max = (min === undefined) ? Math.max(r, g, b) : max;\n\n // if the min and max value are the same -> no saturation, as it's gray\n if(min === max) return 0;\n\n // calculate luminance if it's not provided\n l = (l === undefined) ? getLuminance(r, g, b) : l;\n\n // check the level of luminance\n const s = (l <= 50) ?\n // @ts-ignore\n ((max - min) / (max + min)) : // this formula is used when luminance <= 50%\n // @ts-ignore\n (max - min) / (2.0 - max - min); // this formula is used when luminance > 50%\n\n // return saturation in %\n return s * 100;\n};\n\nexport const rgbToHsl = (rgb: RGBColor, decimalPlaces = Infinity): HSLColor => {\n\n // convert rgb values to the range [0, 1]\n const r = rgb[0] / 255;\n const g = rgb[1] / 255;\n const b = rgb[2] / 255;\n\n // find the minimum and maximum values of r, g, and b\n const min = Math.min(r, g, b);\n const max = Math.max(r, g, b);\n\n // calculate the luminance value in %\n const l = getLuminance(r, g, b, min, max);\n\n // calculate the saturation in %\n const s = getSaturation(r, g, b, min, max, l);\n\n // calculate the hue in % (not in degrees!)\n const h = getHue(r, g, b, min, max);\n\n if(h > 360 || s > 100 || l > 100){\n return [0, 0, 100];\n }\n\n if(h < 0 || s < 0 || l < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(h, decimalPlaces),\n setDecimalPlaces(s, decimalPlaces),\n setDecimalPlaces(l, decimalPlaces),\n ];\n};\n\n/**\n * helper: HSL to RGB\n */\nconst hslToRgbHelper = (helper1 : number, helper2 : number, colorHelper : number) : number => {\n\n // all values need to be between 0 and 1\n // if you get a negative value you need to add 1 to it\n if(colorHelper < 0) colorHelper += 1;\n\n // if you get a value above 1 you need to subtract 1 from it.\n if(colorHelper > 1) colorHelper -= 1;\n\n if(colorHelper * 6 < 1) return helper2 + (helper1 - helper2) * 6 * colorHelper;\n\n if(colorHelper * 2 < 1) return helper1;\n\n if(colorHelper * 3 < 2){\n return helper2 + (helper1 - helper2) * (0.666 - colorHelper) * 6;\n }\n else{\n return helper2;\n }\n};\n\nexport const hslToRgb = (hsl: HSLColor, decimalPlaces = Infinity): RGBColor => {\n\n // convert all values to [0, 1] from %\n const h = hsl[0] / 100;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n // if there is no saturation -> it\u2019s grey\n if(s === 0){\n // convert the luminance from [0, 1] to [0, 255]\n const gray = l * 255;\n return [gray, gray, gray];\n }\n\n // check the level of luminance\n const helper1 = (l < 0.5) ?\n (l * (1.0 + s)) :\n (l + s - l * s);\n\n const helper2 = 2 * l - helper1;\n\n const rHelper = h + 0.333;\n const gHelper = h;\n const bHelper = h - 0.333;\n\n let r = hslToRgbHelper(helper1, helper2, rHelper);\n let g = hslToRgbHelper(helper1, helper2, gHelper);\n let b = hslToRgbHelper(helper1, helper2, bHelper);\n\n // convert rgb to [0, 255]\n r *= 255;\n g *= 255;\n b *= 255;\n\n if(r > 255 || g > 255 || b > 255){\n return [255, 255, 255];\n }\n\n if(r < 0 || g < 0 || b < 0){\n return [0, 0, 0];\n }\n\n return [\n setDecimalPlaces(r, decimalPlaces),\n setDecimalPlaces(g, decimalPlaces),\n setDecimalPlaces(b, decimalPlaces),\n ];\n};\n\n/**\n * HSL to hex\n * hslToHex(360, 100, 50) // [360, 100, 5] ==> \"#ff0000\" (red)\n */\nexport const hslToHex = (hsl: HSLColor) => {\n\n if(hsl[0] > 360 || hsl[1] > 100 || hsl[2] > 100){\n return '#ffffff';\n }\n\n if(hsl[0] < 0 || hsl[1] < 0 || hsl[2] < 0){\n return '#000000';\n }\n\n const h = hsl[0] / 360;\n const s = hsl[1] / 100;\n const l = hsl[2] / 100;\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n };\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n};\n\n/**\n * RGB to HEX\n * rgbToHex([235, 64, 52]) // #eb4034\n */\nexport const rgbToHex = (rgb: RGBColor) => {\n const [r, g, b] = rgb;\n return '#' + (1 << 24 | r << 16 | g << 8 | b).toString(16).slice(1);\n};\n\nexport const hexToRgb = (hex: string) : RGBColor | null => {\n\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n const _hex = hex.replace(shorthandRegex, (_m, r, g, b) => {\n return r + r + g + g + b + b;\n });\n\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(_hex);\n if(!result) return null;\n\n const r = parseInt(result[1], 16);\n const g = parseInt(result[2], 16);\n const b = parseInt(result[3], 16);\n\n return [r, g, b];\n};\n\nexport const rgbToLab = (rgb: RGBColor, decimalPlaces = Infinity) : LABColor => {\n\n let r = rgb[0] / 255;\n let g = rgb[1] / 255;\n let b = rgb[2] / 255;\n\n r = (r > 0.04045) ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;\n g = (g > 0.04045) ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;\n b = (b > 0.04045) ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;\n\n let x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;\n let y = (r * 0.2126 + g * 0.7152 + b * 0.0722) / 1.00000;\n let z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;\n\n x = (x > 0.008856) ? Math.pow(x, 1/3) : (7.787 * x) + 16/116;\n y = (y > 0.008856) ? Math.pow(y, 1/3) : (7.787 * y) + 16/116;\n z = (z > 0.008856) ? Math.pow(z, 1/3) : (7.787 * z) + 16/116;\n\n return [\n setDecimalPlaces((116 * y) - 16, decimalPlaces),\n setDecimalPlaces(500 * (x - y), decimalPlaces),\n setDecimalPlaces(200 * (y - z), decimalPlaces),\n ];\n};\n\nexport const labToRgb = (lab: LABColor, decimalPlaces = Infinity) : RGBColor => {\n let y = (lab[0] + 16) / 116;\n let x = lab[1] / 500 + y;\n let z = y - lab[2] / 200;\n\n x = 0.95047 * ((x * x * x > 0.008856) ? x * x * x : (x - 16/116) / 7.787);\n y = 1.00000 * ((y * y * y > 0.008856) ? y * y * y : (y - 16/116) / 7.787);\n z = 1.08883 * ((z * z * z > 0.008856) ? z * z * z : (z - 16/116) / 7.787);\n\n let r = x * 3.2406 + y * -1.5372 + z * -0.4986;\n let g = x * -0.9689 + y * 1.8758 + z * 0.0415;\n let b = x * 0.0557 + y * -0.2040 + z * 1.0570;\n\n r = (r > 0.0031308) ? (1.055 * Math.pow(r, 1/2.4) - 0.055) : 12.92 * r;\n g = (g > 0.0031308) ? (1.055 * Math.pow(g, 1/2.4) - 0.055) : 12.92 * g;\n b = (b > 0.0031308) ? (1.055 * Math.pow(b, 1/2.4) - 0.055) : 12.92 * b;\n\n return [\n setDecimalPlaces(Math.max(0, Math.min(1, r)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, g)) * 255, decimalPlaces),\n setDecimalPlaces(Math.max(0, Math.min(1, b)) * 255, decimalPlaces),\n ];\n};\n\n// ----------------------- GET SHIFTED COLORS --------------------------------------\n\nexport const getShiftedHue = (color: HSLColor, shift = 180) : HSLColor => {\n let hue = color[0];\n hue += shift;\n\n if (hue > 360 || hue < 0) {\n hue = mod(hue, 360);\n }\n\n return [hue, color[1], color[2]];\n};\n\nexport const getShiftedLightness = (color: HSLColor, shift = 10) : HSLColor => {\n let lightness = color[2];\n lightness += shift;\n\n if (lightness > 100 || lightness < 0) {\n lightness = mod(lightness, 100);\n }\n\n return [color[0], color[1], lightness];\n};\n\nexport const getShiftedSaturation = (color: HSLColor, shift = 10) : HSLColor => {\n let saturation = color[1];\n saturation += shift;\n\n if (saturation > 100) {\n saturation -= 100;\n }\n\n if(saturation < 0){\n saturation += 100;\n }\n\n return [color[0], saturation, color[2]];\n};\n\n// ----------------------- SIMILAR COLORS --------------------------------------\n\n/**\n * Measure the perceptual difference between two RGB colors using the CIE76 color difference formula:\n * delta = Math.sqrt((L2 - L1)^2 + (a2 - a1)^2 + (b2 - b1)^2)\n * https://en.wikipedia.org/wiki/Color_difference\n * https://stackoverflow.com/questions/13586999/color-difference-similarity-between-two-values-with-js\n * <= 1.0 Not perceptible by human eyes.\n * 1 - 2 Perceptible through close observation.\n * 2 - 10 Perceptible at a glance.\n * 11 - 49 Colors are more similar than opposite\n * 100 Colors are exact opposite\n */\nexport const getColorsDelta = (rgbA: RGBColor, rgbB: RGBColor, decimalPlaces = Infinity) => {\n const labA = rgbToLab(rgbA, decimalPlaces);\n const labB = rgbToLab(rgbB, decimalPlaces);\n\n // differences between the LAB components of the two colors\n const deltaL = labA[0] - labB[0];\n const deltaA = labA[1] - labB[1];\n const deltaB = labA[2] - labB[2];\n\n // chroma components\n const c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);\n const c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);\n const deltaC = c1 - c2;\n\n // difference in hue, deltaH, which takes into account both the differences\n // in the a* and b* components of LAB and the differences in chroma.\n let deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;\n deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);\n\n const sc = 1.0 + 0.045 * c1;\n const sh = 1.0 + 0.015 * c1;\n\n // It applies weighting factors to the differences in lightness (deltaL),\n // chroma (deltaC), and hue (deltaH).\n const deltaLKlsl = deltaL / (1.0);\n const deltaCkcsc = deltaC / (sc);\n const deltaHkhsh = deltaH / (sh);\n\n // It computes the final color difference using the CIE76 formula:\n // deltaE = sqrt(deltaLKlsl^2 + deltaCkcsc^2 + deltaHkhsh^2),\n // where deltaLKlsl is the weighted lightness difference,\n // deltaCkcsc is the weighted chroma difference,\n // and deltaHkhsh is the weighted hue difference.\n const i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;\n\n // It returns the calculated color difference,\n // optionally rounded to the specified number of decimal places.\n return i < 0 ? 0 : Math.sqrt(i);\n};\n", "/**\n * guid like '932ade5e-c515-4807-ac01-73b20ab3fb66'\n */\nexport const guid = () => {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = Math.random() * 16 | 0;\n return (c == 'x' ? r : r & 0x3 | 0x8).toString(16);\n });\n};\n\n/**\n * id like 'df4unio1opulby2uqh4'\n */\nexport const newId = () => {\n return Math.random().toString(36).substring(2) + (new Date()).getTime().toString(36);\n};\n", "import { ICircle, IPolygon, IRect, Matrix2, Vector2 } from '../types';\nimport { mod } from './other';\nimport { v2GetNormal, v2DotProduct } from './linear-algebra/vector';\n\n/**\n * Rectangles collision detection.\n * Rectangles should not be rotated.\n * The algorithm works by ensuring there is no gap between any of the 4 sides of the rectangles.\n * Any gap means a collision does not exist.\n * Returns true if collision is detected.\n */\nexport const rectCollide = (rect1: IRect, rect2: IRect) : boolean => {\n return rect1.x <= rect2.x + rect2.w &&\n rect1.x + rect1.w >= rect2.x &&\n rect1.y <= rect2.y + rect2.h &&\n rect1.h + rect1.y >= rect2.y;\n};\n\n/**\n * Circles collision detection.\n * This algorithm works by taking the center points of the two circles\n * and ensuring the distance between the center points\n * are less than the two radii added together.\n * Returns true if collision is detected.\n */\nexport const circleCollide = (circle1: ICircle, circle2: ICircle) => {\n const dx = Math.abs(circle1.cx - circle2.cx);\n const dy = Math.abs(circle1.cy - circle2.cy);\n const distance = Math.sqrt(dx * dx + dy * dy);\n return distance <= circle1.r + circle2.r;\n};\n\n//-------------------- Separating Axis Theorem (SAT) Collision detection -------------------------\n\nconst getEdges = (poly: IPolygon) : Matrix2[] => {\n const edges: Matrix2[] = [];\n\n for(let i= 0; i {\n const edges: Matrix2[] = [];\n\n // collect polygon edges, and combine then into a single array\n edges.push(...getEdges(poly1));\n edges.push(...getEdges(poly2));\n\n // for each edge, find the normal vector and project both polygons onto it\n for (const edge of edges) {\n const normal = v2GetNormal(edge[0], edge[1]);\n const p1Proj = projectPolygon(poly1, normal);\n const p2Proj = projectPolygon(poly2, normal);\n\n // Check if the projections overlap\n const isOverlap = p1Proj.max >= p2Proj.min && p2Proj.max >= p1Proj.min;\n\n // Check if the projections overlap; if not, the polygons do not collide\n if (!isOverlap) return false;\n }\n\n // If all tests pass, the polygons overlap and collide\n return true;\n};\n\n/**\n * Project every polygon point onto the normal.\n * Then find min and max.\n */\nconst projectPolygon = (polygon: IPolygon, normal: Vector2): { min: number, max: number } => {\n let min = Infinity;\n let max = -Infinity;\n\n // Project each vertex of the polygon onto the axis\n for (const vertex of polygon) {\n const projection = v2DotProduct(vertex, normal);\n min = Math.min(min, projection);\n max = Math.max(max, projection);\n }\n\n return { min, max };\n};", "export interface IAnimationProps {\n duration?: number;\n callback: (result: IAnimationResult) => void;\n restartOnResize?: boolean;\n resizeCallback?: (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => void;\n}\n\nexport interface IAnimationResult {\n start: () => void;\n stop: () => void;\n pause: () => void;\n resume: () => void;\n restart: () => void;\n isAnimating: () => boolean;\n getStartTime: () => number|undefined;\n getElapsedTime: () => number|undefined;\n getPercent: () => number|undefined;\n getResizeObserver: () => ResizeObserver|undefined;\n}\n\nexport const animate = (props: IAnimationProps) : IAnimationResult => {\n\n const _duration = props.duration !== undefined ? props.duration : Infinity;\n\n let startTime: number|undefined = undefined; // in milliseconds\n let animationId: number|undefined = undefined;\n\n // the time elapsed since the start of the animation (in milliseconds)\n let elapsed: number|undefined = undefined;\n let previousTimeStamp: number|undefined = undefined;\n\n let animating = false;\n let observer: ResizeObserver|undefined = undefined;\n\n // -------------------- COMMANDS ---------------------\n\n const stop = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = false;\n\n /*if(observer !== undefined){\n observer.disconnect();\n observer = undefined;\n }*/\n\n if(animationId === undefined) return;\n window.cancelAnimationFrame(animationId);\n };\n\n const restart = () => {\n stop();\n start();\n };\n\n const pause = () => {\n animating = false;\n };\n\n const resume = () => {\n animating = true;\n };\n\n /**\n * Animation Step.\n * @param {number} timeStamp in milliseconds\n */\n const step = (timeStamp: DOMHighResTimeStamp) => {\n\n if (startTime === undefined) {\n startTime = timeStamp;\n }\n\n // the time elapsed since the start of the animation (in milliseconds)\n elapsed = timeStamp - startTime;\n\n if (animating && previousTimeStamp !== timeStamp && typeof props.callback === 'function') {\n\n // do the rendering .............\n props.callback(getResult());\n }\n\n if(elapsed <= _duration){\n previousTimeStamp = timeStamp;\n animationId = window.requestAnimationFrame(step);\n }\n else{\n stop();\n }\n };\n\n const observerHandler = (_entries: ResizeObserverEntry[], _observer: ResizeObserver) => {\n restart();\n\n if(typeof props.resizeCallback === 'function'){\n props.resizeCallback(_entries, _observer);\n }\n };\n\n const start = () => {\n startTime = undefined;\n elapsed = undefined;\n previousTimeStamp = undefined;\n animating = true;\n\n if(props.restartOnResize && window.ResizeObserver && observer === undefined){\n observer = new ResizeObserver(observerHandler);\n observer.observe(document.body, { box: 'border-box' });\n }\n else{\n animationId = window.requestAnimationFrame(step);\n }\n };\n\n // --------------- GET INFO ----------------------\n\n /**\n * the time elapsed since the start of the animation (in milliseconds)\n */\n const getElapsedTime = () : number|undefined => {\n return elapsed;\n };\n\n const isAnimating = () => {\n return animating;\n };\n\n const getStartTime = () => {\n return startTime;\n };\n\n const getPercent = () => {\n if(_duration === Infinity || elapsed === undefined) return undefined;\n return elapsed * 100 / _duration;\n };\n\n const getResizeObserver = () => {\n return observer;\n };\n\n const getResult = () : IAnimationResult => {\n return {\n\n // commands --------------\n start,\n stop,\n pause,\n resume,\n restart,\n\n // information -------\n isAnimating,\n getElapsedTime,\n getStartTime,\n getPercent,\n getResizeObserver,\n };\n };\n\n return getResult();\n};\n", "import { setDecimalPlaces } from './format';\n\nexport const getCircleCircumference = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * radius, decimalPlaces);\n};\n\nexport const getEllipseCircumference = (radius1: number, radius2: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(2 * Math.PI * Math.sqrt((radius1 ** 2 + radius2 ** 2) / 2), decimalPlaces);\n};\n\nexport const isAngleInCircleArc = (startAngleDeg: number, endAngleDeg: number, currentDegrees: number) : boolean => {\n\n if(startAngleDeg > endAngleDeg) {\n endAngleDeg += 360;\n }\n\n return currentDegrees >= startAngleDeg && currentDegrees <= endAngleDeg ||\n (currentDegrees + 360) >= startAngleDeg && (currentDegrees + 360) <= endAngleDeg;\n};\n\n/**\n * get the side of a square inscribed in a circle\n */\nexport const getSquareInCircleSide = (radius: number, decimalPlaces = Infinity) => {\n return setDecimalPlaces(radius * 2 / Math.sqrt(2), decimalPlaces);\n};\n", "/**\n * 1 + 2 + ... + n = n * (n + 1) / 2\n */\nexport const naturalNumbersSequenceSum = (n: number) => {\n return n * (n + 1) / 2;\n};\n\n/**\n * n = the number of terms to be added\n * a = the first term in the sequence\n * d = the constant value between terms\n */\nexport const arithmeticSequenceSum = (n: number, a: number, d: number) => {\n return (n / 2) * (2 * a + (n - 1) * d);\n};", "import { setDecimalPlaces } from './format';\n\n// -------------------- CENTRAL TENDENCY ----------------------------\n\n/**\n * Central tendency: Calculate the Average (mean = \u03BC)\n * Sum of all numbers divided by the array length.\n */\nexport const getArithmeticMean = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const sum = data.reduce((acc, val) => acc + val, 0);\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Frequency map: number ---> it's frequency\n */\nexport const getArithmeticMeanFromFrequency = (frequencyMap: Map, decimalPlaces = Infinity) => {\n\n let mean = 0;\n\n for(const [val, frequency] of frequencyMap) {\n mean += val * frequency;\n }\n\n return setDecimalPlaces(mean, decimalPlaces);\n};\n\n/**\n * Central tendency: What is the central number in the sorted array?\n * Good for lists like [3, 3, 3, 3, 3, 3, 100] - 100 here is called \"Outlier\"\n */\nexport const getMedian = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const copy = [...data].sort((num1, num2) => num1 - num2);\n const mid = Math.floor(copy.length / 2);\n\n if(copy.length % 2 === 0) {\n return setDecimalPlaces((copy[mid] + copy[mid - 1]) / 2, decimalPlaces);\n }\n else {\n return setDecimalPlaces(copy[mid], decimalPlaces);\n }\n};\n\n/**\n * Central tendency: What number is most common in the set.\n * If all numbers have the same frequency, there is no mode.\n */\nexport const getMode = (data: number[]) : number[]|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n // Count frequency of each number in the data array.\n const frequencyMap: Map = new Map();\n for (const num of data) {\n frequencyMap.set(num, (frequencyMap.get(num) || 0) + 1);\n }\n\n let maxFrequency = 0;\n let modes: number[] = [];\n\n // Find the maximum frequency\n for (const [num, frequency] of frequencyMap) {\n if (frequency > maxFrequency) {\n maxFrequency = frequency;\n modes = [num];\n }\n else if (frequency === maxFrequency) {\n modes.push(num);\n }\n }\n\n // If all numbers have the same frequency, there is no mode\n if (modes.length === data.length) {\n return undefined;\n }\n\n // Return the mode(s)\n return modes.length === 1 ? [modes[0]] : modes;\n};\n\n/*\nTODO:\n- geometric mean\n- harmonic mean\n */\n\n// -------------------- DISPERSION ----------------------------\n\n/**\n * Dispersion: the average square distance from the mean.\n * Sum of (x - mean)^2 / N\n */\nexport const getVariance1 = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + ((val - mean) ** 2), 0);\n\n return setDecimalPlaces(sum / data.length, decimalPlaces);\n};\n\n/**\n * Another formula of dispersion - the average square distance from the mean.\n * (Sum of x^2) / N - (mean ^ 2)\n */\nexport const getVariance = (data: number[], decimalPlaces = Infinity) : number|undefined => {\n if(!data || data.length <= 0) return undefined;\n\n const mean = getArithmeticMean(data);\n if(mean === undefined) return undefined;\n\n const sum = data.reduce((acc, val) => acc + (val ** 2), 0);\n\n return setDecimalPlaces((sum / data.length) - (mean ** 2), decimalPlaces);\n};\n\n/**\n * \u03C3\n */\nexport const getStandardDeviation = (data: number[], decimalPlaces = Infinity) => {\n const variance = getVariance(data) ?? 0;\n return setDecimalPlaces(Math.sqrt(variance), decimalPlaces);\n};", "import { setDecimalPlaces } from './format';\nimport { getArithmeticMean, getStandardDeviation } from './statistics';\nimport { IMlNormalizeResult, IMlStandardizeResult } from '../types';\n\n// --------------------- NORMALIZE --------------------------------\n\n/**\n * Changes value to be in the range [0, 1].\n */\nexport const mlNormalizeValue = (value: number, min: number, max: number, decimalPlaces = Infinity) : number => {\n const diff = max - min;\n if(diff === 0) return 0;\n return setDecimalPlaces((value - min) / diff, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [0, 1].\n */\nexport const mlNormalizeArray = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n const copy = [...data];\n\n for(let i=0; i {\n const min = Math.min(...data);\n const max = Math.max(...data);\n const _data = mlNormalizeArray(data, min, max, decimalPlaces);\n\n return {\n min: setDecimalPlaces(min, decimalPlaces),\n max: setDecimalPlaces(max, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlNormalizeUnseenData = (data: number[], min: number, max: number, decimalPlaces = Infinity): number[] => {\n return mlNormalizeArray(data, min, max, decimalPlaces);\n};\n\n// --------------------- STANDARDIZE --------------------------------\n\n/**\n * Changes value to be in the range [-1, 1].\n */\nexport const mlStandardizeValue = (value: number, mean: number, stdDev: number, decimalPlaces = Infinity) : number => {\n if(stdDev === 0) return 0;\n return setDecimalPlaces((value - mean) / stdDev, decimalPlaces);\n};\n\n/**\n * Returns a copy of array, where each value will be in the range [-1, 1].\n */\nexport const mlStandardizeArray = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity) : number[] => {\n return [...data].map(value => mlStandardizeValue(value, mean, stdDev, decimalPlaces));\n};\n\nexport const mlStandardizeTestData = (data: number[], decimalPlaces = Infinity): IMlStandardizeResult => {\n const mean = getArithmeticMean(data) ?? 0;\n const stdDev = getStandardDeviation(data);\n const _data = mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n\n return {\n mean: setDecimalPlaces(mean, decimalPlaces),\n stdDev: setDecimalPlaces(stdDev, decimalPlaces),\n data: _data,\n };\n};\n\n/**\n * Alias.\n */\nexport const mlStandardizeUnseenData = (data: number[], mean: number, stdDev: number, decimalPlaces = Infinity): number[] => {\n return mlStandardizeArray(data, mean, stdDev, decimalPlaces);\n};", "/**\n * Sum of 1 to n numbers:\n * (n * (n + 1)) / 2\n */\nexport const naturalNumbersSum1ToN = (n: number): number => {\n return (n / 2) * (n + 1);\n};\n\n/**\n * Sum of m to n numbers.\n */\nexport const naturalNumbersSumMToN = (m: number, n: number): number => {\n return (n - m + 1) * (m + n) / 2;\n};", "/**\n * The simplest and straightforward method\n * but can become inefficient for extremely large numbers\n * due to growing computational time.\n */\nexport const factorialIterative = (n: number, start = 0): number => {\n\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n let result = 1;\n for (let i = start; i <= n; i++) {\n result *= i;\n }\n return result;\n};\n\n/**\n * A recursive approach is a classic method for calculating factorials\n * but can lead to stack overflow errors\n * for very large inputs because of deep recursion.\n * However, it's a direct translation\n * of the mathematical definition of factorial.\n */\nexport const factorialRecursive = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n // Base case: when n reaches start, return start instead of further reducing\n if (n === start) return start;\n\n // Recursive call\n return n * factorialRecursive(n - 1, start);\n};\n\n/**\n * Memoization (Top-Down Dynamic Programming).\n */\nexport const factorialMemoized = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === 0) {\n if (n === 0) {\n return 1; // 0! is defined as 1\n }\n else {\n start = 1; // Adjust start to 1 to prevent multiplication by zero\n }\n }\n\n const memo = new Map();\n\n const traverse = (num: number, end: number): number => {\n if (num < end) return 1; // Adjust the base case to return 1 if we're below 'end'\n // if (num === 0) return 1;\n\n if (memo.has(num)) return memo.get(num) ?? 1;\n\n if (num === end) {\n memo.set(num, num);\n return num;\n }\n\n const result = num * traverse(num - 1, end);\n\n memo.set(num, result);\n\n return result;\n };\n\n return traverse(n, start);\n};\n\n/**\n * Tabulation (Bottom-Up Dynamic Programming).\n */\nexport const factorial = (n: number, start = 0): number => {\n if (n < 0) {\n throw new Error('Factorial is not defined for negative numbers.');\n }\n\n if (start > n) {\n throw new Error('Start cannot be greater than n.');\n }\n\n if (start < 0) {\n throw new Error('Start must be non-negative.');\n }\n\n if (start === n) {\n return n === 0 ? 1 : n; // If start == n and n == 0, return 1 (0!), otherwise return n\n }\n\n if (start === 0) {\n start = 1;\n }\n\n const table = []; // new Array(n + 1);\n table[0] = 1;\n for (let i = 1; i <= n; i++) {\n table[i] = table[i - 1] * i;\n }\n return table[n] / table[start - 1];\n};", "/**\n * Order doesn't matter.\n */\n/*\nexport const combinations = (n: number) => {\n\n};\n*/\n\n/**\n * Order does matter.\n * A Permutation is an ordered Combination.\n */\n/*\nexport const permutations = (n: number, isRepetitionAllowed: boolean) => {\n if(isRepetitionAllowed) {\n // n!\n }\n};*/\n\n/**\n * Permutations with repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - repetition is allowed\n *\n * Formula:\n * --------\n * n^r\n *\n * Intuition:\n * ----------\n * In other words, there are n possibilities for the first choice,\n * THEN there are n possibilities for the second choice, and so on,\n * multiplying each time.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n/**\n * Permutations without repetitions:\n * - \"n\" is the number of things to choose from\n * - we choose \"r\" of them\n * - order matters\n * - no repetitions\n *\n * Formula:\n * --------\n * P(n,r) = n! / (n \u2212 r)!\n *\n * Intuition:\n * ----------\n * In this case, we have to reduce the number of available choices each time.\n * After choosing, say, number \"14\" we can't choose it again.\n * So, our first choice has 16 possibilities, and our next choice has 15 possibilities,\n * then 14, 13, 12, 11, ... etc.\n *\n * A Permutation is an ordered Combination.\n */\nexport const permutationsWithoutRepetition = (n: number, r: number) => {\n if (n < 0 || r < 0) {\n throw new Error('Both n and r should be non-negative integers.');\n }\n if (!Number.isInteger(n) || !Number.isInteger(r)) {\n throw new Error('Both n and r should be integers.');\n }\n\n return n ** r;\n};\n\n"], + "mappings": "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", + "names": ["index_esm_exports", "__export", "animate", "arithmeticSequenceSum", "circleCollide", "circleMovement", "circleMovementAfterMouse", "convertRange", "convexPolygonsCollide", "degreesToRadians", "doRangesOverlap", "dxArcCos", "dxArcCot", "dxArcSin", "dxArcTan", "dxCos", "dxCot", "dxPolynomial", "dxSin", "dxTan", "dxV2CubicBezierCurve", "dxV2QuadraticBezierCurve", "dxV3CubicBezierCurve", "dxV3QuadraticBezierCurve", "ellipseMovement", "ellipseMovementAfterMouse", "factorial", "factorialIterative", "factorialMemoized", "factorialRecursive", "getAnglesDistance", "getAnglesSub", "getArithmeticMean", "getArithmeticMeanFromFrequency", "getCircleCircumference", "getColorsDelta", "getEllipseCircumference", "getLinearEquationBy2Points", "getMedian", "getMode", "getRandom", "getRandomBoolean", "getRandomGrayscaleHSLColor", "getRandomHSLColor", "getRandomHSLColorWithHue", "getRandomHSLColorWithLightness", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithinRanges", "getRandomHexColor", "getRandomInt", "getRandomItemFromArray", "getRandomRGBColor", "getShiftedHue", "getShiftedLightness", "getShiftedSaturation", "getSquareInCircleSide", "getStandardDeviation", "getV2Angle", "getV2AngleBetween", "getV2AngleInEllipse", "getV3AngleBetween", "getVNAngleBetween", "getVariance", "getVariance1", "guid", "hexToRgb", "hslToHex", "hslToRgb", "identity2", "identity3", "identity4", "identityN", "isAngleBetween", "isAngleInCircleArc", "isClockwise", "isNumber", "isSingularMatrix", "labToRgb", "linearEquation", "linearEquationSystem2", "linearEquationSystem3", "linearEquationSystemN", "lissajousCurve", "m2Adjugate", "m2AppendRow", "m2DeepCopy", "m2Determinant", "m2DivideScalar", "m2Inverse", "m2MulScalar", "m2PrependRow", "m2ReflectionOrigin", "m2ReflectionOriginH", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m2ReflectionYmX", "m2Reset", "m2RotateAroundPointH", "m2Rotation", "m2RotationAroundPointH", "m2RotationH", "m2Scale", "m2ScaleAtPointH", "m2ScaleAtPointHMatrix", "m2ScaleH", "m2ScaleX", "m2ScaleXH", "m2ScaleY", "m2ScaleYH", "m2ShearingX", "m2ShearingY", "m2Sub", "m2Sum", "m2ToCSS", "m2Translation", "m2TranslationH", "m2Transpose", "m2hToCSS", "m2hToCSS3d", "m2x2", "m3Adjugate", "m3AppendRow", "m3DeepCopy", "m3Determinant", "m3DivideScalar", "m3Inverse", "m3MulScalar", "m3PrependRow", "m3ReflectionOrigin", "m3ReflectionOriginH", "m3ReflectionXY", "m3ReflectionXYH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionYZ", "m3ReflectionYZH", "m3Reset", "m3RotationX", "m3RotationXH", "m3RotationY", "m3RotationYH", "m3RotationZ", "m3RotationZH", "m3Scale", "m3ScaleH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m3Sub", "m3Sum", "m3Translation", "m3TranslationH", "m3Transpose", "m3hToCSS3d", "m3x3", "m4x4", "mAdjugate", "mAppendCol", "mAppendRow", "mDeepCopy", "mDelFirstColumn", "mDelFirstRow", "mDelLastColumn", "mDelLastRow", "mDeterminant", "mDivideScalar", "mEqual", "mGetColumn", "mGetFirstColumn", "mGetLastColumn", "mInverse", "mMinor", "mMul", "mMulScalar", "mMulVector", "mNxM", "mPrependCol", "mPrependRow", "mReset", "mSub", "mSum", "mTranspose", "mlNormalizeArray", "mlNormalizeTestData", "mlNormalizeUnseenData", "mlNormalizeValue", "mlStandardizeArray", "mlStandardizeTestData", "mlStandardizeUnseenData", "mlStandardizeValue", "mod", "naturalNumbersSequenceSum", "naturalNumbersSum1ToN", "naturalNumbersSumMToN", "newId", "percentToAngle", "permutationsWithRepetition", "permutationsWithoutRepetition", "polarToCartesian", "radiansToDegrees", "rectCollide", "rgbToHex", "rgbToHsl", "rgbToLab", "setDecimalPlaces", "setV2Angle", "sineWaveMovement", "stringToNumber", "v2", "v2CubicBezierBBox", "v2CubicBezierCurve", "v2CubicBezierCurveExtrema", "v2CubicBezierCurveNormal", "v2CubicBezierCurveTangent", "v2Distance", "v2DivideScalar", "v2DotProduct", "v2FromPolarCoords", "v2GetNormal", "v2Length", "v2MulScalar", "v2Normalize", "v2QuadraticBezierBBox", "v2QuadraticBezierCurve", "v2QuadraticBezierCurveExtrema", "v2QuadraticBezierCurveNormal", "v2QuadraticBezierCurveTangent", "v2Rotate", "v2RotateH", "v2Scale", "v2SetLength", "v2Sub", "v2Sum", "v3", "v3CrossProduct", "v3CubicBezierCurve", "v3CubicBezierCurveTangent", "v3Distance", "v3DivideScalar", "v3DotProduct", "v3Length", "v3MulScalar", "v3Normalize", "v3QuadraticBezierCurve", "v3QuadraticBezierCurveTangent", "v3RotateX", "v3RotateY", "v3RotateZ", "v3Scale", "v3Sub", "v3Sum", "v4", "vDistance", "vDivideScalar", "vDotProduct", "vEqual", "vLength", "vMulScalar", "vN", "vNormalize", "vSub", "vSum", "__toCommonJS", "setDecimalPlaces", "num", "decimalPlaces", "coefficient", "__pow", "mod", "n", "m", "convertRange", "x", "a", "b", "c", "d", "doRangesOverlap", "isNumber", "value", "polarToCartesian", "center", "radii", "angleInRad", "decimalPlaces", "cx", "cy", "rx", "ry", "setDecimalPlaces", "getV2Angle", "v2", "decimalPlaces", "angle", "setDecimalPlaces", "getV2AngleInEllipse", "radii", "setV2Angle", "newAngleRad", "length", "v2Length", "radiansToDegrees", "radians", "res", "degreesToRadians", "degrees", "getVNAngleBetween", "vector1", "vector2", "unitVector1", "vNormalize", "unitVector2", "dotProduct", "vDotProduct", "getV2AngleBetween", "diff", "vSub", "getV3AngleBetween", "isAngleBetween", "angleDegrees", "startAngleDegrees", "endAngleDegrees", "distance", "getAnglesSub", "distance1", "distance2", "totalDistance", "isClockwise", "angle1Deg", "angle2Deg", "startAngleDeg", "angleDegrees1", "angleDegrees2", "angleDistance", "mod", "getAnglesDistance", "percentToAngle", "percent", "endAngleDeg", "circleStartAngle", "vSum", "vector1", "vector2", "decimalPlaces", "vector", "i", "setDecimalPlaces", "v2Sum", "v3Sum", "vSub", "v2Sub", "v3Sub", "vMulScalar", "v", "scalar", "v2MulScalar", "v2", "v3MulScalar", "v3", "vDivideScalar", "v2DivideScalar", "v3DivideScalar", "vLength", "sum", "v2Length", "v3Length", "v2SetLength", "newLength", "angle", "getV2Angle", "vDistance", "diff", "v2Distance", "v3Distance", "vNormalize", "length", "unitVector", "v2Normalize", "v3Normalize", "vDotProduct", "v2DotProduct", "v3DotProduct", "v3CrossProduct", "defaultValue", "v4", "vN", "N", "v2FromPolarCoords", "distance", "angleRad", "setV2Angle", "vEqual", "v2GetNormal", "sub", "mSum", "matrix1", "matrix2", "decimalPlaces", "matrix", "i", "vSum", "m2Sum", "m3Sum", "mSub", "vSub", "m2Sub", "m3Sub", "mMulScalar", "m", "scalar", "v", "vMulScalar", "m2MulScalar", "m2", "m3MulScalar", "m3", "mDivideScalar", "vDivideScalar", "m2DivideScalar", "m3DivideScalar", "mTranspose", "vectorsCount", "vectorLength", "j", "m2Transpose", "m3Transpose", "mReset", "defaultValue", "res", "size", "vector", "m2Reset", "m3Reset", "m2x2", "m3x3", "m4x4", "mNxM", "N", "M", "vN", "identity2", "identity3", "identity4", "identityN", "mDeepCopy", "m2DeepCopy", "m3DeepCopy", "mAppendCol", "col", "copy", "mPrependCol", "mAppendRow", "row", "m2AppendRow", "m3AppendRow", "mPrependRow", "m2PrependRow", "m3PrependRow", "mDelLastRow", "mDelFirstRow", "mDelLastColumn", "mDelFirstColumn", "mGetFirstColumn", "mGetLastColumn", "mGetColumn", "colIndex", "mMul", "transposed", "vector1", "vector2", "product", "vDotProduct", "mMulVector", "mEqual", "vEqual", "mMinorHelper", "mMinor", "mDeterminant", "m2Determinant", "d", "minor", "param", "m3Determinant", "m2Adjugate", "m3Adjugate", "mAdjugate", "cofactors", "sign", "isSingularMatrix", "m2Inverse", "adj", "m3Inverse", "mInverse", "m2ToCSS", "m", "a", "b", "c", "d", "m2hToCSS", "tx", "ty", "m2hToCSS3d", "m3hToCSS3d", "m2Translation", "position", "decimalPlaces", "setDecimalPlaces", "m3Translation", "m2TranslationH", "m3TranslationH", "m2Rotation", "angleRad", "isClockwise", "cos", "sin", "m2RotationH", "m2RotationAroundPointH", "transformOrigin", "translation", "rotation", "translationBack", "v3MulScalar", "temp1", "mMul", "m2RotateAroundPointH", "mat3h", "mMulVector", "v2Rotate", "vector", "unitVector", "v2Normalize", "v2RotateH", "v3Normalize", "m3RotationX", "m3RotationXH", "v3RotateX", "m3RotationY", "m3RotationYH", "v3RotateY", "m3RotationZ", "m3RotationZH", "v3RotateZ", "m2ScaleAtPointHMatrix", "scaleVector", "scale", "m2ScaleH", "m2ScaleAtPointH", "point", "m2Scale", "v2Scale", "m3Scale", "m3ScaleH", "v3Scale", "m2ScaleX", "m2ScaleXH", "m3ScaleX", "m3ScaleXH", "m3ScaleY", "m3ScaleYH", "m3ScaleZ", "m3ScaleZH", "m2ScaleY", "m2ScaleYH", "m2ReflectionOrigin", "m2ReflectionOriginH", "m3ReflectionOrigin", "m3ReflectionOriginH", "m2ReflectionYmX", "m2ReflectionX", "m2ReflectionXH", "m2ReflectionY", "m2ReflectionYH", "m3ReflectionYZ", "m3ReflectionYZH", "m3ReflectionXZ", "m3ReflectionXZH", "m3ReflectionXY", "m3ReflectionXYH", "m2ShearingY", "factor", "m2ShearingX", "getRandom", "min", "max", "decimalPlaces", "setDecimalPlaces", "getRandomInt", "getRandomBoolean", "getRandomItemFromArray", "array", "randomIndex", "stringToNumber", "value", "defaultNumber", "_a", "res", "dxPolynomial", "x", "polynomial", "decimalPlaces", "res", "part", "coeff", "power", "setDecimalPlaces", "dxV2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "temp1", "temp2", "temp3", "dxV3QuadraticBezierCurve", "dxV2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "dxV3CubicBezierCurve", "dxSin", "dxCos", "dxTan", "__pow", "dxCot", "dxArcSin", "dxArcCos", "dxArcTan", "dxArcCot", "linearEquation", "equation", "decimalPlaces", "a", "b", "diff", "setDecimalPlaces", "linearEquationSystem2", "equation1", "equation2", "equationParams", "inversed", "m2Inverse", "equationResults", "mMulVector", "linearEquationSystem3", "equation3", "m3Inverse", "linearEquationSystemN", "equations", "mDelLastColumn", "mInverse", "mGetLastColumn", "getLinearEquationBy2Points", "point1", "point2", "deltaX", "deltaY", "v2Sub", "x", "y", "m", "formula", "quadraticEquation", "equation", "decimalPlaces", "a", "b", "c", "d", "res", "linearEquation", "isNumber", "diff", "discriminant", "setDecimalPlaces", "t1", "t2", "v2QuadraticBezierCurve", "startControlPoint", "centerControlPoint", "endControlPoint", "decimalPlaces", "temp1", "temp2", "temp3", "setDecimalPlaces", "v3QuadraticBezierCurve", "v2CubicBezierCurve", "center1ControlPoint", "center2ControlPoint", "temp4", "v3CubicBezierCurve", "v2QuadraticBezierCurveTangent", "dxVector", "dxV2QuadraticBezierCurve", "v2Normalize", "v3QuadraticBezierCurveTangent", "dxV3QuadraticBezierCurve", "v3Normalize", "v2CubicBezierCurveTangent", "dxV2CubicBezierCurve", "v3CubicBezierCurveTangent", "dxV3CubicBezierCurve", "v2QuadraticBezierCurveNormal", "tangent", "v2CubicBezierCurveNormal", "v2QuadraticBezierCurveExtrema", "a1", "b1", "res1", "linearEquation", "a2", "b2", "res2", "res", "isNumber", "v2CubicBezierCurveExtrema", "c1", "equation1", "c2", "equation2", "quadraticEquation", "num", "v2QuadraticBezierBBox", "extrema", "minX", "minY", "maxX", "maxY", "percent", "point", "x", "y", "v2CubicBezierBBox", "circleMovement", "center", "angle", "radius", "circleMovementAfterMouse", "mouse", "vector", "v2Sub", "getV2Angle", "convertRange", "ellipseMovement", "radius1", "radius2", "ellipseMovementAfterMouse", "radii", "sineWaveMovement", "x", "amplitude", "frequency", "phase", "y", "lissajousCurve", "width", "height", "t", "k", "n", "m", "p", "getRandomRGBColor", "hslColor", "getRandomHSLColor", "hslToRgb", "getRandomHexColor", "hslToHex", "h", "getRandom", "s", "l", "getRandomHSLColorWithHue", "getRandomHSLColorWithSaturation", "getRandomHSLColorWithLightness", "getRandomGrayscaleHSLColor", "getRandomHSLColorWithinRanges", "hueStart", "hueEnd", "saturationStart", "saturationEnd", "lightStart", "lightEnd", "convertHueToDegrees", "getHue", "r", "g", "b", "min", "max", "diff", "getLuminance", "getSaturation", "rgbToHsl", "rgb", "decimalPlaces", "setDecimalPlaces", "hslToRgbHelper", "helper1", "helper2", "colorHelper", "hsl", "gray", "rHelper", "gHelper", "bHelper", "hue2rgb", "q", "t", "p", "toHex", "hex", "rgbToHex", "hexToRgb", "shorthandRegex", "_hex", "_m", "result", "rgbToLab", "x", "y", "z", "labToRgb", "lab", "getShiftedHue", "color", "shift", "hue", "mod", "getShiftedLightness", "lightness", "getShiftedSaturation", "saturation", "getColorsDelta", "rgbA", "rgbB", "labA", "labB", "deltaL", "deltaA", "deltaB", "c1", "c2", "deltaC", "deltaH", "sc", "sh", "deltaLKlsl", "deltaCkcsc", "deltaHkhsh", "i", "guid", "c", "newId", "rectCollide", "rect1", "rect2", "circleCollide", "circle1", "circle2", "dx", "dy", "getEdges", "poly", "edges", "i", "nextIndex", "mod", "edge", "convexPolygonsCollide", "poly1", "poly2", "normal", "v2GetNormal", "p1Proj", "projectPolygon", "p2Proj", "polygon", "min", "max", "vertex", "projection", "v2DotProduct", "animate", "props", "_duration", "startTime", "animationId", "elapsed", "previousTimeStamp", "animating", "observer", "stop", "restart", "start", "pause", "resume", "step", "timeStamp", "getResult", "observerHandler", "_entries", "_observer", "getElapsedTime", "isAnimating", "getStartTime", "getPercent", "getResizeObserver", "getCircleCircumference", "radius", "decimalPlaces", "setDecimalPlaces", "getEllipseCircumference", "radius1", "radius2", "__pow", "isAngleInCircleArc", "startAngleDeg", "endAngleDeg", "currentDegrees", "getSquareInCircleSide", "naturalNumbersSequenceSum", "n", "arithmeticSequenceSum", "a", "d", "getArithmeticMean", "data", "decimalPlaces", "sum", "acc", "val", "setDecimalPlaces", "getArithmeticMeanFromFrequency", "frequencyMap", "mean", "frequency", "getMedian", "copy", "num1", "num2", "mid", "getMode", "num", "maxFrequency", "modes", "getVariance1", "__pow", "getVariance", "getStandardDeviation", "_a", "variance", "mlNormalizeValue", "value", "min", "max", "decimalPlaces", "diff", "setDecimalPlaces", "mlNormalizeArray", "data", "copy", "mlNormalizeTestData", "_data", "mlNormalizeUnseenData", "mlStandardizeValue", "mean", "stdDev", "mlStandardizeArray", "mlStandardizeTestData", "_a", "getArithmeticMean", "getStandardDeviation", "mlStandardizeUnseenData", "naturalNumbersSum1ToN", "n", "naturalNumbersSumMToN", "m", "factorialIterative", "n", "start", "result", "i", "factorialRecursive", "factorialMemoized", "memo", "traverse", "num", "end", "_a", "factorial", "table", "permutationsWithRepetition", "n", "__pow", "permutationsWithoutRepetition"] } diff --git a/src/index-esm.ts b/src/index-esm.ts index ec2f722..cbeca42 100644 --- a/src/index-esm.ts +++ b/src/index-esm.ts @@ -19,4 +19,6 @@ export * from './main/circle-ellipse'; export * from './main/sequence'; export * from './main/statistics'; export * from './main/ml'; -export * from './main/series'; \ No newline at end of file +export * from './main/series'; +export * from './main/combinatorics/factorial'; +export * from './main/combinatorics/combinatorics'; \ No newline at end of file diff --git a/src/index.ts b/src/index.ts index f87037c..279de1c 100644 --- a/src/index.ts +++ b/src/index.ts @@ -20,6 +20,8 @@ import * as sequence from './main/sequence'; import * as statistics from './main/statistics'; import * as ml from './main/ml'; import * as series from './main/series'; +import * as factorial from './main/combinatorics/factorial'; +import * as combinatorics from './main/combinatorics/combinatorics'; const api = { ...vector, @@ -44,6 +46,8 @@ const api = { ...statistics, ...ml, ...series, + ...factorial, + ...combinatorics, }; declare global { @@ -75,4 +79,6 @@ export * from './main/circle-ellipse'; export * from './main/sequence'; export * from './main/statistics'; export * from './main/ml'; -export * from './main/series'; \ No newline at end of file +export * from './main/series'; +export * from './main/combinatorics/factorial'; +export * from './main/combinatorics/combinatorics'; \ No newline at end of file diff --git a/src/main/combinatorics/combinatorics.ts b/src/main/combinatorics/combinatorics.ts new file mode 100644 index 0000000..1e75831 --- /dev/null +++ b/src/main/combinatorics/combinatorics.ts @@ -0,0 +1,81 @@ +/** + * Order doesn't matter. + */ +/* +export const combinations = (n: number) => { + +}; +*/ + +/** + * Order does matter. + * A Permutation is an ordered Combination. + */ +/* +export const permutations = (n: number, isRepetitionAllowed: boolean) => { + if(isRepetitionAllowed) { + // n! + } +};*/ + +/** + * Permutations with repetitions: + * - "n" is the number of things to choose from + * - we choose "r" of them + * - order matters + * - repetition is allowed + * + * Formula: + * -------- + * n^r + * + * Intuition: + * ---------- + * In other words, there are n possibilities for the first choice, + * THEN there are n possibilities for the second choice, and so on, + * multiplying each time. + * + * A Permutation is an ordered Combination. + */ +export const permutationsWithRepetition = (n: number, r: number) => { + if (n < 0 || r < 0) { + throw new Error('Both n and r should be non-negative integers.'); + } + if (!Number.isInteger(n) || !Number.isInteger(r)) { + throw new Error('Both n and r should be integers.'); + } + + return n ** r; +}; + +/** + * Permutations without repetitions: + * - "n" is the number of things to choose from + * - we choose "r" of them + * - order matters + * - no repetitions + * + * Formula: + * -------- + * P(n,r) = n! / (n − r)! + * + * Intuition: + * ---------- + * In this case, we have to reduce the number of available choices each time. + * After choosing, say, number "14" we can't choose it again. + * So, our first choice has 16 possibilities, and our next choice has 15 possibilities, + * then 14, 13, 12, 11, ... etc. + * + * A Permutation is an ordered Combination. + */ +export const permutationsWithoutRepetition = (n: number, r: number) => { + if (n < 0 || r < 0) { + throw new Error('Both n and r should be non-negative integers.'); + } + if (!Number.isInteger(n) || !Number.isInteger(r)) { + throw new Error('Both n and r should be integers.'); + } + + return n ** r; +}; + diff --git a/src/main/combinatorics/factorial.ts b/src/main/combinatorics/factorial.ts new file mode 100644 index 0000000..c518606 --- /dev/null +++ b/src/main/combinatorics/factorial.ts @@ -0,0 +1,150 @@ +/** + * The simplest and straightforward method + * but can become inefficient for extremely large numbers + * due to growing computational time. + */ +export const factorialIterative = (n: number, start = 0): number => { + + if (n < 0) { + throw new Error('Factorial is not defined for negative numbers.'); + } + + if (start > n) { + throw new Error('Start cannot be greater than n.'); + } + + if (start < 0) { + throw new Error('Start must be non-negative.'); + } + + if (start === 0) { + if (n === 0) { + return 1; // 0! is defined as 1 + } + else { + start = 1; // Adjust start to 1 to prevent multiplication by zero + } + } + + let result = 1; + for (let i = start; i <= n; i++) { + result *= i; + } + return result; +}; + +/** + * A recursive approach is a classic method for calculating factorials + * but can lead to stack overflow errors + * for very large inputs because of deep recursion. + * However, it's a direct translation + * of the mathematical definition of factorial. + */ +export const factorialRecursive = (n: number, start = 0): number => { + if (n < 0) { + throw new Error('Factorial is not defined for negative numbers.'); + } + + if (start > n) { + throw new Error('Start cannot be greater than n.'); + } + + if (start < 0) { + throw new Error('Start must be non-negative.'); + } + + if (start === 0) { + if (n === 0) { + return 1; // 0! is defined as 1 + } + else { + start = 1; // Adjust start to 1 to prevent multiplication by zero + } + } + + // Base case: when n reaches start, return start instead of further reducing + if (n === start) return start; + + // Recursive call + return n * factorialRecursive(n - 1, start); +}; + +/** + * Memoization (Top-Down Dynamic Programming). + */ +export const factorialMemoized = (n: number, start = 0): number => { + if (n < 0) { + throw new Error('Factorial is not defined for negative numbers.'); + } + + if (start > n) { + throw new Error('Start cannot be greater than n.'); + } + + if (start < 0) { + throw new Error('Start must be non-negative.'); + } + + if (start === 0) { + if (n === 0) { + return 1; // 0! is defined as 1 + } + else { + start = 1; // Adjust start to 1 to prevent multiplication by zero + } + } + + const memo = new Map(); + + const traverse = (num: number, end: number): number => { + if (num < end) return 1; // Adjust the base case to return 1 if we're below 'end' + // if (num === 0) return 1; + + if (memo.has(num)) return memo.get(num) ?? 1; + + if (num === end) { + memo.set(num, num); + return num; + } + + const result = num * traverse(num - 1, end); + + memo.set(num, result); + + return result; + }; + + return traverse(n, start); +}; + +/** + * Tabulation (Bottom-Up Dynamic Programming). + */ +export const factorial = (n: number, start = 0): number => { + if (n < 0) { + throw new Error('Factorial is not defined for negative numbers.'); + } + + if (start > n) { + throw new Error('Start cannot be greater than n.'); + } + + if (start < 0) { + throw new Error('Start must be non-negative.'); + } + + if (start === n) { + return n === 0 ? 1 : n; // If start == n and n == 0, return 1 (0!), otherwise return n + } + + if (start === 0) { + start = 1; + } + + const table = []; // new Array(n + 1); + table[0] = 1; + for (let i = 1; i <= n; i++) { + table[i] = table[i - 1] * i; + } + return table[n] / table[start - 1]; +}; \ No newline at end of file diff --git a/test/combinatorics.test.ts b/test/combinatorics.test.ts new file mode 100644 index 0000000..1a4b2e5 --- /dev/null +++ b/test/combinatorics.test.ts @@ -0,0 +1,28 @@ +import { permutationsWithRepetition } from '../src/main/combinatorics/combinatorics'; + +describe('Combinatorics', () => { + + describe('permutationsWithRepetition()', () => { + it('calculates correct permutations for valid inputs', () => { + expect(permutationsWithRepetition(3, 2)).toBe(9); // 3^2 + expect(permutationsWithRepetition(4, 3)).toBe(64); // 4^3 + expect(permutationsWithRepetition(5, 1)).toBe(5); // 5^1 + expect(permutationsWithRepetition(2, 0)).toBe(1); // 2^0 should be 1 + }); + + it('throws an error for negative values of n or r', () => { + expect(() => permutationsWithRepetition(-1, 2)).toThrow("Both n and r should be non-negative integers."); + expect(() => permutationsWithRepetition(3, -1)).toThrow("Both n and r should be non-negative integers."); + }); + + it('throws an error for non-integer values of n or r', () => { + expect(() => permutationsWithRepetition(3.5, 2)).toThrow("Both n and r should be integers."); + expect(() => permutationsWithRepetition(3, 2.7)).toThrow("Both n and r should be integers."); + }); + + it('handles edge cases with zero correctly', () => { + expect(permutationsWithRepetition(0, 5)).toBe(0); // 0^5 should be 0 + expect(permutationsWithRepetition(5, 0)).toBe(1); // 5^0 should be 1 + }); + }); +}); \ No newline at end of file diff --git a/test/factorial.test.ts b/test/factorial.test.ts new file mode 100644 index 0000000..a3ac031 --- /dev/null +++ b/test/factorial.test.ts @@ -0,0 +1,220 @@ +import { factorialIterative, factorialRecursive, factorialMemoized, factorial } from '../src/main/combinatorics/factorial'; + +describe('Factorial', () => { + + describe('factorialIterative()', () => { + it('calculates factorial of 0 as 1', () => { + expect(factorialIterative(0)).toBe(1); + expect(factorialIterative(0, 0)).toBe(1); // 0! = 1 by definition + }); + + it('calculates factorial of 1 as 1', () => { + expect(factorialIterative(1)).toBe(1); + }); + + it('calculates factorial of 5 as 120', () => { + expect(factorialIterative(5)).toBe(120); + expect(factorialIterative(5, 1)).toBe(120); + }); + + it('calculates partial factorial from start to n correctly', () => { + expect(factorialIterative(5, 2)).toBe(120); // 2*3*4*5 = 120 + expect(factorialIterative(5, 3)).toBe(60); // 3*4*5 = 60 + expect(factorialIterative(5, 5)).toBe(5); // Only includes 5, so 5! / 4! = 5 + expect(factorialIterative(7, 7)).toBe(7); // Only includes 7, so 7! / 6! = 7 + }); + + it('calculates factorial of 10 as 3628800', () => { + expect(factorialIterative(10)).toBe(3628800); + }); + + it('throws an error for negative numbers', () => { + expect(() => factorialIterative(-1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialIterative(-5)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialIterative(-1, 1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialIterative(-5, 3)).toThrow('Factorial is not defined for negative numbers.'); + }); + + it('throws an error if start is greater than n', () => { + expect(() => factorialIterative(3, 5)).toThrow('Start cannot be greater than n.'); + }); + + it('throws an error if start is negative', () => { + expect(() => factorialIterative(5, -1)).toThrow('Start must be non-negative.'); + }); + + it('handles special case where start is 0', () => { + expect(factorialIterative(5, 0)).toBe(120); // Adjusts start to 1, calculates 5! + }); + + it('handles edge case of n being 0 and start not set', () => { + expect(factorialIterative(0)).toBe(1); // 0! = 1 + }); + + it('handles edge case of n being 0 with start > 0', () => { + expect(() => factorialIterative(0, 1)).toThrow('Start cannot be greater than n.'); + }); + }); + + describe('factorialRecursive()', () => { + it('calculates factorial of 0 as 1', () => { + expect(factorialRecursive(0)).toBe(1); + expect(factorialRecursive(0, 0)).toBe(1); // 0! = 1 by definition + }); + + it('calculates factorial of 1 as 1', () => { + expect(factorialRecursive(1)).toBe(1); + }); + + it('calculates factorial of 5 as 120', () => { + expect(factorialRecursive(5)).toBe(120); + expect(factorialRecursive(5, 1)).toBe(120); + }); + + it('calculates partial factorial from start to n correctly', () => { + expect(factorialRecursive(5, 2)).toBe(120); // 2*3*4*5 = 120 + expect(factorialRecursive(5, 3)).toBe(60); // 3*4*5 = 60 + expect(factorialRecursive(5, 5)).toBe(5); // Only includes 5, so 5! / 4! = 5 + expect(factorialRecursive(7, 7)).toBe(7); // Only includes 7, so 7! / 6! = 7 + }); + + it('calculates factorial of 10 as 3628800', () => { + expect(factorialRecursive(10)).toBe(3628800); + }); + + it('throws an error for negative numbers', () => { + expect(() => factorialRecursive(-1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialRecursive(-5)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialRecursive(-1, 1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialRecursive(-5, 3)).toThrow('Factorial is not defined for negative numbers.'); + }); + + it('throws an error if start is greater than n', () => { + expect(() => factorialRecursive(3, 5)).toThrow('Start cannot be greater than n.'); + }); + + it('throws an error if start is negative', () => { + expect(() => factorialRecursive(5, -1)).toThrow('Start must be non-negative.'); + }); + + it('handles special case where start is 0', () => { + expect(factorialRecursive(5, 0)).toBe(120); // Adjusts start to 1, calculates 5! + }); + + it('handles edge case of n being 0 and start not set', () => { + expect(factorialRecursive(0)).toBe(1); // 0! = 1 + }); + + it('handles edge case of n being 0 with start > 0', () => { + expect(() => factorialRecursive(0, 1)).toThrow('Start cannot be greater than n.'); + }); + }); + + describe('factorialMemoized()', () => { + it('calculates factorial of 0 as 1', () => { + expect(factorialMemoized(0)).toBe(1); + expect(factorialMemoized(0, 0)).toBe(1); // 0! = 1 by definition + }); + + it('calculates factorial of 1 as 1', () => { + expect(factorialMemoized(1)).toBe(1); + }); + + it('calculates factorial of 5 as 120', () => { + expect(factorialMemoized(5)).toBe(120); + expect(factorialMemoized(5, 1)).toBe(120); + }); + + it('calculates partial factorial from start to n correctly', () => { + expect(factorialMemoized(5, 2)).toBe(120); // 2*3*4*5 = 120 + expect(factorialMemoized(5, 3)).toBe(60); // 3*4*5 = 60 + expect(factorialMemoized(5, 5)).toBe(5); // Only includes 5, so 5! / 4! = 5 + expect(factorialMemoized(7, 7)).toBe(7); // Only includes 7, so 7! / 6! = 7 + }); + + it('calculates factorial of 10 as 3628800', () => { + expect(factorialMemoized(10)).toBe(3628800); + }); + + it('throws an error for negative numbers', () => { + expect(() => factorialMemoized(-1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialMemoized(-5)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialMemoized(-1, 1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorialMemoized(-5, 3)).toThrow('Factorial is not defined for negative numbers.'); + }); + + it('throws an error if start is greater than n', () => { + expect(() => factorialMemoized(3, 5)).toThrow('Start cannot be greater than n.'); + }); + + it('throws an error if start is negative', () => { + expect(() => factorialMemoized(5, -1)).toThrow('Start must be non-negative.'); + }); + + it('handles special case where start is 0', () => { + expect(factorialMemoized(5, 0)).toBe(120); // Adjusts start to 1, calculates 5! + }); + + it('handles edge case of n being 0 and start not set', () => { + expect(factorialMemoized(0)).toBe(1); // 0! = 1 + }); + + it('handles edge case of n being 0 with start > 0', () => { + expect(() => factorialMemoized(0, 1)).toThrow('Start cannot be greater than n.'); + }); + }); + + describe('factorial()', () => { + it('calculates factorial of 0 as 1', () => { + expect(factorial(0)).toBe(1); + expect(factorial(0, 0)).toBe(1); // 0! = 1 by definition + }); + + it('calculates factorial of 1 as 1', () => { + expect(factorial(1)).toBe(1); + }); + + it('calculates factorial of 5 as 120', () => { + expect(factorial(5)).toBe(120); + expect(factorial(5, 1)).toBe(120); + }); + + it('calculates partial factorial from start to n correctly', () => { + expect(factorial(5, 2)).toBe(120); // 2*3*4*5 = 120 + expect(factorial(5, 3)).toBe(60); // 3*4*5 = 60 + expect(factorial(5, 5)).toBe(5); // Only includes 5, so 5! / 4! = 5 + expect(factorial(7, 7)).toBe(7); // Only includes 7, so 7! / 6! = 7 + }); + + it('calculates factorial of 10 as 3628800', () => { + expect(factorial(10)).toBe(3628800); + }); + + it('throws an error for negative numbers', () => { + expect(() => factorial(-1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorial(-5)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorial(-1, 1)).toThrow('Factorial is not defined for negative numbers.'); + expect(() => factorial(-5, 3)).toThrow('Factorial is not defined for negative numbers.'); + }); + + it('throws an error if start is greater than n', () => { + expect(() => factorial(3, 5)).toThrow('Start cannot be greater than n.'); + }); + + it('throws an error if start is negative', () => { + expect(() => factorial(5, -1)).toThrow('Start must be non-negative.'); + }); + + it('handles special case where start is 0', () => { + expect(factorial(5, 0)).toBe(120); // Adjusts start to 1, calculates 5! + }); + + it('handles edge case of n being 0 and start not set', () => { + expect(factorial(0)).toBe(1); // 0! = 1 + }); + + it('handles edge case of n being 0 with start > 0', () => { + expect(() => factorial(0, 1)).toThrow('Start cannot be greater than n.'); + }); + }); +}); \ No newline at end of file diff --git a/test/statistics.test.ts b/test/statistics.test.ts index 89c94ae..06bb83f 100644 --- a/test/statistics.test.ts +++ b/test/statistics.test.ts @@ -120,7 +120,7 @@ describe('Statistics', () => { }); test('[1, 2, 3, 8, 7]', () => { - expect(getVariance([1, 2, 3, 8, 7])).toStrictEqual(7.76); + expect(getVariance([1, 2, 3, 8, 7], 2)).toStrictEqual(7.76); }); });