mirror of https://github.com/vladmandic/human
3 lines
63 KiB
JavaScript
3 lines
63 KiB
JavaScript
var Fe=Object.defineProperty;var y=(e,t)=>()=>(t||(t={exports:{}},e(t.exports,t)),t.exports),m0=e=>Fe(e,"__esModule",{value:!0}),ve=(e,t)=>{m0(e);for(var o in t)Fe(e,o,{get:t[o],enumerable:!0})};var We=y(te=>{const f=require("@tensorflow/tfjs"),f0={strides:[8,16],anchors:[2,6]},Le=6;function g0(e,t,o){const n=[];for(let i=0;i<o.strides.length;i++){const s=o.strides[i],r=Math.floor((t+s-1)/s),c=Math.floor((e+s-1)/s),a=o.anchors[i];for(let d=0;d<r;d++){const u=s*(d+.5);for(let h=0;h<c;h++){const l=s*(h+.5);for(let p=0;p<a;p++)n.push([l,u])}}}return n}const He=e=>{e.startEndTensor.dispose(),e.startPoint.dispose(),e.endPoint.dispose()},qe=e=>({startEndTensor:e,startPoint:f.slice(e,[0,0],[-1,2]),endPoint:f.slice(e,[0,2],[-1,2])}),y0=(e,t)=>{const o=f.mul(e.startPoint,t),n=f.mul(e.endPoint,t),i=f.concat2d([o,n],1);return qe(i)};function x0(e,t,o){const n=f.slice(e,[0,1],[-1,2]),i=f.add(n,t),s=f.slice(e,[0,3],[-1,2]),r=f.div(s,o),c=f.div(i,o),a=f.div(r,2),d=f.sub(c,a),u=f.add(c,a),h=f.mul(d,o),l=f.mul(u,o),p=1;return f.concat2d([h,l],p)}function je(e,t){return f.tidy(()=>{const o=e.box?e.box:e;return y0(o,t).startEndTensor.squeeze()})}class Ue{constructor(e,t){this.blazeFaceModel=e,this.width=t.detector.inputSize,this.height=t.detector.inputSize,this.maxFaces=t.detector.maxFaces,this.anchorsData=g0(t.detector.inputSize,t.detector.inputSize,f0),this.anchors=f.tensor2d(this.anchorsData),this.inputSizeData=[t.detector.inputSize,t.detector.inputSize],this.inputSize=f.tensor1d([t.detector.inputSize,t.detector.inputSize]),this.iouThreshold=t.detector.iouThreshold,this.scoreThreshold=t.detector.scoreThreshold}async getBoundingBoxes(e){const[t,o,n]=f.tidy(()=>{const a=e.resizeBilinear([this.width,this.height]),d=f.mul(f.sub(a.div(255),.5),2),u=this.blazeFaceModel.predict(d),h=u.squeeze(),l=x0(h,this.anchors,this.inputSize),p=f.slice(h,[0,0],[-1,1]),m=f.sigmoid(p).squeeze();return[h,l,m]}),i=await f.image.nonMaxSuppressionAsync(o,n,this.maxFaces,this.iouThreshold,this.scoreThreshold),s=await i.array();i.dispose();let r=s.map(a=>f.slice(o,[a,0],[1,-1]));r=await Promise.all(r.map(async a=>{const d=await a.array();return a.dispose(),d}));const c=[];for(let a=0;a<r.length;a++){const d=r[a],u=f.tidy(()=>{const h=qe(d),l=s[a],p=this.anchorsData[l],m=f.slice(t,[l,Le-1],[1,-1]).squeeze().reshape([Le,-1]),P=f.slice(n,[l],[1]);return{box:h,landmarks:m,probability:P,anchor:p}});c.push(u)}return o.dispose(),n.dispose(),t.dispose(),{boxes:c,scaleFactor:[e.shape[2]/this.inputSizeData[0],e.shape[1]/this.inputSizeData[1]]}}async estimateFaces(e,t=!1,o=!0){const n=f.tidy(()=>(e instanceof f.Tensor||(e=f.browser.fromPixels(e)),e.toFloat().expandDims(0))),{boxes:i,scaleFactor:s}=await this.getBoundingBoxes(n);return n.dispose(),t?i.map(r=>{const c=je(r,s),a={topLeft:c.slice([0],[2]),bottomRight:c.slice([2],[2])};if(o){const{landmarks:d,probability:u,anchor:h}=r,l=d.add(h).mul(s);a.landmarks=l,a.probability=u}return a}):Promise.all(i.map(async r=>{const c=je(r,s);let a;if(o){const[d,u,h]=await Promise.all([r.landmarks,c,r.probability].map(async b=>b.array())),l=r.anchor,[p,m]=s,P=d.map(b=>[(b[0]+l[0])*p,(b[1]+l[1])*m]);a={topLeft:u.slice(0,2),bottomRight:u.slice(2),landmarks:P,probability:h},He(r.box),r.landmarks.dispose(),r.probability.dispose()}else{const d=await c.array();a={topLeft:d.slice(0,2),bottomRight:d.slice(2)}}return c.dispose(),a}))}}async function b0(e){const t=await f.loadGraphModel(e.detector.modelPath,{fromTFHub:e.detector.modelPath.includes("tfhub.dev")}),o=new Ue(t,e);return o}te.load=b0;te.BlazeFaceModel=Ue;te.disposeBox=He});var de=y(ce=>{ce.MESH_ANNOTATIONS={silhouette:[10,338,297,332,284,251,389,356,454,323,361,288,397,365,379,378,400,377,152,148,176,149,150,136,172,58,132,93,234,127,162,21,54,103,67,109],lipsUpperOuter:[61,185,40,39,37,0,267,269,270,409,291],lipsLowerOuter:[146,91,181,84,17,314,405,321,375,291],lipsUpperInner:[78,191,80,81,82,13,312,311,310,415,308],lipsLowerInner:[78,95,88,178,87,14,317,402,318,324,308],rightEyeUpper0:[246,161,160,159,158,157,173],rightEyeLower0:[33,7,163,144,145,153,154,155,133],rightEyeUpper1:[247,30,29,27,28,56,190],rightEyeLower1:[130,25,110,24,23,22,26,112,243],rightEyeUpper2:[113,225,224,223,222,221,189],rightEyeLower2:[226,31,228,229,230,231,232,233,244],rightEyeLower3:[143,111,117,118,119,120,121,128,245],rightEyebrowUpper:[156,70,63,105,66,107,55,193],rightEyebrowLower:[35,124,46,53,52,65],rightEyeIris:[473,474,475,476,477],leftEyeUpper0:[466,388,387,386,385,384,398],leftEyeLower0:[263,249,390,373,374,380,381,382,362],leftEyeUpper1:[467,260,259,257,258,286,414],leftEyeLower1:[359,255,339,254,253,252,256,341,463],leftEyeUpper2:[342,445,444,443,442,441,413],leftEyeLower2:[446,261,448,449,450,451,452,453,464],leftEyeLower3:[372,340,346,347,348,349,350,357,465],leftEyebrowUpper:[383,300,293,334,296,336,285,417],leftEyebrowLower:[265,353,276,283,282,295],leftEyeIris:[468,469,470,471,472],midwayBetweenEyes:[168],noseTip:[1],noseBottom:[2],noseRightCorner:[98],noseLeftCorner:[327],rightCheek:[205],leftCheek:[425]};ce.MESH_TO_IRIS_INDICES_MAP=[{key:"EyeUpper0",indices:[9,10,11,12,13,14,15]},{key:"EyeUpper1",indices:[25,26,27,28,29,30,31]},{key:"EyeUpper2",indices:[41,42,43,44,45,46,47]},{key:"EyeLower0",indices:[0,1,2,3,4,5,6,7,8]},{key:"EyeLower1",indices:[16,17,18,19,20,21,22,23,24]},{key:"EyeLower2",indices:[32,33,34,35,36,37,38,39,40]},{key:"EyeLower3",indices:[54,55,56,57,58,59,60,61,62]},{key:"EyebrowUpper",indices:[63,64,65,66,67,68,69,70]},{key:"EyebrowLower",indices:[48,49,50,51,52,53]}]});var Ke=y(L=>{const P0=require("@tensorflow/tfjs");function w0(e,t){const o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]];return{startPoint:o,endPoint:n}}L.scaleBoxCoordinates=w0;function le(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}L.getBoxSize=le;function he(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}L.getBoxCenter=he;function E0(e,t,o){const n=t.shape[1],i=t.shape[2],s=[[e.startPoint[1]/n,e.startPoint[0]/i,e.endPoint[1]/n,e.endPoint[0]/i]];return P0.image.cropAndResize(t,s,[0],o)}L.cutBoxFromImageAndResize=E0;function I0(e,t=1.5){const o=he(e),n=le(e),i=[t*n[0]/2,t*n[1]/2],s=[o[0]-i[0],o[1]-i[1]],r=[o[0]+i[0],o[1]+i[1]];return{startPoint:s,endPoint:r,landmarks:e.landmarks}}L.enlargeBox=I0;function M0(e){const t=he(e),o=le(e),n=Math.max(...o),i=n/2,s=[t[0]-i,t[1]-i],r=[t[0]+i,t[1]+i];return{startPoint:s,endPoint:r,landmarks:e.landmarks}}L.squarifyBox=M0});var Qe=y(S=>{S.IDENTITY_MATRIX=[[1,0,0],[0,1,0],[0,0,1]];function Ye(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}S.normalizeRadians=Ye;function S0(e,t){const o=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Ye(o)}S.computeRotation=S0;function T0(e){return e*180/Math.PI}S.radToDegrees=T0;function Xe(e,t){return[[1,0,e],[0,1,t],[0,0,1]]}function K(e,t){let o=0;for(let n=0;n<e.length;n++)o+=e[n]*t[n];return o}S.dot=K;function Ge(e,t){const o=[];for(let n=0;n<e.length;n++)o.push(e[n][t]);return o}S.getColumnFrom2DArr=Ge;function Ve(e,t){const o=[],n=e.length;for(let i=0;i<n;i++){o.push([]);for(let s=0;s<n;s++)o[i].push(K(e[i],Ge(t,s)))}return o}function B0(e,t){const o=Math.cos(e),n=Math.sin(e),i=[[o,-n,0],[n,o,0],[0,0,1]],s=Xe(t[0],t[1]),r=Ve(s,i),c=Xe(-t[0],-t[1]);return Ve(r,c)}S.buildRotationMatrix=B0;function _0(e){const t=[[e[0][0],e[1][0]],[e[0][1],e[1][1]]],o=[e[0][2],e[1][2]],n=[-K(t[0],o),-K(t[1],o)];return[t[0].concat(n[0]),t[1].concat(n[1]),[0,0,1]]}S.invertTransformMatrix=_0;function k0(e,t){return[K(e,t[0]),K(e,t[1])]}S.rotatePoint=k0;function z0(e,t){return Math.sqrt((e[0]-t[0])**2+(e[1]-t[1])**2)}S.xyDistanceBetweenPoints=z0});var $e=y(Ze=>{const N=require("@tensorflow/tfjs"),B=Ke(),A=de(),O=Qe(),R0=468,N0=.25,A0=13,O0=[A0,A.MESH_ANNOTATIONS.midwayBetweenEyes[0]],C0=3,D0=2,F0=[C0,D0],ue=A.MESH_ANNOTATIONS.leftEyeLower0,pe=[ue[0],ue[ue.length-1]],me=A.MESH_ANNOTATIONS.rightEyeLower0,fe=[me[0],me[me.length-1]],v0=3,L0=4,H0=71,ge=76;function oe(e,t,o,n){for(let i=0;i<A.MESH_TO_IRIS_INDICES_MAP.length;i++){const{key:s,indices:r}=A.MESH_TO_IRIS_INDICES_MAP[i],c=A.MESH_ANNOTATIONS[`${o}${s}`],a=n==null;if(a||n.includes(s))for(let d=0;d<r.length;d++){const u=r[d];e[c[d]]=[t[u][0],t[u][1],(t[u][2]+e[c[d]][2])/2]}}}class q0{constructor(e,t,o,n){this.regionsOfInterest=[],this.runsWithoutFaceDetector=0,this.boundingBoxDetector=e,this.meshDetector=t,this.irisModel=o,this.meshWidth=n.mesh.inputSize,this.meshHeight=n.mesh.inputSize,this.irisSize=n.iris.inputSize,this.irisEnlarge=n.iris.enlargeFactor}transformRawCoords(e,t,o,n){const i=B.getBoxSize({startPoint:t.startPoint,endPoint:t.endPoint}),s=[i[0]/this.meshWidth,i[1]/this.meshHeight],r=e.map(l=>[s[0]*(l[0]-this.meshWidth/2),s[1]*(l[1]-this.meshHeight/2),l[2]]),c=O.buildRotationMatrix(o,[0,0]),a=r.map(l=>[...O.rotatePoint(l,c),l[2]]),d=O.invertTransformMatrix(n),u=[...B.getBoxCenter({startPoint:t.startPoint,endPoint:t.endPoint}),1],h=[O.dot(u,d[0]),O.dot(u,d[1])];return a.map(l=>[l[0]+h[0],l[1]+h[1],l[2]])}getLeftToRightEyeDepthDifference(e){const t=e[pe[0]][2],o=e[fe[0]][2];return t-o}getEyeBox(e,t,o,n,i=!1){const s=B.squarifyBox(B.enlargeBox(this.calculateLandmarksBoundingBox([e[o],e[n]]),this.irisEnlarge)),r=B.getBoxSize(s);let c=N.image.cropAndResize(t,[[s.startPoint[1]/this.meshHeight,s.startPoint[0]/this.meshWidth,s.endPoint[1]/this.meshHeight,s.endPoint[0]/this.meshWidth]],[0],[this.irisSize,this.irisSize]);return i&&(c=N.image.flipLeftRight(c)),{box:s,boxSize:r,crop:c}}getEyeCoords(e,t,o,n=!1){const i=[];for(let s=0;s<ge;s++){const r=e[s*3],c=e[s*3+1],a=e[s*3+2];i.push([(n?1-r/this.irisSize:r/this.irisSize)*o[0]+t.startPoint[0],c/this.irisSize*o[1]+t.startPoint[1],a])}return{rawCoords:i,iris:i.slice(H0)}}getAdjustedIrisCoords(e,t,o){const n=e[A.MESH_ANNOTATIONS[`${o}EyeUpper0`][v0]][2],i=e[A.MESH_ANNOTATIONS[`${o}EyeLower0`][L0]][2],s=(n+i)/2;return t.map((r,c)=>{let a=s;return c===2?a=n:c===4&&(a=i),[r[0],r[1],a]})}async predict(e,t){if(this.skipFrames=t.detector.skipFrames,this.maxFaces=t.detector.maxFaces,this.shouldUpdateRegionsOfInterest()){const{boxes:n,scaleFactor:i}=await this.boundingBoxDetector.getBoundingBoxes(e);if(n.length===0)return this.regionsOfInterest=[],null;const s=n.map(r=>{const c={startPoint:r.box.startPoint.squeeze().arraySync(),endPoint:r.box.endPoint.squeeze().arraySync()};r.box.startPoint.dispose(),r.box.endPoint.dispose();const a=B.scaleBoxCoordinates(c,i),d=B.enlargeBox(a),u=r.landmarks.arraySync();return r.landmarks.dispose(),r.probability.dispose(),{...d,landmarks:u}});this.updateRegionsOfInterest(s),this.runsWithoutFaceDetector=0}else this.runsWithoutFaceDetector++;const o=N.tidy(()=>this.regionsOfInterest.map((n,i)=>{let s=0;const r=n.landmarks.length>=R0;let[c,a]=O0;r===!1&&([c,a]=F0),s=O.computeRotation(n.landmarks[c],n.landmarks[a]);const d=B.getBoxCenter({startPoint:n.startPoint,endPoint:n.endPoint}),u=[d[0]/e.shape[2],d[1]/e.shape[1]];let h=e,l=O.IDENTITY_MATRIX;s!==0&&(h=N.image.rotateWithOffset(e,s,0,u),l=O.buildRotationMatrix(-s,d));const p={startPoint:n.startPoint,endPoint:n.endPoint},m=B.cutBoxFromImageAndResize(p,h,[this.meshHeight,this.meshWidth]).div(255),[,P,b]=this.meshDetector.predict(m),w=N.reshape(b,[-1,3]);let x=w.arraySync();if(t.iris.enabled){const{box:W,boxSize:ae,crop:s0}=this.getEyeBox(x,m,pe[0],pe[1],!0),{box:i0,boxSize:r0,crop:a0}=this.getEyeBox(x,m,fe[0],fe[1]),Ne=this.irisModel.predict(N.concat([s0,a0])),Ae=Ne.dataSync();Ne.dispose();const c0=Ae.slice(0,ge*3),{rawCoords:Oe,iris:d0}=this.getEyeCoords(c0,W,ae,!0),l0=Ae.slice(ge*3),{rawCoords:Ce,iris:h0}=this.getEyeCoords(l0,i0,r0),De=this.getLeftToRightEyeDepthDifference(x);Math.abs(De)<30?(oe(x,Oe,"left"),oe(x,Ce,"right")):De<1?oe(x,Oe,"left",["EyeUpper0","EyeLower0"]):oe(x,Ce,"right",["EyeUpper0","EyeLower0"]);const u0=this.getAdjustedIrisCoords(x,d0,"left"),p0=this.getAdjustedIrisCoords(x,h0,"right");x=x.concat(u0).concat(p0)}const R=this.transformRawCoords(x,n,s,l);N.dispose(x);const U=B.enlargeBox(this.calculateLandmarksBoundingBox(R));if(t.mesh.enabled){const W=N.tensor2d(R);this.regionsOfInterest[i]={...U,landmarks:W.arraySync()};const ae={coords:W,box:U,confidence:P.squeeze(),image:m};return ae}const Q={coords:null,box:U,confidence:P.squeeze(),image:m};return Q}));return o}updateRegionsOfInterest(e){for(let t=0;t<e.length;t++){const o=e[t],n=this.regionsOfInterest[t];let i=0;if(n&&n.startPoint){const[s,r]=o.startPoint,[c,a]=o.endPoint,[d,u]=n.startPoint,[h,l]=n.endPoint,p=Math.max(s,d),m=Math.max(r,u),P=Math.min(c,h),b=Math.min(a,l),w=(P-p)*(b-m),x=(c-s)*(a-r),R=(h-d)*(l-r);i=w/(x+R-w)}i<N0&&(this.regionsOfInterest[t]=o)}this.regionsOfInterest=this.regionsOfInterest.slice(0,e.length)}clearRegionOfInterest(e){this.regionsOfInterest[e]!=null&&(this.regionsOfInterest=[...this.regionsOfInterest.slice(0,e),...this.regionsOfInterest.slice(e+1)])}shouldUpdateRegionsOfInterest(){const e=this.regionsOfInterest.length,t=e===0;return this.maxFaces===1||t?t:e!==this.maxFaces&&this.runsWithoutFaceDetector>=this.skipFrames}calculateLandmarksBoundingBox(e){const t=e.map(s=>s[0]),o=e.map(s=>s[1]),n=[Math.min(...t),Math.min(...o)],i=[Math.max(...t),Math.max(...o)];return{startPoint:n,endPoint:i}}}Ze.Pipeline=q0});var et=y(Je=>{Je.UV_COORDS=[[.499976992607117,.652534008026123],[.500025987625122,.547487020492554],[.499974012374878,.602371990680695],[.482113003730774,.471979022026062],[.500150978565216,.527155995368958],[.499909996986389,.498252987861633],[.499523013830185,.40106201171875],[.289712011814117,.380764007568359],[.499954998493195,.312398016452789],[.499987006187439,.269918978214264],[.500023007392883,.107050001621246],[.500023007392883,.666234016418457],[.5000159740448,.679224014282227],[.500023007392883,.692348003387451],[.499976992607117,.695277988910675],[.499976992607117,.70593398809433],[.499976992607117,.719385027885437],[.499976992607117,.737019002437592],[.499967992305756,.781370997428894],[.499816000461578,.562981009483337],[.473773002624512,.573909997940063],[.104906998574734,.254140973091125],[.365929991006851,.409575998783112],[.338757991790771,.41302502155304],[.311120003461838,.409460008144379],[.274657994508743,.389131009578705],[.393361985683441,.403706014156342],[.345234006643295,.344011008739471],[.370094001293182,.346076011657715],[.319321990013123,.347265005111694],[.297903001308441,.353591024875641],[.24779200553894,.410809993743896],[.396889001131058,.842755019664764],[.280097991228104,.375599980354309],[.106310002505779,.399955987930298],[.2099249958992,.391353011131287],[.355807989835739,.534406006336212],[.471751004457474,.65040397644043],[.474155008792877,.680191993713379],[.439785003662109,.657229006290436],[.414617002010345,.66654098033905],[.450374007225037,.680860996246338],[.428770989179611,.682690978050232],[.374971002340317,.727805018424988],[.486716985702515,.547628998756409],[.485300987958908,.527395009994507],[.257764995098114,.314490020275116],[.401223003864288,.455172002315521],[.429818987846375,.548614978790283],[.421351999044418,.533740997314453],[.276895999908447,.532056987285614],[.483370006084442,.499586999416351],[.33721199631691,.282882988452911],[.296391993761063,.293242990970612],[.169294998049736,.193813979625702],[.447580009698868,.302609980106354],[.392390012741089,.353887975215912],[.354490011930466,.696784019470215],[.067304998636246,.730105042457581],[.442739009857178,.572826027870178],[.457098007202148,.584792017936707],[.381974011659622,.694710969924927],[.392388999462128,.694203019142151],[.277076005935669,.271932005882263],[.422551989555359,.563233017921448],[.385919004678726,.281364023685455],[.383103013038635,.255840003490448],[.331431001424789,.119714021682739],[.229923993349075,.232002973556519],[.364500999450684,.189113974571228],[.229622006416321,.299540996551514],[.173287004232407,.278747975826263],[.472878992557526,.666198015213013],[.446828007698059,.668527007102966],[.422762006521225,.673889994621277],[.445307999849319,.580065965652466],[.388103008270264,.693961024284363],[.403039008378983,.706539988517761],[.403629004955292,.693953037261963],[.460041999816895,.557139039039612],[.431158006191254,.692366003990173],[.452181994915009,.692366003990173],[.475387006998062,.692366003990173],[.465828001499176,.779190003871918],[.472328990697861,.736225962638855],[.473087012767792,.717857003211975],[.473122000694275,.704625964164734],[.473033010959625,.695277988910675],[.427942007780075,.695277988910675],[.426479011774063,.703539967536926],[.423162013292313,.711845993995667],[.4183090031147,.720062971115112],[.390094995498657,.639572978019714],[.013953999616206,.560034036636353],[.499913990497589,.58014702796936],[.413199990987778,.69539999961853],[.409626007080078,.701822996139526],[.468080013990402,.601534962654114],[.422728985548019,.585985004901886],[.463079988956451,.593783974647522],[.37211999297142,.47341400384903],[.334562003612518,.496073007583618],[.411671012639999,.546965003013611],[.242175996303558,.14767599105835],[.290776997804642,.201445996761322],[.327338010072708,.256527006626129],[.399509996175766,.748921036720276],[.441727995872498,.261676013469696],[.429764986038208,.187834024429321],[.412198007106781,.108901023864746],[.288955003023148,.398952007293701],[.218936994671822,.435410976409912],[.41278201341629,.398970007896423],[.257135003805161,.355440020561218],[.427684992551804,.437960982322693],[.448339998722076,.536936044692993],[.178560003638268,.45755398273468],[.247308000922203,.457193970680237],[.286267012357712,.467674970626831],[.332827985286713,.460712015628815],[.368755996227264,.447206974029541],[.398963987827301,.432654976844788],[.476410001516342,.405806005001068],[.189241006970406,.523923993110657],[.228962004184723,.348950982093811],[.490725994110107,.562400996685028],[.404670000076294,.485132992267609],[.019469000399113,.401564002037048],[.426243007183075,.420431017875671],[.396993011236191,.548797011375427],[.266469985246658,.376977026462555],[.439121007919312,.51895797252655],[.032313998788595,.644356966018677],[.419054001569748,.387154996395111],[.462783008813858,.505746960639954],[.238978996872902,.779744982719421],[.198220998048782,.831938028335571],[.107550002634525,.540755033493042],[.183610007166862,.740257024765015],[.134409993886948,.333683013916016],[.385764002799988,.883153975009918],[.490967005491257,.579378008842468],[.382384985685349,.508572995662689],[.174399003386497,.397670984268188],[.318785011768341,.39623498916626],[.343364000320435,.400596976280212],[.396100014448166,.710216999053955],[.187885001301765,.588537991046906],[.430987000465393,.944064974784851],[.318993002176285,.898285031318665],[.266247987747192,.869701027870178],[.500023007392883,.190576016902924],[.499976992607117,.954452991485596],[.366169989109039,.398822009563446],[.393207013607025,.39553701877594],[.410373002290726,.391080021858215],[.194993004202843,.342101991176605],[.388664990663528,.362284004688263],[.365961998701096,.355970978736877],[.343364000320435,.355356991291046],[.318785011768341,.35834002494812],[.301414996385574,.363156020641327],[.058132998645306,.319076001644135],[.301414996385574,.387449026107788],[.499987989664078,.618434011936188],[.415838003158569,.624195992946625],[.445681989192963,.566076993942261],[.465844005346298,.620640993118286],[.49992299079895,.351523995399475],[.288718998432159,.819945991039276],[.335278987884521,.852819979190826],[.440512001514435,.902418971061707],[.128294005990028,.791940987110138],[.408771991729736,.373893976211548],[.455606997013092,.451801002025604],[.499877005815506,.908990025520325],[.375436991453171,.924192011356354],[.11421000212431,.615022003650665],[.448662012815475,.695277988910675],[.4480200111866,.704632043838501],[.447111994028091,.715808033943176],[.444831997156143,.730794012546539],[.430011987686157,.766808986663818],[.406787008047104,.685672998428345],[.400738000869751,.681069016456604],[.392399996519089,.677703022956848],[.367855995893478,.663918972015381],[.247923001646996,.601333022117615],[.452769994735718,.420849978923798],[.43639200925827,.359887003898621],[.416164010763168,.368713974952698],[.413385987281799,.692366003990173],[.228018000721931,.683571994304657],[.468268007040024,.352671027183533],[.411361992359161,.804327011108398],[.499989002943039,.469825029373169],[.479153990745544,.442654013633728],[.499974012374878,.439637005329132],[.432112008333206,.493588984012604],[.499886006116867,.866917014122009],[.49991300702095,.821729004383087],[.456548988819122,.819200992584229],[.344549000263214,.745438992977142],[.37890899181366,.574010014533997],[.374292999505997,.780184984207153],[.319687992334366,.570737957954407],[.357154995203018,.604269981384277],[.295284003019333,.621580958366394],[.447750002145767,.862477004528046],[.410986006259918,.508723020553589],[.31395098567009,.775308012962341],[.354128003120422,.812552988529205],[.324548006057739,.703992962837219],[.189096003770828,.646299958229065],[.279776990413666,.71465802192688],[.1338230073452,.682700991630554],[.336768001317978,.644733011722565],[.429883986711502,.466521978378296],[.455527991056442,.548622965812683],[.437114000320435,.558896005153656],[.467287987470627,.529924988746643],[.414712011814117,.335219979286194],[.37704598903656,.322777986526489],[.344107985496521,.320150971412659],[.312875986099243,.32233202457428],[.283526003360748,.333190023899078],[.241245999932289,.382785975933075],[.102986000478268,.468762993812561],[.267612010240555,.424560010433197],[.297879010438919,.433175981044769],[.333433985710144,.433878004550934],[.366427004337311,.426115989685059],[.396012008190155,.416696012020111],[.420121014118195,.41022801399231],[.007561000064015,.480777025222778],[.432949006557465,.569517970085144],[.458638995885849,.479089021682739],[.473466008901596,.545744001865387],[.476087987422943,.563830018043518],[.468472003936768,.555056989192963],[.433990985155106,.582361996173859],[.483518004417419,.562983989715576],[.482482999563217,.57784903049469],[.42645001411438,.389798998832703],[.438998997211456,.39649498462677],[.450067013502121,.400434017181396],[.289712011814117,.368252992630005],[.276670008897781,.363372981548309],[.517862021923065,.471948027610779],[.710287988185883,.380764007568359],[.526226997375488,.573909997940063],[.895093023777008,.254140973091125],[.634069979190826,.409575998783112],[.661242008209229,.41302502155304],[.688880026340485,.409460008144379],[.725341975688934,.389131009578705],[.606630027294159,.40370500087738],[.654766023159027,.344011008739471],[.629905998706818,.346076011657715],[.680678009986877,.347265005111694],[.702096998691559,.353591024875641],[.75221198797226,.410804986953735],[.602918028831482,.842862963676453],[.719901978969574,.375599980354309],[.893692970275879,.399959981441498],[.790081977844238,.391354024410248],[.643998026847839,.534487962722778],[.528249025344849,.65040397644043],[.525849997997284,.680191040039062],[.560214996337891,.657229006290436],[.585384011268616,.66654098033905],[.549625992774963,.680860996246338],[.57122802734375,.682691991329193],[.624852001667023,.72809898853302],[.513050019741058,.547281980514526],[.51509702205658,.527251958847046],[.742246985435486,.314507007598877],[.598631024360657,.454979002475739],[.570338010787964,.548575043678284],[.578631997108459,.533622980117798],[.723087012767792,.532054007053375],[.516445994377136,.499638974666595],[.662801027297974,.282917976379395],[.70362401008606,.293271005153656],[.830704987049103,.193813979625702],[.552385985851288,.302568018436432],[.607609987258911,.353887975215912],[.645429015159607,.696707010269165],[.932694971561432,.730105042457581],[.557260990142822,.572826027870178],[.542901992797852,.584792017936707],[.6180260181427,.694710969924927],[.607590973377228,.694203019142151],[.722943007946014,.271963000297546],[.577413976192474,.563166975975037],[.614082992076874,.281386971473694],[.616907000541687,.255886018276215],[.668509006500244,.119913995265961],[.770092010498047,.232020974159241],[.635536015033722,.189248979091644],[.77039098739624,.299556016921997],[.826722025871277,.278755009174347],[.527121007442474,.666198015213013],[.553171992301941,.668527007102966],[.577238023281097,.673889994621277],[.554691970348358,.580065965652466],[.611896991729736,.693961024284363],[.59696102142334,.706539988517761],[.596370995044708,.693953037261963],[.539958000183105,.557139039039612],[.568841993808746,.692366003990173],[.547818005084991,.692366003990173],[.52461302280426,.692366003990173],[.534089982509613,.779141008853912],[.527670979499817,.736225962638855],[.526912987232208,.717857003211975],[.526877999305725,.704625964164734],[.526966989040375,.695277988910675],[.572058022022247,.695277988910675],[.573521018028259,.703539967536926],[.57683801651001,.711845993995667],[.581691026687622,.720062971115112],[.609944999217987,.639909982681274],[.986046016216278,.560034036636353],[.5867999792099,.69539999961853],[.590372025966644,.701822996139526],[.531915009021759,.601536989212036],[.577268004417419,.585934996604919],[.536915004253387,.593786001205444],[.627542972564697,.473352015018463],[.665585994720459,.495950996875763],[.588353991508484,.546862006187439],[.757824003696442,.14767599105835],[.709249973297119,.201507985591888],[.672684013843536,.256581008434296],[.600408971309662,.74900496006012],[.55826598405838,.261672019958496],[.570303976535797,.187870979309082],[.588165998458862,.109044015407562],[.711045026779175,.398952007293701],[.781069993972778,.435405015945435],[.587247014045715,.398931980133057],[.742869973182678,.355445981025696],[.572156012058258,.437651991844177],[.55186802148819,.536570012569427],[.821442008018494,.457556009292603],[.752701997756958,.457181990146637],[.71375697851181,.467626988887787],[.66711300611496,.460672974586487],[.631101012229919,.447153985500336],[.6008620262146,.432473003864288],[.523481011390686,.405627012252808],[.810747981071472,.523926019668579],[.771045982837677,.348959028720856],[.509127020835876,.562718033790588],[.595292985439301,.485023975372314],[.980530977249146,.401564002037048],[.573499977588654,.420000016689301],[.602994978427887,.548687994480133],[.733529984951019,.376977026462555],[.560611009597778,.519016981124878],[.967685997486115,.644356966018677],[.580985009670258,.387160003185272],[.537728011608124,.505385041236877],[.760966002941132,.779752969741821],[.801778972148895,.831938028335571],[.892440974712372,.54076099395752],[.816350996494293,.740260004997253],[.865594983100891,.333687007427216],[.614073991775513,.883246004581451],[.508952975273132,.579437971115112],[.617941975593567,.508316040039062],[.825608015060425,.397674977779388],[.681214988231659,.39623498916626],[.656635999679565,.400596976280212],[.603900015354156,.710216999053955],[.81208598613739,.588539004325867],[.56801301240921,.944564998149872],[.681007981300354,.898285031318665],[.733752012252808,.869701027870178],[.633830010890961,.398822009563446],[.606792986392975,.39553701877594],[.589659988880157,.391062021255493],[.805015981197357,.342108011245728],[.611334979534149,.362284004688263],[.634037971496582,.355970978736877],[.656635999679565,.355356991291046],[.681214988231659,.35834002494812],[.698584973812103,.363156020641327],[.941866993904114,.319076001644135],[.698584973812103,.387449026107788],[.584177017211914,.624107003211975],[.554318010807037,.566076993942261],[.534153997898102,.62064003944397],[.711217999458313,.819975018501282],[.664629995822906,.852871000766754],[.559099972248077,.902631998062134],[.871706008911133,.791940987110138],[.591234028339386,.373893976211548],[.544341027736664,.451583981513977],[.624562978744507,.924192011356354],[.88577002286911,.615028977394104],[.551338016986847,.695277988910675],[.551980018615723,.704632043838501],[.552887976169586,.715808033943176],[.555167973041534,.730794012546539],[.569944024085999,.767035007476807],[.593203008174896,.685675978660583],[.599261999130249,.681069016456604],[.607599973678589,.677703022956848],[.631937980651855,.663500010967255],[.752032995223999,.601315021514893],[.547226011753082,.420395016670227],[.563543975353241,.359827995300293],[.583841025829315,.368713974952698],[.586614012718201,.692366003990173],[.771915018558502,.683578014373779],[.531597018241882,.352482974529266],[.588370978832245,.804440975189209],[.52079701423645,.442565023899078],[.567984998226166,.493479013442993],[.543282985687256,.819254994392395],[.655317008495331,.745514988899231],[.621008992195129,.574018001556396],[.625559985637665,.78031200170517],[.680198013782501,.570719003677368],[.64276397228241,.604337990283966],[.704662978649139,.621529996395111],[.552012026309967,.862591981887817],[.589071989059448,.508637011051178],[.685944974422455,.775357007980347],[.645735025405884,.812640011310577],[.675342977046967,.703978002071381],[.810858011245728,.646304965019226],[.72012197971344,.714666962623596],[.866151988506317,.682704985141754],[.663187026977539,.644596993923187],[.570082008838654,.466325998306274],[.544561982154846,.548375964164734],[.562758982181549,.558784961700439],[.531987011432648,.530140042304993],[.585271000862122,.335177004337311],[.622952997684479,.32277899980545],[.655896008014679,.320163011550903],[.687132000923157,.322345972061157],[.716481983661652,.333200991153717],[.758756995201111,.382786989212036],[.897013008594513,.468769013881683],[.732392013072968,.424547016620636],[.70211398601532,.433162987232208],[.66652500629425,.433866024017334],[.633504986763,.426087975502014],[.603875994682312,.416586995124817],[.579657971858978,.409945011138916],[.992439985275269,.480777025222778],[.567192018032074,.569419980049133],[.54136598110199,.478899002075195],[.526564002037048,.546118021011353],[.523913025856018,.563830018043518],[.531529009342194,.555056989192963],[.566035985946655,.582329034805298],[.51631098985672,.563053965568542],[.5174720287323,.577877044677734],[.573594987392426,.389806985855103],[.560697972774506,.395331978797913],[.549755990505219,.399751007556915],[.710287988185883,.368252992630005],[.723330020904541,.363372981548309]]});var tt=y(j0=>{ve(j0,{default:()=>U0});var U0=[127,34,139,11,0,37,232,231,120,72,37,39,128,121,47,232,121,128,104,69,67,175,171,148,157,154,155,118,50,101,73,39,40,9,151,108,48,115,131,194,204,211,74,40,185,80,42,183,40,92,186,230,229,118,202,212,214,83,18,17,76,61,146,160,29,30,56,157,173,106,204,194,135,214,192,203,165,98,21,71,68,51,45,4,144,24,23,77,146,91,205,50,187,201,200,18,91,106,182,90,91,181,85,84,17,206,203,36,148,171,140,92,40,39,193,189,244,159,158,28,247,246,161,236,3,196,54,68,104,193,168,8,117,228,31,189,193,55,98,97,99,126,47,100,166,79,218,155,154,26,209,49,131,135,136,150,47,126,217,223,52,53,45,51,134,211,170,140,67,69,108,43,106,91,230,119,120,226,130,247,63,53,52,238,20,242,46,70,156,78,62,96,46,53,63,143,34,227,173,155,133,123,117,111,44,125,19,236,134,51,216,206,205,154,153,22,39,37,167,200,201,208,36,142,100,57,212,202,20,60,99,28,158,157,35,226,113,160,159,27,204,202,210,113,225,46,43,202,204,62,76,77,137,123,116,41,38,72,203,129,142,64,98,240,49,102,64,41,73,74,212,216,207,42,74,184,169,170,211,170,149,176,105,66,69,122,6,168,123,147,187,96,77,90,65,55,107,89,90,180,101,100,120,63,105,104,93,137,227,15,86,85,129,102,49,14,87,86,55,8,9,100,47,121,145,23,22,88,89,179,6,122,196,88,95,96,138,172,136,215,58,172,115,48,219,42,80,81,195,3,51,43,146,61,171,175,199,81,82,38,53,46,225,144,163,110,246,33,7,52,65,66,229,228,117,34,127,234,107,108,69,109,108,151,48,64,235,62,78,191,129,209,126,111,35,143,163,161,246,117,123,50,222,65,52,19,125,141,221,55,65,3,195,197,25,7,33,220,237,44,70,71,139,122,193,245,247,130,33,71,21,162,153,158,159,170,169,150,188,174,196,216,186,92,144,160,161,2,97,167,141,125,241,164,167,37,72,38,12,145,159,160,38,82,13,63,68,71,226,35,111,158,153,154,101,50,205,206,92,165,209,198,217,165,167,97,220,115,218,133,112,243,239,238,241,214,135,169,190,173,133,171,208,32,125,44,237,86,87,178,85,86,179,84,85,180,83,84,181,201,83,182,137,93,132,76,62,183,61,76,184,57,61,185,212,57,186,214,207,187,34,143,156,79,239,237,123,137,177,44,1,4,201,194,32,64,102,129,213,215,138,59,166,219,242,99,97,2,94,141,75,59,235,24,110,228,25,130,226,23,24,229,22,23,230,26,22,231,112,26,232,189,190,243,221,56,190,28,56,221,27,28,222,29,27,223,30,29,224,247,30,225,238,79,20,166,59,75,60,75,240,147,177,215,20,79,166,187,147,213,112,233,244,233,128,245,128,114,188,114,217,174,131,115,220,217,198,236,198,131,134,177,132,58,143,35,124,110,163,7,228,110,25,356,389,368,11,302,267,452,350,349,302,303,269,357,343,277,452,453,357,333,332,297,175,152,377,384,398,382,347,348,330,303,304,270,9,336,337,278,279,360,418,262,431,304,408,409,310,415,407,270,409,410,450,348,347,422,430,434,313,314,17,306,307,375,387,388,260,286,414,398,335,406,418,364,367,416,423,358,327,251,284,298,281,5,4,373,374,253,307,320,321,425,427,411,421,313,18,321,405,406,320,404,405,315,16,17,426,425,266,377,400,369,322,391,269,417,465,464,386,257,258,466,260,388,456,399,419,284,332,333,417,285,8,346,340,261,413,441,285,327,460,328,355,371,329,392,439,438,382,341,256,429,420,360,364,394,379,277,343,437,443,444,283,275,440,363,431,262,369,297,338,337,273,375,321,450,451,349,446,342,467,293,334,282,458,461,462,276,353,383,308,324,325,276,300,293,372,345,447,382,398,362,352,345,340,274,1,19,456,248,281,436,427,425,381,256,252,269,391,393,200,199,428,266,330,329,287,273,422,250,462,328,258,286,384,265,353,342,387,259,257,424,431,430,342,353,276,273,335,424,292,325,307,366,447,345,271,303,302,423,266,371,294,455,460,279,278,294,271,272,304,432,434,427,272,407,408,394,430,431,395,369,400,334,333,299,351,417,168,352,280,411,325,319,320,295,296,336,319,403,404,330,348,349,293,298,333,323,454,447,15,16,315,358,429,279,14,15,316,285,336,9,329,349,350,374,380,252,318,402,403,6,197,419,318,319,325,367,364,365,435,367,397,344,438,439,272,271,311,195,5,281,273,287,291,396,428,199,311,271,268,283,444,445,373,254,339,263,466,249,282,334,296,449,347,346,264,447,454,336,296,299,338,10,151,278,439,455,292,407,415,358,371,355,340,345,372,390,249,466,346,347,280,442,443,282,19,94,370,441,442,295,248,419,197,263,255,359,440,275,274,300,383,368,351,412,465,263,467,466,301,368,389,380,374,386,395,378,379,412,351,419,436,426,322,373,390,388,2,164,393,370,462,461,164,0,267,302,11,12,374,373,387,268,12,13,293,300,301,446,261,340,385,384,381,330,266,425,426,423,391,429,355,437,391,327,326,440,457,438,341,382,362,459,457,461,434,430,394,414,463,362,396,369,262,354,461,457,316,403,402,315,404,403,314,405,404,313,406,405,421,418,406,366,401,361,306,408,407,291,409,408,287,410,409,432,436,410,434,416,411,264,368,383,309,438,457,352,376,401,274,275,4,421,428,262,294,327,358,433,416,367,289,455,439,462,370,326,2,326,370,305,460,455,254,449,448,255,261,446,253,450,449,252,451,450,256,452,451,341,453,452,413,464,463,441,413,414,258,442,441,257,443,442,259,444,443,260,445,444,467,342,445,459,458,250,289,392,290,290,328,460,376,433,435,250,290,392,411,416,433,341,463,464,453,464,465,357,465,412,343,412,399,360,363,440,437,399,456,420,456,363,401,435,288,372,383,353,339,255,249,448,261,255,133,243,190,133,155,112,33,246,247,33,130,25,398,384,286,362,398,414,362,463,341,263,359,467,263,249,255,466,467,260,75,60,166,238,239,79,162,127,139,72,11,37,121,232,120,73,72,39,114,128,47,233,232,128,103,104,67,152,175,148,173,157,155,119,118,101,74,73,40,107,9,108,49,48,131,32,194,211,184,74,185,191,80,183,185,40,186,119,230,118,210,202,214,84,83,17,77,76,146,161,160,30,190,56,173,182,106,194,138,135,192,129,203,98,54,21,68,5,51,4,145,144,23,90,77,91,207,205,187,83,201,18,181,91,182,180,90,181,16,85,17,205,206,36,176,148,140,165,92,39,245,193,244,27,159,28,30,247,161,174,236,196,103,54,104,55,193,8,111,117,31,221,189,55,240,98,99,142,126,100,219,166,218,112,155,26,198,209,131,169,135,150,114,47,217,224,223,53,220,45,134,32,211,140,109,67,108,146,43,91,231,230,120,113,226,247,105,63,52,241,238,242,124,46,156,95,78,96,70,46,63,116,143,227,116,123,111,1,44,19,3,236,51,207,216,205,26,154,22,165,39,167,199,200,208,101,36,100,43,57,202,242,20,99,56,28,157,124,35,113,29,160,27,211,204,210,124,113,46,106,43,204,96,62,77,227,137,116,73,41,72,36,203,142,235,64,240,48,49,64,42,41,74,214,212,207,183,42,184,210,169,211,140,170,176,104,105,69,193,122,168,50,123,187,89,96,90,66,65,107,179,89,180,119,101,120,68,63,104,234,93,227,16,15,85,209,129,49,15,14,86,107,55,9,120,100,121,153,145,22,178,88,179,197,6,196,89,88,96,135,138,136,138,215,172,218,115,219,41,42,81,5,195,51,57,43,61,208,171,199,41,81,38,224,53,225,24,144,110,105,52,66,118,229,117,227,34,234,66,107,69,10,109,151,219,48,235,183,62,191,142,129,126,116,111,143,7,163,246,118,117,50,223,222,52,94,19,141,222,221,65,196,3,197,45,220,44,156,70,139,188,122,245,139,71,162,145,153,159,149,170,150,122,188,196,206,216,92,163,144,161,164,2,167,242,141,241,0,164,37,11,72,12,144,145,160,12,38,13,70,63,71,31,226,111,157,158,154,36,101,205,203,206,165,126,209,217,98,165,97,237,220,218,237,239,241,210,214,169,140,171,32,241,125,237,179,86,178,180,85,179,181,84,180,182,83,181,194,201,182,177,137,132,184,76,183,185,61,184,186,57,185,216,212,186,192,214,187,139,34,156,218,79,237,147,123,177,45,44,4,208,201,32,98,64,129,192,213,138,235,59,219,141,242,97,97,2,141,240,75,235,229,24,228,31,25,226,230,23,229,231,22,230,232,26,231,233,112,232,244,189,243,189,221,190,222,28,221,223,27,222,224,29,223,225,30,224,113,247,225,99,60,240,213,147,215,60,20,166,192,187,213,243,112,244,244,233,245,245,128,188,188,114,174,134,131,220,174,217,236,236,198,134,215,177,58,156,143,124,25,110,7,31,228,25,264,356,368,0,11,267,451,452,349,267,302,269,350,357,277,350,452,357,299,333,297,396,175,377,381,384,382,280,347,330,269,303,270,151,9,337,344,278,360,424,418,431,270,304,409,272,310,407,322,270,410,449,450,347,432,422,434,18,313,17,291,306,375,259,387,260,424,335,418,434,364,416,391,423,327,301,251,298,275,281,4,254,373,253,375,307,321,280,425,411,200,421,18,335,321,406,321,320,405,314,315,17,423,426,266,396,377,369,270,322,269,413,417,464,385,386,258,248,456,419,298,284,333,168,417,8,448,346,261,417,413,285,326,327,328,277,355,329,309,392,438,381,382,256,279,429,360,365,364,379,355,277,437,282,443,283,281,275,363,395,431,369,299,297,337,335,273,321,348,450,349,359,446,467,283,293,282,250,458,462,300,276,383,292,308,325,283,276,293,264,372,447,346,352,340,354,274,19,363,456,281,426,436,425,380,381,252,267,269,393,421,200,428,371,266,329,432,287,422,290,250,328,385,258,384,446,265,342,386,387,257,422,424,430,445,342,276,422,273,424,306,292,307,352,366,345,268,271,302,358,423,371,327,294,460,331,279,294,303,271,304,436,432,427,304,272,408,395,394,431,378,395,400,296,334,299,6,351,168,376,352,411,307,325,320,285,295,336,320,319,404,329,330,349,334,293,333,366,323,447,316,15,315,331,358,279,317,14,316,8,285,9,277,329,350,253,374,252,319,318,403,351,6,419,324,318,325,397,367,365,288,435,397,278,344,439,310,272,311,248,195,281,375,273,291,175,396,199,312,311,268,276,283,445,390,373,339,295,282,296,448,449,346,356,264,454,337,336,299,337,338,151,294,278,455,308,292,415,429,358,355,265,340,372,388,390,466,352,346,280,295,442,282,354,19,370,285,441,295,195,248,197,457,440,274,301,300,368,417,351,465,251,301,389,385,380,386,394,395,379,399,412,419,410,436,322,387,373,388,326,2,393,354,370,461,393,164,267,268,302,12,386,374,387,312,268,13,298,293,301,265,446,340,380,385,381,280,330,425,322,426,391,420,429,437,393,391,326,344,440,438,458,459,461,364,434,394,428,396,262,274,354,457,317,316,402,316,315,403,315,314,404,314,313,405,313,421,406,323,366,361,292,306,407,306,291,408,291,287,409,287,432,410,427,434,411,372,264,383,459,309,457,366,352,401,1,274,4,418,421,262,331,294,358,435,433,367,392,289,439,328,462,326,94,2,370,289,305,455,339,254,448,359,255,446,254,253,449,253,252,450,252,256,451,256,341,452,414,413,463,286,441,414,286,258,441,258,257,442,257,259,443,259,260,444,260,467,445,309,459,250,305,289,290,305,290,460,401,376,435,309,250,392,376,411,433,453,341,464,357,453,465,343,357,412,437,343,399,344,360,440,420,437,456,360,420,363,361,401,288,265,372,353,390,339,249,339,448,255]});var st=y(Z=>{const H=require("@tensorflow/tfjs"),W0=We(),ot=de(),K0=$e(),Y0=et(),X0=tt().default;class nt{constructor(e,t,o,n){this.pipeline=new K0.Pipeline(e,t,o,n),n&&(this.config=n)}async estimateFaces(e,t){t&&(this.config=t);const o=H.tidy(()=>(e instanceof H.Tensor||(e=H.browser.fromPixels(e)),e.toFloat().expandDims(0))),n=await this.pipeline.predict(o,t);H.dispose(o);const i=[];for(const s of n||[]){const r=s.confidence.arraySync();if(r>=this.config.detector.minConfidence){const c=s.coords?s.coords.arraySync():null,a={};if(c&&c.length>0)for(const d in ot.MESH_ANNOTATIONS)(this.config.iris.enabled||d.includes("Iris")===!1)&&(a[d]=ot.MESH_ANNOTATIONS[d].map(u=>c[u]));i.push({confidence:r||0,box:s.box?[s.box.startPoint[0],s.box.startPoint[1],s.box.endPoint[0]-s.box.startPoint[0],s.box.endPoint[1]-s.box.startPoint[1]]:0,mesh:c,annotations:a,image:s.image?H.clone(s.image):null})}s.confidence.dispose(),s.image.dispose()}return i}}async function G0(e){const t=await Promise.all([W0.load(e),H.loadGraphModel(e.mesh.modelPath,{fromTFHub:e.mesh.modelPath.includes("tfhub.dev")}),H.loadGraphModel(e.iris.modelPath,{fromTFHub:e.iris.modelPath.includes("tfhub.dev")})]),o=new nt(t[0],t[1],t[2],e);return o}Z.load=G0;Z.MediaPipeFaceMesh=nt;Z.uv_coords=Y0;Z.triangulation=X0});var rt=y(ne=>{const E=require("@tensorflow/tfjs"),Y={};let it={age:0,gender:""},ye=0;async function V0(e,t){const o=E.tidy(()=>{const n=E.browser.fromPixels(e),i=E.image.resizeBilinear(n,[t,t]),s=E.cast(E.expandDims(i,0),"float32");return s});return o}async function Q0(e){Y.age||(Y.age=await E.loadGraphModel(e.face.age.modelPath))}async function Z0(e){Y.gender||(Y.gender=await E.loadGraphModel(e.face.gender.modelPath))}async function $0(e,t){if(ye+=1,ye>=t.face.age.skipFrames)return ye=0,it;let o;if(e instanceof E.Tensor){const i=E.image.resizeBilinear(e,[t.face.age.inputSize,t.face.age.inputSize],!1);o=E.mul(i,[255]),E.dispose(i)}else o=await V0(e,t.face.age.inputSize);const n={};if(t.face.age.enabled){const i=await Y.age.predict(o),s=await i.data();n.age=Math.trunc(10*s[0])/10,E.dispose(i)}if(t.face.gender.enabled){const i=await Y.gender.predict(o),s=await i.data();n.gender=Math.trunc(100*s[0])<50?"female":"male",E.dispose(i)}return E.dispose(o),it=n,n}ne.predict=$0;ne.loadAge=Q0;ne.loadGender=Z0});var dt=y(at=>{const ct=require("@tensorflow/tfjs");class J0{constructor(e,t){this.model=e,this.outputStride=t;const o=this.model.inputs[0].shape;ct.util.assert(o[1]===-1&&o[2]===-1,()=>`Input shape [${o[1]}, ${o[2]}] must both be equal to or -1`)}predict(e){return ct.tidy(()=>{const t=this.preprocessInput(e.toFloat()),o=t.expandDims(0),n=this.model.predict(o),i=n.map(r=>r.squeeze([0])),s=this.nameOutputResults(i);return{heatmapScores:s.heatmap.sigmoid(),offsets:s.offsets,displacementFwd:s.displacementFwd,displacementBwd:s.displacementBwd}})}dispose(){this.model.dispose()}}at.BaseModel=J0});var xe=y(lt=>{const ht=require("@tensorflow/tfjs"),e1=dt();class t1 extends e1.BaseModel{preprocessInput(e){return ht.tidy(()=>ht.div(e,127.5).sub(1))}nameOutputResults(e){const[t,o,n,i]=e;return{offsets:t,heatmap:o,displacementFwd:n,displacementBwd:i}}}lt.MobileNet=t1});var pt=y(ut=>{function be(e){return Math.floor(e/2)}class o1{constructor(e,t){this.priorityQueue=new Array(e),this.numberOfElements=-1,this.getElementValue=t}enqueue(e){this.priorityQueue[++this.numberOfElements]=e,this.swim(this.numberOfElements)}dequeue(){const e=this.priorityQueue[0];return this.exchange(0,this.numberOfElements--),this.sink(0),this.priorityQueue[this.numberOfElements+1]=null,e}empty(){return this.numberOfElements===-1}size(){return this.numberOfElements+1}all(){return this.priorityQueue.slice(0,this.numberOfElements+1)}max(){return this.priorityQueue[0]}swim(e){for(;e>0&&this.less(be(e),e);)this.exchange(e,be(e)),e=be(e)}sink(e){for(;2*e<=this.numberOfElements;){let t=2*e;if(t<this.numberOfElements&&this.less(t,t+1)&&t++,!this.less(e,t))break;this.exchange(e,t),e=t}}getValueAt(e){return this.getElementValue(this.priorityQueue[e])}less(e,t){return this.getValueAt(e)<this.getValueAt(t)}exchange(e,t){const o=this.priorityQueue[e];this.priorityQueue[e]=this.priorityQueue[t],this.priorityQueue[t]=o}}ut.MaxHeap=o1});var ft=y(mt=>{const n1=pt();function s1(e,t,o,n,i,s){const[r,c]=s.shape;let a=!0;const d=Math.max(o-i,0),u=Math.min(o+i+1,r);for(let h=d;h<u;++h){const l=Math.max(n-i,0),p=Math.min(n+i+1,c);for(let m=l;m<p;++m)if(s.get(h,m,e)>t){a=!1;break}if(!a)break}return a}function i1(e,t,o){const[n,i,s]=o.shape,r=new n1.MaxHeap(n*i*s,({score:c})=>c);for(let c=0;c<n;++c)for(let a=0;a<i;++a)for(let d=0;d<s;++d){const u=o.get(c,a,d);if(u<e)continue;s1(d,u,c,a,t,o)&&r.enqueue({score:u,part:{heatmapY:c,heatmapX:a,id:d}})}return r}mt.buildPartWithScoreQueue=i1});var $=y(T=>{T.partNames=["nose","leftEye","rightEye","leftEar","rightEar","leftShoulder","rightShoulder","leftElbow","rightElbow","leftWrist","rightWrist","leftHip","rightHip","leftKnee","rightKnee","leftAnkle","rightAnkle"];T.NUM_KEYPOINTS=T.partNames.length;T.partIds=T.partNames.reduce((e,t,o)=>(e[t]=o,e),{});const r1=[["leftHip","leftShoulder"],["leftElbow","leftShoulder"],["leftElbow","leftWrist"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["rightHip","rightShoulder"],["rightElbow","rightShoulder"],["rightElbow","rightWrist"],["rightHip","rightKnee"],["rightKnee","rightAnkle"],["leftShoulder","rightShoulder"],["leftHip","rightHip"]];T.poseChain=[["nose","leftEye"],["leftEye","leftEar"],["nose","rightEye"],["rightEye","rightEar"],["nose","leftShoulder"],["leftShoulder","leftElbow"],["leftElbow","leftWrist"],["leftShoulder","leftHip"],["leftHip","leftKnee"],["leftKnee","leftAnkle"],["nose","rightShoulder"],["rightShoulder","rightElbow"],["rightElbow","rightWrist"],["rightShoulder","rightHip"],["rightHip","rightKnee"],["rightKnee","rightAnkle"]];T.connectedPartIndices=r1.map(([e,t])=>[T.partIds[e],T.partIds[t]]);T.partChannels=["left_face","right_face","right_upper_leg_front","right_lower_leg_back","right_upper_leg_back","left_lower_leg_front","left_upper_leg_front","left_upper_leg_back","left_lower_leg_back","right_feet","right_lower_leg_front","left_feet","torso_front","torso_back","right_upper_arm_front","right_upper_arm_back","right_lower_arm_back","left_lower_arm_front","left_upper_arm_front","left_upper_arm_back","left_lower_arm_back","right_hand","right_lower_arm_front","left_hand"]});var we=y(C=>{const a1=$();function gt(e,t,o,n){return{y:n.get(e,t,o),x:n.get(e,t,o+a1.NUM_KEYPOINTS)}}C.getOffsetPoint=gt;function c1(e,t,o){const{heatmapY:n,heatmapX:i,id:s}=e,{y:r,x:c}=gt(n,i,s,o);return{x:e.heatmapX*t+c,y:e.heatmapY*t+r}}C.getImageCoords=c1;function d1(e,t){const o=new Array(t);for(let n=0;n<t;n++)o[n]=e;return o}C.fillArray=d1;function Pe(e,t,o){return e<t?t:e>o?o:e}C.clamp=Pe;function l1(e,t,o,n){const i=o-e,s=n-t;return i*i+s*s}C.squaredDistance=l1;function h1(e,t){return{x:e.x+t.x,y:e.y+t.y}}C.addVectors=h1;function u1(e,t,o){return{y:Pe(e.y,t,o),x:Pe(e.x,t,o)}}C.clampVector=u1});var wt=y(yt=>{const J=$(),X=we(),xt=J.poseChain.map(([e,t])=>[J.partIds[e],J.partIds[t]]),Ee=xt.map(([,e])=>e),bt=xt.map(([e])=>e);function p1(e,t,o){const n=o.shape[2]/2;return{y:o.get(t.y,t.x,e),x:o.get(t.y,t.x,n+e)}}function Ie(e,t,o,n){return{y:X.clamp(Math.round(e.y/t),0,o-1),x:X.clamp(Math.round(e.x/t),0,n-1)}}function Pt(e,t,o,n,i,s,r,c=2){const[a,d]=n.shape,u=Ie(t.position,s,a,d),h=p1(e,u,r),l=X.addVectors(t.position,h);let p=l;for(let b=0;b<c;b++){const w=Ie(p,s,a,d),x=X.getOffsetPoint(w.y,w.x,o,i);p=X.addVectors({x:w.x*s,y:w.y*s},{x:x.x,y:x.y})}const m=Ie(p,s,a,d),P=n.get(m.y,m.x,o);return{position:p,part:J.partNames[o],score:P}}function m1(e,t,o,n,i,s){const r=t.shape[2],c=Ee.length,a=new Array(r),{part:d,score:u}=e,h=X.getImageCoords(d,n,o);a[d.id]={score:u,part:J.partNames[d.id],position:h};for(let l=c-1;l>=0;--l){const p=Ee[l],m=bt[l];a[p]&&!a[m]&&(a[m]=Pt(l,a[p],m,t,o,n,s))}for(let l=0;l<c;++l){const p=bt[l],m=Ee[l];a[p]&&!a[m]&&(a[m]=Pt(l,a[p],m,t,o,n,i))}return a}yt.decodePose=m1});var Me=y(Et=>{const f1=ft(),g1=wt(),It=we();function Mt(e,t,{x:o,y:n},i){return e.some(({keypoints:s})=>{const r=s[i].position;return It.squaredDistance(n,o,r.y,r.x)<=t})}function y1(e,t,o){const n=o.reduce((i,{position:s,score:r},c)=>(Mt(e,t,s,c)||(i+=r),i),0);return n/o.length}const x1=1;function b1(e,t,o,n,i,s,r=.5,c=20){const a=[],d=f1.buildPartWithScoreQueue(r,x1,e),u=c*c;for(;a.length<s&&!d.empty();){const h=d.dequeue(),l=It.getImageCoords(h.part,i,t);if(Mt(a,u,l,h.part.id))continue;const p=g1.decodePose(h,e,t,i,o,n),m=y1(a,u,p);a.push({keypoints:p,score:m})}return a}Et.decodeMultiplePoses=b1});var Te=y(M=>{const G=require("@tensorflow/tfjs"),P1=$();function w1(e,t,o){return e<o||t<o}function E1(e,t){return P1.connectedPartIndices.reduce((o,[n,i])=>(w1(e[n].score,e[i].score,t)||o.push([e[n],e[i]]),o),[])}M.getAdjacentKeyPoints=E1;const{NEGATIVE_INFINITY:St,POSITIVE_INFINITY:Tt}=Number;function Bt(e){return e.reduce(({maxX:t,maxY:o,minX:n,minY:i},{position:{x:s,y:r}})=>({maxX:Math.max(t,s),maxY:Math.max(o,r),minX:Math.min(n,s),minY:Math.min(i,r)}),{maxX:St,maxY:St,minX:Tt,minY:Tt})}M.getBoundingBox=Bt;function I1(e){const{minX:t,minY:o,maxX:n,maxY:i}=Bt(e);return[{x:t,y:o},{x:n,y:o},{x:n,y:i},{x:t,y:i}]}M.getBoundingBoxPoints=I1;async function M1(e){return Promise.all(e.map(t=>t.buffer()))}M.toTensorBuffers3D=M1;function _t(e,t,o,n=0,i=0){return{score:e.score,keypoints:e.keypoints.map(({score:s,part:r,position:c})=>({score:s,part:r,position:{x:c.x*o+i,y:c.y*t+n}}))}}M.scalePose=_t;function kt(e,t,o,n=0,i=0){return o===1&&t===1&&n===0&&i===0?e:e.map(s=>_t(s,t,o,n,i))}M.scalePoses=kt;function zt(e){return e instanceof G.Tensor?[e.shape[0],e.shape[1]]:[e.height,e.width]}M.getInputTensorDimensions=zt;function Se(e){return e instanceof G.Tensor?e:G.browser.fromPixels(e)}M.toInputTensor=Se;function S1(e,t,o){return G.tidy(()=>{const n=Se(e);return n.resizeBilinear([t,o])})}M.toResizedInputTensor=S1;function T1(e,[t,o]){const[n,i]=zt(e),s=o/t,r=i/n;let[c,a,d,u]=[0,0,0,0];r<s?(c=0,a=0,d=Math.round(.5*(s*n-i)),u=Math.round(.5*(s*n-i))):(c=Math.round(.5*(1/s*i-n)),a=Math.round(.5*(1/s*i-n)),d=0,u=0);const h=G.tidy(()=>{let l=Se(e);return l=G.pad3d(l,[[c,a],[d,u],[0,0]]),l.resizeBilinear([t,o])});return{resized:h,padding:{top:c,left:d,right:u,bottom:a}}}M.padAndResizeTo=T1;function B1(e,[t,o],[n,i],s){const r=(t+s.top+s.bottom)/n,c=(o+s.left+s.right)/i,a=kt(e,r,c,-s.top,-s.left);return a}M.scaleAndFlipPoses=B1});var Nt=y(Be=>{const _1=require("@tensorflow/tfjs"),k1=xe(),z1=Me(),se=Te();class Rt{constructor(e){this.baseModel=e}async estimatePoses(e,t){const o=t.outputStride,[n,i]=se.getInputTensorDimensions(e),{resized:s,padding:r}=se.padAndResizeTo(e,[t.inputResolution,t.inputResolution]),{heatmapScores:c,offsets:a,displacementFwd:d,displacementBwd:u}=this.baseModel.predict(s),h=await se.toTensorBuffers3D([c,a,d,u]),l=h[0],p=h[1],m=h[2],P=h[3],b=await z1.decodeMultiplePoses(l,p,m,P,o,t.maxDetections,t.scoreThreshold,t.nmsRadius),w=se.scaleAndFlipPoses(b,[n,i],[t.inputResolution,t.inputResolution],r);return c.dispose(),a.dispose(),d.dispose(),u.dispose(),s.dispose(),w}dispose(){this.baseModel.dispose()}}Be.PoseNet=Rt;async function R1(e){const t=await _1.loadGraphModel(e.modelPath),o=new k1.MobileNet(t,e.outputStride);return new Rt(o)}async function N1(e){return R1(e)}Be.load=N1});var Ot=y(I=>{const A1=xe(),At=Nt(),O1=Me(),ie=$(),ee=Te();I.load=At.load;I.PoseNet=At.PoseNet;I.MobileNet=A1.MobileNet;I.decodeMultiplePoses=O1.decodeMultiplePoses;I.partChannels=ie.partChannels;I.partIds=ie.partIds;I.partNames=ie.partNames;I.poseChain=ie.poseChain;I.getAdjacentKeyPoints=ee.getAdjacentKeyPoints;I.getBoundingBox=ee.getBoundingBox;I.getBoundingBoxPoints=ee.getBoundingBoxPoints;I.scaleAndFlipPoses=ee.scaleAndFlipPoses;I.scalePose=ee.scalePose});var ze=y(D=>{const C1=require("@tensorflow/tfjs");function _e(e){return[Math.abs(e.endPoint[0]-e.startPoint[0]),Math.abs(e.endPoint[1]-e.startPoint[1])]}D.getBoxSize=_e;function ke(e){return[e.startPoint[0]+(e.endPoint[0]-e.startPoint[0])/2,e.startPoint[1]+(e.endPoint[1]-e.startPoint[1])/2]}D.getBoxCenter=ke;function D1(e,t,o){const n=t.shape[1],i=t.shape[2],s=[[e.startPoint[1]/n,e.startPoint[0]/i,e.endPoint[1]/n,e.endPoint[0]/i]];return C1.image.cropAndResize(t,s,[0],o)}D.cutBoxFromImageAndResize=D1;function F1(e,t){const o=[e.startPoint[0]*t[0],e.startPoint[1]*t[1]],n=[e.endPoint[0]*t[0],e.endPoint[1]*t[1]],i=e.palmLandmarks.map(s=>{const r=[s[0]*t[0],s[1]*t[1]];return r});return{startPoint:o,endPoint:n,palmLandmarks:i}}D.scaleBoxCoordinates=F1;function v1(e,t=1.5){const o=ke(e),n=_e(e),i=[t*n[0]/2,t*n[1]/2],s=[o[0]-i[0],o[1]-i[1]],r=[o[0]+i[0],o[1]+i[1]];return{startPoint:s,endPoint:r,palmLandmarks:e.palmLandmarks}}D.enlargeBox=v1;function L1(e){const t=ke(e),o=_e(e),n=Math.max(...o),i=n/2,s=[t[0]-i,t[1]-i],r=[t[0]+i,t[1]+i];return{startPoint:s,endPoint:r,palmLandmarks:e.palmLandmarks}}D.squarifyBox=L1;function H1(e,t){const o=[e.endPoint[0]-e.startPoint[0],e.endPoint[1]-e.startPoint[1]],n=[o[0]*t[0],o[1]*t[1]],i=[e.startPoint[0]+n[0],e.startPoint[1]+n[1]],s=[e.endPoint[0]+n[0],e.endPoint[1]+n[1]];return{startPoint:i,endPoint:s,palmLandmarks:e.palmLandmarks}}D.shiftBox=H1});var Dt=y(Ct=>{const g=require("@tensorflow/tfjs"),q1=ze();class j1{constructor(e,t,o){this.model=e,this.width=o.inputSize,this.height=o.inputSize,this.anchors=t.map(n=>[n.x_center,n.y_center]),this.anchorsTensor=g.tensor2d(this.anchors),this.inputSizeTensor=g.tensor1d([o.inputSize,o.inputSize]),this.doubleInputSizeTensor=g.tensor1d([o.inputSize*2,o.inputSize*2])}normalizeBoxes(e){return g.tidy(()=>{const t=g.slice(e,[0,0],[-1,2]),o=g.slice(e,[0,2],[-1,2]),n=g.add(g.div(t,this.inputSizeTensor),this.anchorsTensor),i=g.div(o,this.doubleInputSizeTensor),s=g.mul(g.sub(n,i),this.inputSizeTensor),r=g.mul(g.add(n,i),this.inputSizeTensor);return g.concat2d([s,r],1)})}normalizeLandmarks(e,t){return g.tidy(()=>{const o=g.add(g.div(e.reshape([-1,7,2]),this.inputSizeTensor),this.anchors[t]);return g.mul(o,this.inputSizeTensor)})}async getBoundingBoxes(e){const t=g.tidy(()=>g.mul(g.sub(e,.5),2)),o=this.model.predict(t),n=o.squeeze(),i=g.tidy(()=>g.sigmoid(g.slice(n,[0,0],[-1,1])).squeeze()),s=g.slice(n,[0,1],[-1,4]),r=this.normalizeBoxes(s),c=await g.image.nonMaxSuppressionAsync(r,i,this.maxHands,this.iouThreshold,this.scoreThreshold),a=await c.array(),d=[t,o,c,n,r,s,i];if(a.length===0)return d.forEach(h=>h.dispose()),null;const u=g.tidy(()=>{const h=[];for(const l in a){const p=a[l],m=g.slice(r,[p,0],[1,-1]),P=g.slice(n,[p,5],[1,14]),b=g.tidy(()=>this.normalizeLandmarks(P,p).reshape([-1,2]));h.push({boxes:m,palmLandmarks:b})}return h});return u}async estimateHandBounds(e,t){const o=e.shape[1],n=e.shape[2];this.iouThreshold=t.iouThreshold,this.scoreThreshold=t.scoreThreshold,this.maxHands=t.maxHands;const i=g.tidy(()=>e.resizeBilinear([this.width,this.height]).div(255)),s=await this.getBoundingBoxes(i);if(i.dispose(),!s||s.length===0)return null;const r=[];for(const c in s){const a=s[c],d=await a.boxes.array(),u=d[0].slice(0,2),h=d[0].slice(2,4),l=await a.palmLandmarks.array();a.boxes.dispose(),a.palmLandmarks.dispose(),r.push(q1.scaleBoxCoordinates({startPoint:u,endPoint:h,palmLandmarks:l},[n/this.width,o/this.height]))}return r}}Ct.HandDetector=j1});var vt=y(Ft=>{Ft.MESH_ANNOTATIONS={thumb:[1,2,3,4],indexFinger:[5,6,7,8],middleFinger:[9,10,11,12],ringFinger:[13,14,15,16],pinky:[17,18,19,20],palmBase:[0]}});var Ut=y(F=>{function Lt(e){return e-2*Math.PI*Math.floor((e+Math.PI)/(2*Math.PI))}F.normalizeRadians=Lt;function U1(e,t){const o=Math.PI/2-Math.atan2(-(t[1]-e[1]),t[0]-e[0]);return Lt(o)}F.computeRotation=U1;const Ht=(e,t)=>[[1,0,e],[0,1,t],[0,0,1]];function V(e,t){let o=0;for(let n=0;n<e.length;n++)o+=e[n]*t[n];return o}F.dot=V;function qt(e,t){const o=[];for(let n=0;n<e.length;n++)o.push(e[n][t]);return o}F.getColumnFrom2DArr=qt;function jt(e,t){const o=[],n=e.length;for(let i=0;i<n;i++){o.push([]);for(let s=0;s<n;s++)o[i].push(V(e[i],qt(t,s)))}return o}function W1(e,t){const o=Math.cos(e),n=Math.sin(e),i=[[o,-n,0],[n,o,0],[0,0,1]],s=Ht(t[0],t[1]),r=jt(s,i),c=Ht(-t[0],-t[1]);return jt(r,c)}F.buildRotationMatrix=W1;function K1(e){const t=[[e[0][0],e[1][0]],[e[0][1],e[1][1]]],o=[e[0][2],e[1][2]],n=[-V(t[0],o),-V(t[1],o)];return[t[0].concat(n[0]),t[1].concat(n[1]),[0,0,1]]}F.invertTransformMatrix=K1;function Y1(e,t){return[V(e,t[0]),V(e,t[1])]}F.rotatePoint=Y1});var Xt=y(Wt=>{const Kt=require("@tensorflow/tfjs"),_=ze(),v=Ut(),X1=.8,G1=[0,-.4],V1=[0,-.1],Q1=1.65,Yt=[0,5,9,13,17,1,2],Z1=0,$1=2;class J1{constructor(e,t,o){this.regionsOfInterest=[],this.runsWithoutHandDetector=0,this.boundingBoxDetector=e,this.meshDetector=t,this.meshWidth=o.inputSize,this.meshHeight=o.inputSize,this.enlargeFactor=o.enlargeFactor}getBoxForPalmLandmarks(e,t){const o=e.map(i=>{const s=[...i,1];return v.rotatePoint(s,t)}),n=this.calculateLandmarksBoundingBox(o);return _.enlargeBox(_.squarifyBox(_.shiftBox(n,G1)),this.enlargeFactor)}getBoxForHandLandmarks(e){const t=this.calculateLandmarksBoundingBox(e),o=_.enlargeBox(_.squarifyBox(_.shiftBox(t,V1)),Q1),n=[];for(let i=0;i<Yt.length;i++)n.push(e[Yt[i]].slice(0,2));return o.palmLandmarks=n,o}transformRawCoords(e,t,o,n){const i=_.getBoxSize(t),s=[i[0]/this.meshWidth,i[1]/this.meshHeight],r=e.map(l=>[s[0]*(l[0]-this.meshWidth/2),s[1]*(l[1]-this.meshHeight/2),l[2]]),c=v.buildRotationMatrix(o,[0,0]),a=r.map(l=>{const p=v.rotatePoint(l,c);return[...p,l[2]]}),d=v.invertTransformMatrix(n),u=[..._.getBoxCenter(t),1],h=[v.dot(u,d[0]),v.dot(u,d[1])];return a.map(l=>[l[0]+h[0],l[1]+h[1],l[2]])}async estimateHands(e,t){this.maxContinuousChecks=t.skipFrames,this.detectionConfidence=t.minConfidence,this.maxHands=t.maxHands;const o=this.shouldUpdateRegionsOfInterest();if(o===!0){const i=await this.boundingBoxDetector.estimateHandBounds(e,t);this.regionsOfInterest=[];for(const s in i)this.updateRegionsOfInterest(i[s],!0,s);this.runsWithoutHandDetector=0}else this.runsWithoutHandDetector++;const n=[];if(!this.regionsOfInterest)return n;for(const i in this.regionsOfInterest){const s=this.regionsOfInterest[i][0];if(!s)return n;const r=v.computeRotation(s.palmLandmarks[Z1],s.palmLandmarks[$1]),c=_.getBoxCenter(s),a=[c[0]/e.shape[2],c[1]/e.shape[1]],d=Kt.image.rotateWithOffset(e,r,0,a),u=v.buildRotationMatrix(-r,c),h=o?this.getBoxForPalmLandmarks(s.palmLandmarks,u):s,l=_.cutBoxFromImageAndResize(h,d,[this.meshWidth,this.meshHeight]),p=l.div(255);l.dispose(),d.dispose();const m=this.meshDetector.predict(p),[P,b]=m;p.dispose();const w=P.dataSync()[0];if(P.dispose(),w<t.minConfidence)return b.dispose(),this.regionsOfInterest[i]=[],n;const x=Kt.reshape(b,[-1,3]),R=await x.array();b.dispose(),x.dispose();const U=this.transformRawCoords(R,h,r,u),Q=this.getBoxForHandLandmarks(U);this.updateRegionsOfInterest(Q,!1,i);const W={landmarks:U,confidence:w,box:{topLeft:Q.startPoint,bottomRight:Q.endPoint}};n.push(W)}return n}calculateLandmarksBoundingBox(e){const t=e.map(s=>s[0]),o=e.map(s=>s[1]),n=[Math.min(...t),Math.min(...o)],i=[Math.max(...t),Math.max(...o)];return{startPoint:n,endPoint:i}}updateRegionsOfInterest(e,t,o){if(t)this.regionsOfInterest[o]=[e];else{const n=this.regionsOfInterest[o][0];let i=0;if(n!=null&&n.startPoint!=null){const[s,r]=e.startPoint,[c,a]=e.endPoint,[d,u]=n.startPoint,[h,l]=n.endPoint,p=Math.max(s,d),m=Math.max(r,u),P=Math.min(c,h),b=Math.min(a,l),w=(P-p)*(b-m),x=(c-s)*(a-r),R=(h-d)*(l-r);i=w/(x+R-w)}this.regionsOfInterest[o][0]=i>X1?n:e}}shouldUpdateRegionsOfInterest(){return!this.regionsOfInterest||this.regionsOfInterest.length===0||this.runsWithoutHandDetector>=this.maxContinuousChecks}}Wt.HandPipeline=J1});var Qt=y(Re=>{const q=require("@tensorflow/tfjs"),eo=Dt(),Gt=vt(),to=Xt();class Vt{constructor(e){this.pipeline=e}async estimateHands(e,t){this.maxContinuousChecks=t.skipFrames,this.detectionConfidence=t.minConfidence,this.maxHands=t.maxHands;const o=q.tidy(()=>(e instanceof q.Tensor||(e=q.browser.fromPixels(e)),e.toFloat().expandDims(0))),n=await this.pipeline.estimateHands(o,t);o.dispose();const i=[];if(!n)return i;for(const s of n){if(!s)return[];const r={};for(const c of Object.keys(Gt.MESH_ANNOTATIONS))r[c]=Gt.MESH_ANNOTATIONS[c].map(a=>s.landmarks[a]);i.push({confidence:s.confidence||0,box:s.box?[s.box.topLeft[0],s.box.topLeft[1],s.box.bottomRight[0]-s.box.topLeft[0],s.box.bottomRight[1]-s.box.topLeft[1]]:0,landmarks:s.landmarks,annotations:r})}return i}}Re.HandPose=Vt;async function oo(e){if(q.env().features.IS_NODE){const t=require("fs"),o=await t.readFileSync(e.replace("file://",""));return JSON.parse(o)}return q.util.fetch(e).then(t=>t.json())}async function no(e){const[t,o,n]=await Promise.all([oo(e.detector.anchors),q.loadGraphModel(e.detector.modelPath,{fromTFHub:e.detector.modelPath.includes("tfhub.dev")}),q.loadGraphModel(e.skeleton.modelPath,{fromTFHub:e.skeleton.modelPath.includes("tfhub.dev")})]),i=new eo.HandDetector(o,t,e),s=new to.HandPipeline(i,n,e),r=new Vt(s);return r}Re.load=no});var Zt=y(so=>{ve(so,{default:()=>io});var io={face:{enabled:!0,detector:{modelPath:"../models/blazeface/model.json",inputSize:128,maxFaces:10,skipFrames:10,minConfidence:.5,iouThreshold:.3,scoreThreshold:.7},mesh:{enabled:!0,modelPath:"../models/facemesh/model.json",inputSize:192},iris:{enabled:!0,modelPath:"../models/iris/model.json",enlargeFactor:2.3,inputSize:64},age:{enabled:!0,modelPath:"../models/ssrnet-age/imdb/model.json",inputSize:64,skipFrames:10},gender:{enabled:!0,modelPath:"../models/ssrnet-gender/imdb/model.json"}},body:{enabled:!0,modelPath:"../models/posenet/model.json",inputResolution:257,outputStride:16,maxDetections:5,scoreThreshold:.7,nmsRadius:20},hand:{enabled:!0,inputSize:256,skipFrames:10,minConfidence:.5,iouThreshold:.3,scoreThreshold:.7,enlargeFactor:1.65,maxHands:2,detector:{anchors:"../models/handdetect/anchors.json",modelPath:"../models/handdetect/model.json"},skeleton:{modelPath:"../models/handskeleton/model.json"}}}});var n0=y(z=>{const j=require("@tensorflow/tfjs"),$t=st(),re=rt(),Jt=Ot(),e0=Qt(),t0=Zt().default,k={facemesh:null,blazeface:null,ssrnet:null,iris:null};function o0(...e){const t=o=>o&&typeof o=="object";return e.reduce((o,n)=>(Object.keys(n||{}).forEach(i=>{const s=o[i],r=n[i];Array.isArray(s)&&Array.isArray(r)?o[i]=s.concat(...r):t(s)&&t(r)?o[i]=o0(s,r):o[i]=r}),o),{})}async function ro(e,t){return new Promise(async o=>{const n=o0(t0,t);n.face.age.enabled&&await re.loadAge(n),n.face.gender.enabled&&await re.loadGender(n),n.body.enabled&&!k.posenet&&(k.posenet=await Jt.load(n.body)),n.hand.enabled&&!k.handpose&&(k.handpose=await e0.load(n.hand)),n.face.enabled&&!k.facemesh&&(k.facemesh=await $t.load(n.face)),j.engine().startScope();let i;j.getBackend()==="webgl"&&(i=j.env().get("WEBGL_PACK_DEPTHWISECONV"),j.env().set("WEBGL_PACK_DEPTHWISECONV",!0));const s={};let r;r=performance.now();let c=[];n.body.enabled&&(c=await k.posenet.estimatePoses(e,n.body)),s.body=Math.trunc(performance.now()-r),r=performance.now();let a=[];n.hand.enabled&&(a=await k.handpose.estimateHands(e,n.hand)),s.hand=Math.trunc(performance.now()-r);const d=[];if(n.face.enabled){r=performance.now();const u=await k.facemesh.estimateFaces(e,n.face);s.face=Math.trunc(performance.now()-r);for(const h of u){r=performance.now();const l=n.face.age.enabled||n.face.gender.enabled?await re.predict(h.image,n):{};s.agegender=Math.trunc(performance.now()-r),h.image.dispose();const p=h.annotations.leftEyeIris&&h.annotations.rightEyeIris?Math.max(h.annotations.leftEyeIris[3][0]-h.annotations.leftEyeIris[1][0],h.annotations.rightEyeIris[3][0]-h.annotations.rightEyeIris[1][0]):0;d.push({confidence:h.confidence,box:h.box,mesh:h.mesh,annotations:h.annotations,age:l.age,gender:l.gender,iris:p!==0?Math.trunc(100*11.7/p)/100:0})}}j.env().set("WEBGL_PACK_DEPTHWISECONV",i),j.engine().endScope(),s.total=Object.values(s).reduce((u,h)=>u+h),console.log("total",s.total),o({face:d,body:c,hand:a,performance:s})})}z.detect=ro;z.defaults=t0;z.models=k;z.facemesh=$t;z.ssrnet=re;z.posenet=Jt;z.handpose=e0;z.tf=j});export default n0();
|
|
//# sourceMappingURL=human.nobundle.js.map
|